1 Star 0 Fork 1

王布衣 / num

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
type_float32.go 3.19 KB
一键复制 编辑 原始数据 按行查看 历史
package num
import (
"fmt"
"gitee.com/quant1x/gox/exception"
"gitee.com/quant1x/gox/logger"
"gitee.com/quant1x/num/x32"
"math"
"reflect"
"strconv"
)
const (
errorFloat32Base = errorTypeBase + int(reflect.Float32)*100
)
const (
MaxFloat32 = float32(math.MaxFloat32) // float32最大值
MinFloat32 = float32(math.SmallestNonzeroFloat32) // float32最小值
StringTrue2Float32 float32 = float32(1) // 字符串true转float32
StringFalse2Float32 float32 = float32(0) // 字符串false转float32
)
var (
__nilToFloat32 = float32(math.NaN())
)
func Float32NaN() float32 {
return float32(NaN())
}
// Float32IsNaN 判断float32是否NaN
func Float32IsNaN(f float32) bool {
return Float64IsNaN(float64(f))
}
// 普通的处理方式, 将切片强制转换成float32
func sliceNumberToFloat32[T Number](s []T) []float32 {
count := len(s)
if count == 0 {
return []float32{}
}
d := make([]float32, count)
for idx, iv := range s {
// 强制转换
d[idx] = float32(iv)
}
return d
}
// SliceToFloat32 any输入只能是一维slice或者数组
func SliceToFloat32(v any) []float32 {
var vs []float32
switch values := v.(type) {
case []int8:
return sliceNumberToFloat32(values)
case []uint8:
return sliceNumberToFloat32(values)
case []int16:
return sliceNumberToFloat32(values)
case []uint16:
return sliceNumberToFloat32(values)
case []int32: // 加速
return x32.FromInt32(values)
case []uint32:
return sliceNumberToFloat32(values)
case []int64: // 加速
return x32.FromInt64(values)
case []uint64:
return sliceNumberToFloat32(values)
case []int:
return sliceNumberToFloat32(values)
case []uint:
return sliceNumberToFloat32(values)
case []float32: // 克隆
//return slices.Clone(values)
return values
case []float64: // 加速
return x32.FromFloat64(values)
case []bool:
count := len(values)
if count == 0 {
return []float32{}
}
// 加速
return x32.FromBool(values)
case []string:
count := len(values)
if count == 0 {
return []float32{}
}
vs = make([]float32, count)
for idx, iv := range values {
vs[idx] = float32(AnyToFloat64(iv))
}
default:
vv := reflect.ValueOf(v)
vk := vv.Kind()
panic(exception.New(errorFloat32Base+0, fmt.Sprintf("Unsupported type: %s", vk.String())))
}
return []float32{}
}
// ParseFloat32 字符串转float32
func ParseFloat32(s string, v any) float32 {
defer func() {
// 解析失败以后输出日志, 以备检查
if err := recover(); err != nil {
logger.Errorf("ParseFloat32 %+v, error=%+v\n", v, err)
}
}()
if IsEmpty(s) {
// TODO:NaN是针对64位, 这样直接转换应该有问题, 需要进一步确认
return __nilToFloat32
}
if StringIsTrue(s) {
return StringTrue2Float32
} else if StringIsFalse(s) {
return StringFalse2Float32
}
f, err := strconv.ParseFloat(s, 32)
if err == nil {
return float32(f)
}
if IgnoreParseExceptions {
return __nilToFloat32
}
_ = v.(float32) // Intentionally panic
return __nilToFloat32
}
func AnyToFloat32(v any) float32 {
if vv, ok := ExtractValueFromPointer(v); ok {
v = vv
}
f := valueToNumber(v, __nilToFloat32, BoolToFloat32, ParseFloat32)
return f
}
Go
1
https://gitee.com/quant1x/num.git
git@gitee.com:quant1x/num.git
quant1x
num
num
v0.3.1

搜索帮助