Files
Adrian Gallagher bb122dcafa codebase: Remove web frontend and related services (#2067)
* codebase: Remove web frontend and related services

* refactor: Update StartPPROF to accept context and adjust related tests

* refactor: Simplify SetIfZero functions and update related tests

* config: Clarify DowngradeConfig method documentation regarding permanent removal of deprecated fields

* refactor: Rename setIfZeroAndWarn to setDefaultIfZeroWarn for clarity and update related calls

* refactor: Update error handling in DataHistoryManager and remove redundant error variable
2025-09-30 13:32:09 +10:00

3.8 KiB

GoCryptoTrader Backtester: Portfolio package

Build Status Software License GoDoc Coverage Status Go Report Card

This portfolio 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

Portfolio package overview

The portfolio is one of the most critical packages in the GoCryptoTrader Backtester. It is responsible for making sure that all orders, simulated or otherwise are within all defined risk and sizing rules defined in the config. The portfolio receives three kinds of events to be processed: OnSignal, OnFill and Update

The following steps are taken for the OnSignal function:

  • Retrieve previous iteration's holdings data
  • If a buy order signal is received, ensure there are enough funds
  • If a sell order signal is received, ensure there are any holdings to sell
  • If any other direction, return
  • The portfolio manager will then size the order according to the exchange asset currency pair's settings along with the portfolio manager's own sizing rules
    • In the event that the order is to large, the sizing package will reduce the order until it fits that limit, inclusive of fees.
    • When an order is sized under the limits, an order event cannot be raised an no order will be submitted by the exchange
    • The portfolio manager's sizing rules override any CurrencySettings' rules if the sizing is outside the portfolio manager's
  • The portfolio manager will then assess the risk of the order, it will compare existing holdings and ensures that if an order is placed, it will not go beyond risk rules as defined in the config
  • If the risk is too high, the order signal will be changed to CouldNotBuy, CouldNotSell or DoNothing
  • If the order is deemed appropriate, the order event will be returned and appended to the event queue for the exchange event handler to run and place the order

The following steps are taken for the OnFill function:

  • Previous holdings are retrieved and amended with new order information.
    • The stats for the exchange asset currency pair will be updated to reflect the order and pricing
  • The order will be added to the compliance manager for analysis in future events or the statistics package

The following steps are taken for the Update function:

  • The Update function is called when orders are not placed, this allows for the portfolio manager to still keep track of pricing and holding statistics, while not needing to process any orders

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