Source code for tradeexecutor.state.valuation

"""Position valuations."""
import datetime
from dataclasses import dataclass
from decimal import Decimal

from dataclasses_json import dataclass_json

from tradeexecutor.state.types import USDollarPrice, BlockNumber
from tradingstrategy.types import PrimaryKey, USDollarAmount

[docs]@dataclass_json @dataclass class ValuationUpdate: """Valuation update events. Generated by :py:class:`tradeexecutor.strategy.valuation.ValuationModel` """ position_id: PrimaryKey #: When this valuation was updated. #: #: Valuation can be based on old data, #: this is the strategy cycle timestamp or wall-clock timestmap #: when this event was generated. #: #: See also :py:attr:`valued_at` #: created_at: datetime.datetime #: The block timestamp this valuation is based on. #: #: If not available then wall clock time of the valuation. #: Note that block timestamp may lag :py:attr:`created_at` #: because we cannot use the last block due to #: chain tip instability. #: #: See also :py:attr:`event_generated_at` #: valued_at: datetime.datetime new_value: USDollarAmount #: The new price of the base asset of the position. #: #: Note that position value depends also on gained #: interest and the price of the quote asset. #: new_price: USDollarPrice #: What was the position value before this update. #: old_value: USDollarAmount | None = None #: What was the position base asset price before this update. #: old_price: USDollarPrice | None = None #: What is the block number is valuation is based on. #: #: Must match :py:attr:`valued_at`. #: block_number: BlockNumber | None = None #: In this update, we marked down this position to zero because of the valuation failure. #: #: Set to `True` indicate we lost the valuation source for this position. #: #: See `revalue_portfolio()`. #: mark_down_to_zero: bool | None = None #: What was the quantity of the position at the time of valuation quantity: Decimal | None = None