README
¶
GoCryptoTrader Backtester: Dollarcostaverage package

This dollarcostaverage package is part of the GoCryptoTrader codebase.
This is still in active development
You can track ideas, planned features and what's in progress on our GoCryptoTrader Kanban board.
Join our slack to discuss all things related to GoCryptoTrader! GoCryptoTrader Slack
Dollarcostaverage package overview
The dollar cost average is a strategy which is designed to purchase on every data candle. Unless data is missing, all output signals will be to buy.
This strategy supports simultaneous signal processing, aka config.StrategySettings.SimultaneousSignalProcessing
set to true will use the function OnSignals(d []data.Handler, p portfolio.Handler) ([]signal.Event, error)
. This function, like the basic OnSignal
function, will signal to buy on every iteration.
This strategy does not support customisation
Please click GoDocs chevron above to view current GoDoc information for this package
Contribution
Please feel free to submit any pull requests or suggest any desired features to be added.
When submitting a PR, please abide by our coding guidelines:
- Code must adhere to the official Go formatting guidelines (i.e. uses gofmt).
- Code must be documented adhering to the official Go commentary guidelines.
- Code must adhere to our coding style.
- Pull requests need to be based on and opened against the
master
branch.
Donations

If this framework helped you in any way, or you would like to support the developers working on it, please donate Bitcoin to:
bc1qk0jareu4jytc0cfrhr5wgshsq8282awpavfahc
Documentation
¶
Index ¶
- Constants
- type Strategy
- func (s *Strategy) Description() string
- func (s *Strategy) Name() string
- func (s *Strategy) OnSignal(d data.Handler, _ funding.IFundingTransferer, _ portfolio.Handler) (signal.Event, error)
- func (s *Strategy) OnSimultaneousSignals(d []data.Handler, _ funding.IFundingTransferer, _ portfolio.Handler) ([]signal.Event, error)
- func (s *Strategy) SetCustomSettings(_ map[string]interface{}) error
- func (s *Strategy) SetDefaults()
- func (s *Strategy) SupportsSimultaneousProcessing() bool
Constants ¶
const (
// Name is the strategy name
Name = "dollarcostaverage"
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Strategy ¶
Strategy is an implementation of the Handler interface
func (*Strategy) Description ¶
Description provides a nice overview of the strategy be it definition of terms or to highlight its purpose
func (*Strategy) OnSignal ¶
func (s *Strategy) OnSignal(d data.Handler, _ funding.IFundingTransferer, _ portfolio.Handler) (signal.Event, error)
OnSignal handles a data event and returns what action the strategy believes should occur For dollarcostaverage, this means returning a buy signal on every event
func (*Strategy) OnSimultaneousSignals ¶
func (s *Strategy) OnSimultaneousSignals(d []data.Handler, _ funding.IFundingTransferer, _ portfolio.Handler) ([]signal.Event, error)
OnSimultaneousSignals analyses multiple data points simultaneously, allowing flexibility in allowing a strategy to only place an order for X currency if Y currency's price is Z For dollarcostaverage, the strategy is always "buy", so it uses the OnSignal function
func (*Strategy) SetCustomSettings ¶
SetCustomSettings not required for DCA
func (*Strategy) SupportsSimultaneousProcessing ¶
SupportsSimultaneousProcessing highlights whether the strategy can handle multiple currency calculation