代码拉取完成,页面将自动刷新
package formula
import (
"gitee.com/quant1x/pandas/stat"
"github.com/mymmsc/gox/exception"
)
// SMA 中国式的SMA,至少需要120周期才精确 (雪球180周期) alpha=1/(1+com)
func SMA(S stat.Series, N any, M int) stat.Series {
if M == 0 {
M = 1
}
var X float32
switch v := N.(type) {
case int:
X = float32(v)
case stat.Series:
vs := v.Values()
fs := stat.SliceToFloat32(vs)
X = fs[len(fs)-1]
default:
panic(exception.New(1, "error window"))
}
//x := S.EWM(stat.EW{Alpha: float64(M) / float64(X), Adjust: false}).Mean().Values()
x := S.EWM(stat.EW{Alpha: float64(M) / float64(X), Adjust: false}).Mean()
return x
}
// 最接近
func SMA_v5(S stat.Series, N any, M int) any {
if M == 0 {
M = 1
}
var X []float32
switch v := N.(type) {
case int:
X = stat.Repeat[float32](float32(v), S.Len())
case stat.Series:
vs := v.Values()
X = stat.SliceToFloat32(vs)
X = stat.Align(X, stat.Nil2Float32, S.Len())
default:
panic(exception.New(1, "error window"))
}
k := X[0]
x := S.EWM(stat.EW{Alpha: stat.Nil2Float64, Callback: func(idx int) stat.DType {
j := X[idx]
if j == 0 {
j = 1
} else {
k = j
}
return float64(M) / float64(j)
}, Adjust: false}).Mean().Values()
_ = k
return x
}
// SMA_v4 听说SMA(S, N, 1) 其实就是MA(S,N), 试验后发现是骗子
func SMA_v4(S stat.Series, N any, M int) any {
var X []float32
switch v := N.(type) {
case int:
X = stat.Repeat[float32](float32(v), S.Len())
case stat.Series:
vs := v.Values()
X = stat.SliceToFloat32(vs)
X = stat.Align(X, stat.Nil2Float32, S.Len())
default:
panic(exception.New(1, "error window"))
}
return S.Rolling(X).Mean().Values()
}
// SMA_v3 使用滑动窗口
func SMA_v3(S stat.Series, N any, M int) any {
if M == 0 {
M = 1
}
x := S.Rolling(N).Apply(func(S stat.Series, N stat.DType) stat.DType {
r := S.EWM(stat.EW{Alpha: float64(M) / float64(N), Adjust: false}).Mean().Values().([]float64)
if len(r) == 0 {
return stat.DTypeNaN
}
return stat.DType(r[len(r)-1])
}).Values()
return x
}
// SMA_v1 最原始的python写法
func SMA_v1(S stat.Series, N int, M int) any {
if M == 0 {
M = 1
}
x := S.EWM(stat.EW{Alpha: float64(M) / float64(N), Adjust: false}).Mean().Values()
return x
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。