1 Star 4 Fork 13

王布衣/pandas

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
series_shift.go 1.24 KB
一键复制 编辑 原始数据 按行查看 历史
王布衣 提交于 2023-02-16 12:02 . !61#I6CYP6实现通达信LLVBARS函数
package pandas
import (
"gitee.com/quant1x/pandas/stat"
"math"
)
// Shift series切片, 使用可选的时间频率按所需的周期数移动索引
func Shift[T stat.GenericType](s *stat.Series, periods int, cbNan func() T) stat.Series {
var d stat.Series
d = stat.Clone(*s).(stat.Series)
if periods == 0 {
return d
}
values := d.Values().([]T)
var (
naVals []T
dst []T
src []T
)
if shlen := int(math.Abs(float64(periods))); shlen < len(values) {
if periods > 0 {
naVals = values[:shlen]
dst = values[shlen:]
src = values
} else {
naVals = values[len(values)-shlen:]
dst = values[:len(values)-shlen]
src = values[shlen:]
}
copy(dst, src)
} else {
naVals = values
}
for i := range naVals {
naVals[i] = cbNan()
}
_ = naVals
return d
}
// Shift2 series切片, 使用可选的时间频率按所需的周期数移动索引
func Shift2[T stat.GenericType](s *stat.Series, N []float32, cbNan func() T) stat.Series {
var d stat.Series
d = stat.Clone(*s).(stat.Series)
if len(N) == 0 {
return d
}
S := (*s).Values().([]T)
values := d.Values().([]T)
for i, _ := range S {
x := N[i]
if stat.Float32IsNaN(x) || int(x) > i {
values[i] = cbNan()
continue
}
values[i] = S[i-int(x)]
}
return d
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/quant1x/pandas.git
git@gitee.com:quant1x/pandas.git
quant1x
pandas
pandas
v0.6.6

搜索帮助