wip
parent
f49308d4d5
commit
76aa4ff34a
|
|
@ -0,0 +1,68 @@
|
||||||
|
package ledger
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"log"
|
||||||
|
"maps"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func RegisterWithContributionPrediction(reg map[string]Balances, windowAsPercentOfTotalDuration float64) (map[string]Balances, error) {
|
||||||
|
return reg, io.EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
func BPIWithFixedGrowthPrediction(reg map[string]Balances, windowAsPercentOfTotalDuration float64, pattern string, rate float64) (map[string]Balances, error) {
|
||||||
|
result := make(map[string]Balances)
|
||||||
|
return result, io.EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
func RegisterWithCompoundingInterestPrediction(reg map[string]Balances, windowAsPercentOfTotalDuration float64, pattern string, rate float64) (map[string]Balances, error) {
|
||||||
|
nameToLastDate := func() map[string]string {
|
||||||
|
result := map[string]string{}
|
||||||
|
for date, balances := range reg {
|
||||||
|
for name := range balances {
|
||||||
|
if result[name] < date {
|
||||||
|
result[name] = date
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
}()
|
||||||
|
firstTime, lastTime := func() (time.Time, time.Time) {
|
||||||
|
var latest time.Time
|
||||||
|
first := time.Now()
|
||||||
|
for _, v := range nameToLastDate {
|
||||||
|
v2, _ := dateToTime(v)
|
||||||
|
if latest.Before(v2) {
|
||||||
|
latest = v2
|
||||||
|
}
|
||||||
|
if first.Before(v2) {
|
||||||
|
first = v2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return first, latest
|
||||||
|
}()
|
||||||
|
log.Println("first", firstTime, "last time", lastTime, "nameToDate", nameToLastDate)
|
||||||
|
|
||||||
|
lastPrediction := lastTime
|
||||||
|
for lastPrediction.Before(lastTime.Add(lastTime.Sub(firstTime) * time.Duration(windowAsPercentOfTotalDuration))) {
|
||||||
|
lastPrediction = lastPrediction.Add(time.Hour * 24 * (45 - lastPrediction.Day()))
|
||||||
|
TODO ^
|
||||||
|
}
|
||||||
|
|
||||||
|
result := maps.Clone(reg)
|
||||||
|
return result, io.EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
func dateToTime(s string) (time.Time, error) {
|
||||||
|
for _, layout := range []string{
|
||||||
|
"2006-01-02",
|
||||||
|
"2006-01",
|
||||||
|
} {
|
||||||
|
if t, err := time.ParseInLocation(layout, s, time.Local); err == nil {
|
||||||
|
return t, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return time.Time{}, fmt.Errorf("no layout matching %q", s)
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,61 @@
|
||||||
|
package ledger
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestRegisterPrediction(t *testing.T) {
|
||||||
|
t.Run("contribution", func(t *testing.T) {
|
||||||
|
input := newTestRegister()
|
||||||
|
|
||||||
|
got, err := RegisterWithContributionPrediction(input, .12)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
t.Logf("%+v", got)
|
||||||
|
|
||||||
|
if len(got) != len(input)+1 {
|
||||||
|
t.Error(len(got))
|
||||||
|
}
|
||||||
|
if _, ok := got["2001-11"]; !ok {
|
||||||
|
t.Error(ok)
|
||||||
|
}
|
||||||
|
t.Error("not impl")
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("compounding interest", func(t *testing.T) {
|
||||||
|
input := newTestRegister()
|
||||||
|
|
||||||
|
got, err := RegisterWithCompoundingInterestPrediction(input, 1, "X", .04)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
t.Logf("%+v", got)
|
||||||
|
|
||||||
|
if len(got) <= len(input) {
|
||||||
|
t.Error(len(got))
|
||||||
|
}
|
||||||
|
t.Error("not impl")
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestBPIPrediction(t *testing.T) {
|
||||||
|
t.Run("fixed growth", func(t *testing.T) {
|
||||||
|
t.Error("not impl")
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func newTestRegister() map[string]Balances {
|
||||||
|
return map[string]Balances{
|
||||||
|
"2001-01": Balances{"X": Balance{USD: 1}},
|
||||||
|
"2001-02": Balances{"X": Balance{USD: 2}},
|
||||||
|
"2001-03": Balances{"X": Balance{USD: 3}},
|
||||||
|
"2001-04": Balances{"X": Balance{USD: 4}},
|
||||||
|
"2001-05": Balances{"X": Balance{USD: 5}},
|
||||||
|
"2001-06": Balances{"X": Balance{USD: 6}},
|
||||||
|
"2001-07": Balances{"X": Balance{USD: 8}},
|
||||||
|
"2001-08": Balances{"X": Balance{USD: 10}},
|
||||||
|
"2001-09": Balances{"X": Balance{USD: 12}},
|
||||||
|
"2001-10": Balances{"X": Balance{USD: 16}},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
package ledger
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"io"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
func RegisterWithContributionPrediction(reg map[string]Balances, windowAsPercentOfTotalDuration float64) (map[string]Balances, error) {
|
|
||||||
return reg, io.EOF
|
|
||||||
}
|
|
||||||
|
|
||||||
func RegisterWithCompoundingInterestPrediction(reg map[string]Balances, windowAsPercentOfTotalDuration float64, name string, rate float64) (map[string]Balances, error) {
|
|
||||||
result := make(map[string]Balances)
|
|
||||||
return result, io.EOF
|
|
||||||
}
|
|
||||||
|
|
||||||
func dateToTime(s string) (time.Time, error) {
|
|
||||||
for _, layout := range []string{
|
|
||||||
"2006-01-02",
|
|
||||||
"2006-01",
|
|
||||||
} {
|
|
||||||
if t, err := time.ParseInLocation(layout, s, time.Local); err == nil {
|
|
||||||
return t, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return time.Time{}, fmt.Errorf("no layout matching %q", s)
|
|
||||||
}
|
|
||||||
|
|
@ -1,31 +0,0 @@
|
||||||
package ledger
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestRegisterPredictContribution(t *testing.T) {
|
|
||||||
input := map[string]Balances{
|
|
||||||
"2001-01": Balances{"X": Balance{USD: 1}},
|
|
||||||
"2001-02": Balances{"X": Balance{USD: 2}},
|
|
||||||
"2001-03": Balances{"X": Balance{USD: 3}},
|
|
||||||
"2001-04": Balances{"X": Balance{USD: 4}},
|
|
||||||
"2001-05": Balances{"X": Balance{USD: 5}},
|
|
||||||
"2001-06": Balances{"X": Balance{USD: 6}},
|
|
||||||
"2001-07": Balances{"X": Balance{USD: 8}},
|
|
||||||
"2001-08": Balances{"X": Balance{USD: 10}},
|
|
||||||
"2001-09": Balances{"X": Balance{USD: 12}},
|
|
||||||
"2001-10": Balances{"X": Balance{USD: 16}},
|
|
||||||
}
|
|
||||||
got, err := RegisterWithContributionPrediction(input, .12)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
if len(got) != len(input)+1 {
|
|
||||||
t.Error(len(got))
|
|
||||||
}
|
|
||||||
if _, ok := got["2001-11"]; !ok {
|
|
||||||
t.Error(ok)
|
|
||||||
}
|
|
||||||
t.Logf("%+v", got)
|
|
||||||
}
|
|
||||||
Loading…
Reference in New Issue