1 Star 0 Fork 0

younland / godas

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
last.go 651 Bytes
一键复制 编辑 原始数据 按行查看 历史
package formula
import (
"gitee.com/younland/godas/stat"
)
// LAST LAST(X,A,B):持续存在.
//
// A 支持序列化, B不支持
// 例如:
// LAST(CLOSE>OPEN,10,5)
// 表示从前10日到前5日内一直阳线
// 若A为0,表示从第一天开始,B为0,表示到最后日止
func LAST(X stat.Series, A, B int) stat.Series {
s := X.Rolling(A + 1).Apply(func(S stat.Series, N stat.DType) stat.DType {
s := S.DTypes()
s = stat.Reverse(s)
T := s[B:]
n := len(T)
for _, v := range T {
if v != 0 {
n--
}
}
if n == 0 {
return 1
} else {
return 0
}
})
d := s.Values().([]stat.DType)
stat.Fill(d, 1, true)
return s
}
1
https://gitee.com/younland/godas.git
git@gitee.com:younland/godas.git
younland
godas
godas
v1.0.1

搜索帮助