You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

88 lines
1.8 KiB
Go

8 years ago
package ent
import (
"math"
8 years ago
"github.com/jordanorelli/hyperstone/bit"
)
const (
f_min = 1 << iota
f_max
f_center
)
func floatType(spec *typeSpec, env *Env) tÿpe {
switch spec.typeName {
8 years ago
case "CNetworkedQuantizedFloat":
return qFloatType(spec, env)
8 years ago
case "float32":
default:
return nil
}
if spec.encoder == "coord" {
return nil
}
if spec.serializer == "simulationtime" {
return nil
}
switch spec.bits {
case 0, 32:
8 years ago
Debug.Printf(" std float type")
return typeFn(float_t)
default:
return qFloatType(spec, env)
8 years ago
}
}
func qFloatType(spec *typeSpec, env *Env) tÿpe {
if spec.bits < 0 {
8 years ago
return typeError("quantized float has invalid negative bit count specifier")
}
if spec.high-spec.low < 0 {
8 years ago
return typeError("quantized float has invalid negative range")
}
t := qfloat_t{typeSpec: *spec}
8 years ago
t.span = t.high - t.low
t.intervals = uint(1<<t.bits - 1)
t.interval = t.span / float32(t.intervals)
if t.flags > 0 {
t.special = new(float32)
switch t.flags {
case f_min:
*t.special = t.low
case f_max:
*t.special = t.high
case f_center:
*t.special = t.low + (t.high+t.low)*0.5
default:
return typeError("dunno how to handle qfloat flag value: %d", t.flags)
}
8 years ago
}
8 years ago
Debug.Printf(" qfloat type")
8 years ago
return t
}
type qfloat_t struct {
typeSpec
8 years ago
span float32 // total range of values
intervals uint // number of intervals in the quantization range
interval float32 // width of one interval
special *float32
}
func (t qfloat_t) read(r bit.Reader) (value, error) {
if t.special != nil && bit.ReadBool(r) {
return *t.special, nil
}
return t.low + float32(r.ReadBits(t.bits))*t.interval, r.Err()
}
func float_t(r bit.Reader) (value, error) {
// TODO: check uint32 overflow here?
return math.Float32frombits(uint32(r.ReadBits(32))), r.Err()
8 years ago
}