prediction about to test

This commit is contained in:
bel
2023-10-27 07:38:09 -06:00
parent 2af03d4e84
commit 086ada530f
3 changed files with 104 additions and 0 deletions

View File

@@ -1,3 +1,44 @@
package ana
import (
"maps"
"time"
"gogs.inhome.blapointe.com/ana-ledger/ledger"
)
type Prediction []Predictor
func NewPrediction(predictor ...Predictor) Prediction {
return Prediction(predictor)
}
func (prediction Prediction) Predict(register ledger.Register, window time.Duration) ledger.Register {
return prediction.predict(register.Latest(), time.Now(), predictionTimes(window))
}
func (prediction Prediction) predict(latest ledger.Balances, from time.Time, these []time.Time) ledger.Register {
latestT := from
result := make(ledger.Register)
for i := range these {
k := these[i].Format("2006-01")
result[k] = make(ledger.Balances)
for k2, v2 := range result[k] {
result[k][k2] = maps.Clone(v2)
}
elapsed := these[i].Sub(latestT)
result[k] = prediction.predictOne(result[k], elapsed)
latest = result[k]
latestT = these[i]
}
return result
}
func (prediction Prediction) predictOne(balances ledger.Balances, elapsed time.Duration) ledger.Balances {
for i := range prediction {
balances = prediction[i](balances, elapsed)
}
return balances
}