Skip to content

Commit

Permalink
Add ad indicator
Browse files Browse the repository at this point in the history
  • Loading branch information
narumiruna committed May 10, 2021
1 parent 95d58e9 commit 7cc5485
Show file tree
Hide file tree
Showing 2 changed files with 81 additions and 0 deletions.
66 changes: 66 additions & 0 deletions pkg/indicator/ad.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
package indicator

import (
"time"

"github.com/c9s/bbgo/pkg/types"
)

/*
ad implements accumulation/distribution indicator
Accumulation/Distribution Indicator (A/D)
- https://www.investopedia.com/terms/a/accumulationdistribution.asp
*/
//go:generate callbackgen -type AD
type AD struct {
types.IntervalWindow
Values Float64Slice
PrePrice float64

EndTime time.Time
UpdateCallbacks []func(value float64)
}

func (inc *AD) update(kLine types.KLine) {
close := kLine.Close
high := kLine.High
low := kLine.Low
volume := kLine.Volume

moneyFlowVolume := ((2*close - high - low) / (high - low)) * volume

ad := inc.Last() + moneyFlowVolume
inc.Values.Push(ad)
}

func (inc *AD) Last() float64 {
if len(inc.Values) == 0 {
return 0.0
}
return inc.Values[len(inc.Values)-1]
}

func (inc *AD) calculateAndUpdate(kLines []types.KLine) {
for i, k := range kLines {
if inc.EndTime != zeroTime && k.EndTime.Before(inc.EndTime) {
continue
}

inc.update(k)
inc.EmitUpdate(inc.Last())
inc.EndTime = kLines[i].EndTime
}

}
func (inc *AD) handleKLineWindowUpdate(interval types.Interval, window types.KLineWindow) {
if inc.Interval != interval {
return
}

inc.calculateAndUpdate(window)
}

func (inc *AD) Bind(updater KLineWindowUpdater) {
updater.OnKLineWindowUpdate(inc.handleKLineWindowUpdate)
}
15 changes: 15 additions & 0 deletions pkg/indicator/ad_callbacks.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 7cc5485

Please sign in to comment.