AssetIdentifier#
API documentation for tradeexecutor.state.identifier.AssetIdentifier Python class in Trading Strategy framework.
- class AssetIdentifier[source]#
Bases:
object
Identify a blockchain asset for trade execution.
This is pass-by-copy (as opposite to pass-by-reference) asset identifier we use across the persistent state. Because we copy a lot of information about asset, not just its id, this makes data reads and diagnosing problems simpler.
As internal token_ids and pair_ids may be unstable, trading pairs and tokens are explicitly referred by their smart contract addresses when a strategy decision moves to the execution. We duplicate data here to make sure we have a persistent record that helps to diagnose the issues.
Setting custom data:
Both
AssetIdentifier
andTradingPairIdentifier
offerAssetIdentifier.other_data
allowing you to set custom attributes.Most useful of them is to categorise tokens with different tags, see
get_tags()
andset_tags()
.You must set these attributes in create_trading_universe function.
For more usage examples see test_custom_labels.
A custom asset tagging example:
def create_trading_universe( ts: datetime.datetime, client: Client, execution_context: ExecutionContext, universe_options: UniverseOptions, ) -> TradingStrategyUniverse: assert universe_options.start_at pairs = [ (ChainId.polygon, "uniswap-v3", "WETH", "USDC", 0.0005) ] dataset = load_partial_data( client, execution_context=unit_test_execution_context, time_bucket=TimeBucket.d1, pairs=pairs, universe_options=default_universe_options, start_at=universe_options.start_at, end_at=universe_options.end_at, ) strategy_universe = TradingStrategyUniverse.create_single_pair_universe(dataset) # IMPORTANT # Warm up must be called before any tags are set strategy_universe.warm_up_data() # Set custom labels on the token WETH on the trading pair weth_usdc = strategy_universe.get_pair_by_human_description(pairs[0]) weth_usdc.base.set_tags({"L1", "EVM", "bluechip"}) assert strategy_universe.data_universe.pairs.pair_map is not None, "Cache data structure missing?" weth_usdc = strategy_universe.get_pair_by_human_description(pairs[0]) assert len(weth_usdc.base.get_tags()) > 0 return strategy_universe
Then how to read tag data and use it in trade decision making:
def decide_trades(input: StrategyInput) -> list[TradeExecution]: # Show how to read pair and asset labels in decide_trade() for pair in input.strategy_universe.iterate_pairs(): if "L1" in pair.get_tags(): # Do some trading logic for L1 tokens only pass return []
- __init__(chain_id, address, token_symbol, decimals, internal_id=None, info_url=None, underlying=None, type=None, liquidation_threshold=None, other_data=<factory>)#
Methods
__init__
(chain_id, address, token_symbol, ...)convert_to_decimal
(raw_amount)convert_to_raw_amount
(amount)Return any amount in token native units.
from_dict
(kvs, *[, infer_missing])from_json
(s, *[, parse_float, parse_int, ...])Get buy tax associated with this token if any.
Assets are identified by their smart contract address.
Get the asset that delivers price for this asset.
Get sell tax associated with this token if any.
get_tags
()Return list of tags associated with this asset.
Is this a credit asset that accrue interest for us
is_debt
()Is this a credit asset that accrue interest for us
Will this token gain on-chain interest thru rebase
Do we think this asset reprents a stablecoin
schema
(*[, infer_missing, only, exclude, ...])set_tags
(tags)Set tags for this asset.
to_dict
([encode_json])to_json
(*[, skipkeys, ensure_ascii, ...])Attributes
Ethereum madness.
Info page URL for this asset
How this asset is referred in the internal database
Aave liquidation threhold for this asset
What kind of asset is this
The underlying asset for aTokens, vTokens and such
Smart contract address of the asset.
The ticker symbol of this token.
How many tokens this decimals.
User storeable properties.
- underlying: Optional[AssetIdentifier] = None#
The underlying asset for aTokens, vTokens and such
- liquidation_threshold: float | None = None#
Aave liquidation threhold for this asset
Set on aTokens that are used as collateral.
- other_data: Optional[dict]#
User storeable properties.
You can add any of your own metadata on the assets here.
Be wary of the life cycle of the instances. The life time of the class instances tied to the trading universe that is recreated for every strategy cycle.
See also
get_tags()
.
- get_identifier()[source]#
Assets are identified by their smart contract address.
JSON/Human friendly format to give hash keys to assets, in the format chain id-address.
- Returns:
JSON friendly hask key
- Return type:
- property checksum_address: HexAddress#
Ethereum madness.
- convert_to_raw_amount(amount)[source]#
Return any amount in token native units.
Convert decimal to fixed point integer.
- get_pricing_asset()[source]#
Get the asset that delivers price for this asset.
- Returns:
If this asset is a derivative of another, then get the underlying, otherwise return self.
- Return type:
- get_tags()[source]#
Return list of tags associated with this asset.
Used in basket construction strategies
Cen be source from CoinGecko, CoinMarketCap or hand labelled
Is Python
set
See also
TradingPairIdentifier.get_tags()
See also
set_tags()
To set tags:
asset.other_data[“tags”] = {“L1”, “memecoin”}
- set_tags(tags)[source]#
Set tags for this asset.
See also
get_tags()
See also
other_data()
Must be called in create_trading_universe
Be wary of AssetIdentifier life time as it is passed by value, not be reference, so you cannot update instance data after it has been copied to open positions, etc.
translate_trading_pair() is the critical method for understanding and managing identifier life times
- get_buy_tax()[source]#
Get buy tax associated with this token if any.
Note
This property should be per trading pair, but all other DEX systems use per token tax values.
- Return type:
float | None
- get_sell_tax()[source]#
Get sell tax associated with this token if any.
Note
This property should be per trading pair, but all other DEX systems use per token tax values.
- Return type:
float | None
- __init__(chain_id, address, token_symbol, decimals, internal_id=None, info_url=None, underlying=None, type=None, liquidation_threshold=None, other_data=<factory>)#