代码拉取完成,页面将自动刷新
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
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。