1 Star 4 Fork 11

王布衣 / pandas

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
series_min.go 1.88 KB
一键复制 编辑 原始数据 按行查看 历史
王布衣 提交于 2023-02-16 12:02 . !61#I6CYP6实现通达信LLVBARS函数
package pandas
import "gitee.com/quant1x/pandas/stat"
func (self *NDFrame) Min() any {
values := self.Values()
switch rows := values.(type) {
case []bool:
min := true
i := 0
for idx, iv := range rows {
if !iv && min {
min = iv
i += 1
}
_ = idx
}
if i > 0 {
return min
}
return false
case []string:
min := ""
hasNaN := false
i := 0
for idx, iv := range rows {
if stat.StringIsNaN(iv) {
hasNaN = true
break
} else if i < 1 {
min = iv
i += 1
}
if iv < min {
min = iv
i += 1
}
_ = idx
}
if hasNaN {
return stat.StringNaN
} else if i > 0 {
return min
}
return stat.StringNaN
case []int64:
min := stat.MaxInt64
i := 0
for idx, iv := range rows {
if stat.Float64IsNaN(float64(iv)) {
continue
} else if i < 1 {
min = iv
i += 1
}
if iv < min {
min = iv
i += 1
}
_ = idx
}
return min
case []float32:
min := stat.MaxFloat32
hasNan := false
i := 0
for idx, iv := range rows {
if stat.Float32IsNaN(iv) {
hasNan = true
break
}
if iv < min {
min = iv
i += 1
}
_ = idx
}
if hasNan {
return stat.Nil2Float32
} else if i > 0 {
return min
}
return stat.Nil2Float32
//case []float32:
// if self.Len() == 0 {
// return Nil2Float32
// }
// return stat.Min(rows)
case []float64:
min := stat.MaxFloat64
hasNaN := false
i := 0
for idx, iv := range rows {
if stat.Float64IsNaN(iv) {
hasNaN = true
break
}
if iv < min {
min = iv
i += 1
}
_ = idx
}
if hasNaN {
return stat.Nil2Float64
} else if i > 0 {
return min
}
return stat.Nil2Float64
//case []float64:
// if self.Len() == 0 {
// return Nil2Float64
// }
// return stat.Min(rows)
default:
panic(ErrUnsupportedType)
}
return stat.Nil2Float64
}
func (self *NDFrame) ArgMin() int {
return stat.ArgMin2(self.DTypes())
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/quant1x/pandas.git
git@gitee.com:quant1x/pandas.git
quant1x
pandas
pandas
v0.6.8

搜索帮助

344bd9b3 5694891 D2dac590 5694891