dollarcostaverage

package
v0.0.0-...-4fcee84 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 2, 2025 License: MIT Imports: 8 Imported by: 3

README

GoCryptoTrader Backtester: Dollarcostaverage package

Build Status Software License GoDoc Coverage Status Go Report Card

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

View Source
const (
	// Name is the strategy name
	Name = "dollarcostaverage"
)

Variables

This section is empty.

Functions

This section is empty.

Types

type Strategy

type Strategy struct {
	base.Strategy
}

Strategy is an implementation of the Handler interface

func (*Strategy) Description

func (s *Strategy) Description() string

Description provides a nice overview of the strategy be it definition of terms or to highlight its purpose

func (*Strategy) Name

func (s *Strategy) Name() string

Name returns the name

func (*Strategy) OnSignal

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

func (s *Strategy) SetCustomSettings(_ map[string]interface{}) error

SetCustomSettings not required for DCA

func (*Strategy) SetDefaults

func (s *Strategy) SetDefaults()

SetDefaults not required for DCA

func (*Strategy) SupportsSimultaneousProcessing

func (s *Strategy) SupportsSimultaneousProcessing() bool

SupportsSimultaneousProcessing highlights whether the strategy can handle multiple currency calculation

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL