1 Star 0 Fork 1

王布衣 / num

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
ndarray.go 1.34 KB
一键复制 编辑 原始数据 按行查看 历史
王布衣 提交于 2024-02-23 13:36 . num新增NDArray封装, 私有
package num
type ndarray[E BaseType] []E
func (this *ndarray[E]) Shift(n any) ndarray[E] {
return Shift(*this, n)
}
// 切片边界检查
func (this *ndarray[E]) checkBoundary(index int) bool {
length := len(*this)
return index >= 0 && index < length
}
func (this *ndarray[E]) Rolling(n any, apply func(index int, v E) E) []E {
return this.v2Rolling(n, apply)
}
func (this *ndarray[E]) v1Rolling(n any, apply func(index int, v E) E) []E {
length := len(*this)
d := make([]E, length)
window := Any2Window[DType](n)
defaultValue := TypeDefault[E]()
for i, v := range *this {
val := v
period := window.At(i)
if DTypeIsNaN(period) {
val = defaultValue
} else {
newIndex := i - int(period)
if newIndex < 0 || newIndex >= length {
val = defaultValue
} else {
val = apply(i, (*this)[newIndex])
}
}
d[i] = val
}
return d
}
func (this *ndarray[E]) v2Rolling(n any, apply func(index int, v E) E) []E {
length := len(*this)
d := make([]E, length)
window := Any2Window[DType](n)
defaultValue := TypeDefault[E]()
for i := 0; i < length; i++ {
val := (*this)[i]
period := window.At(i)
if DTypeIsNaN(period) {
val = defaultValue
} else {
newIndex := i - int(period)
if newIndex < 0 || newIndex >= length {
val = defaultValue
} else {
val = apply(i, (*this)[newIndex])
}
}
d[i] = val
}
return d
}
Go
1
https://gitee.com/quant1x/num.git
git@gitee.com:quant1x/num.git
quant1x
num
num
v0.2.9

搜索帮助