#[repr(C)]pub struct CryptoFuture {Show 26 fields
pub id: InstrumentId,
pub raw_symbol: Symbol,
pub underlying: Currency,
pub quote_currency: Currency,
pub settlement_currency: Currency,
pub is_inverse: bool,
pub activation_ns: UnixNanos,
pub expiration_ns: UnixNanos,
pub price_precision: u8,
pub size_precision: u8,
pub price_increment: Price,
pub size_increment: Quantity,
pub multiplier: Quantity,
pub lot_size: Quantity,
pub margin_init: Decimal,
pub margin_maint: Decimal,
pub maker_fee: Decimal,
pub taker_fee: Decimal,
pub max_quantity: Option<Quantity>,
pub min_quantity: Option<Quantity>,
pub max_notional: Option<Money>,
pub min_notional: Option<Money>,
pub max_price: Option<Price>,
pub min_price: Option<Price>,
pub ts_event: UnixNanos,
pub ts_init: UnixNanos,
}
Expand description
Represents a deliverable futures contract instrument, with crypto assets as underlying and for settlement.
Fields§
§id: InstrumentId
The instrument ID for the instrument.
raw_symbol: Symbol
The raw/local/native symbol for the instrument, assigned by the venue.
underlying: Currency
The underlying asset.
quote_currency: Currency
The contract quote currency.
settlement_currency: Currency
The settlement currency.
is_inverse: bool
If the instrument costing is inverse (quantity expressed in quote currency units).
activation_ns: UnixNanos
UNIX timestamp (nanoseconds) for contract activation.
expiration_ns: UnixNanos
UNIX timestamp (nanoseconds) for contract expiration.
price_precision: u8
The price decimal precision.
size_precision: u8
The trading size decimal precision.
price_increment: Price
The minimum price increment (tick size).
size_increment: Quantity
The minimum size increment.
multiplier: Quantity
The contract multiplier.
lot_size: Quantity
The rounded lot unit size (standard/board).
margin_init: Decimal
The initial (order) margin requirement in percentage of order value.
margin_maint: Decimal
The maintenance (position) margin in percentage of position value.
maker_fee: Decimal
The fee rate for liquidity makers as a percentage of order value.
taker_fee: Decimal
The fee rate for liquidity takers as a percentage of order value.
max_quantity: Option<Quantity>
The maximum allowable order quantity.
min_quantity: Option<Quantity>
The minimum allowable order quantity.
max_notional: Option<Money>
The maximum allowable order notional value.
min_notional: Option<Money>
The minimum allowable order notional value.
max_price: Option<Price>
The maximum allowable quoted price.
min_price: Option<Price>
The minimum allowable quoted price.
ts_event: UnixNanos
UNIX timestamp (nanoseconds) when the data event occurred.
ts_init: UnixNanos
UNIX timestamp (nanoseconds) when the data object was initialized.
Implementations§
Source§impl CryptoFuture
impl CryptoFuture
Sourcepub fn new_checked(
id: InstrumentId,
raw_symbol: Symbol,
underlying: Currency,
quote_currency: Currency,
settlement_currency: Currency,
is_inverse: bool,
activation_ns: UnixNanos,
expiration_ns: UnixNanos,
price_precision: u8,
size_precision: u8,
price_increment: Price,
size_increment: Quantity,
multiplier: Option<Quantity>,
lot_size: Option<Quantity>,
max_quantity: Option<Quantity>,
min_quantity: Option<Quantity>,
max_notional: Option<Money>,
min_notional: Option<Money>,
max_price: Option<Price>,
min_price: Option<Price>,
margin_init: Option<Decimal>,
margin_maint: Option<Decimal>,
maker_fee: Option<Decimal>,
taker_fee: Option<Decimal>,
ts_event: UnixNanos,
ts_init: UnixNanos,
) -> Result<Self>
pub fn new_checked( id: InstrumentId, raw_symbol: Symbol, underlying: Currency, quote_currency: Currency, settlement_currency: Currency, is_inverse: bool, activation_ns: UnixNanos, expiration_ns: UnixNanos, price_precision: u8, size_precision: u8, price_increment: Price, size_increment: Quantity, multiplier: Option<Quantity>, lot_size: Option<Quantity>, max_quantity: Option<Quantity>, min_quantity: Option<Quantity>, max_notional: Option<Money>, min_notional: Option<Money>, max_price: Option<Price>, min_price: Option<Price>, margin_init: Option<Decimal>, margin_maint: Option<Decimal>, maker_fee: Option<Decimal>, taker_fee: Option<Decimal>, ts_event: UnixNanos, ts_init: UnixNanos, ) -> Result<Self>
Creates a new CryptoFuture
instance with correctness checking.
§Notes
PyO3 requires a Result
type for proper error handling and stacktrace printing in Python.
Sourcepub fn new(
id: InstrumentId,
raw_symbol: Symbol,
underlying: Currency,
quote_currency: Currency,
settlement_currency: Currency,
is_inverse: bool,
activation_ns: UnixNanos,
expiration_ns: UnixNanos,
price_precision: u8,
size_precision: u8,
price_increment: Price,
size_increment: Quantity,
multiplier: Option<Quantity>,
lot_size: Option<Quantity>,
max_quantity: Option<Quantity>,
min_quantity: Option<Quantity>,
max_notional: Option<Money>,
min_notional: Option<Money>,
max_price: Option<Price>,
min_price: Option<Price>,
margin_init: Option<Decimal>,
margin_maint: Option<Decimal>,
maker_fee: Option<Decimal>,
taker_fee: Option<Decimal>,
ts_event: UnixNanos,
ts_init: UnixNanos,
) -> Self
pub fn new( id: InstrumentId, raw_symbol: Symbol, underlying: Currency, quote_currency: Currency, settlement_currency: Currency, is_inverse: bool, activation_ns: UnixNanos, expiration_ns: UnixNanos, price_precision: u8, size_precision: u8, price_increment: Price, size_increment: Quantity, multiplier: Option<Quantity>, lot_size: Option<Quantity>, max_quantity: Option<Quantity>, min_quantity: Option<Quantity>, max_notional: Option<Money>, min_notional: Option<Money>, max_price: Option<Price>, min_price: Option<Price>, margin_init: Option<Decimal>, margin_maint: Option<Decimal>, maker_fee: Option<Decimal>, taker_fee: Option<Decimal>, ts_event: UnixNanos, ts_init: UnixNanos, ) -> Self
Creates a new CryptoFuture
instance.
Trait Implementations§
Source§impl Clone for CryptoFuture
impl Clone for CryptoFuture
Source§fn clone(&self) -> CryptoFuture
fn clone(&self) -> CryptoFuture
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for CryptoFuture
impl Debug for CryptoFuture
Source§impl<'de> Deserialize<'de> for CryptoFuture
impl<'de> Deserialize<'de> for CryptoFuture
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl Hash for CryptoFuture
impl Hash for CryptoFuture
Source§impl Instrument for CryptoFuture
impl Instrument for CryptoFuture
fn into_any(self) -> InstrumentAny
fn id(&self) -> InstrumentId
fn raw_symbol(&self) -> Symbol
fn asset_class(&self) -> AssetClass
fn instrument_class(&self) -> InstrumentClass
fn underlying(&self) -> Option<Ustr>
fn quote_currency(&self) -> Currency
fn base_currency(&self) -> Option<Currency>
fn settlement_currency(&self) -> Currency
fn isin(&self) -> Option<Ustr>
fn exchange(&self) -> Option<Ustr>
fn option_kind(&self) -> Option<OptionKind>
fn is_inverse(&self) -> bool
fn price_precision(&self) -> u8
fn size_precision(&self) -> u8
fn price_increment(&self) -> Price
fn size_increment(&self) -> Quantity
fn multiplier(&self) -> Quantity
fn lot_size(&self) -> Option<Quantity>
fn max_quantity(&self) -> Option<Quantity>
fn min_quantity(&self) -> Option<Quantity>
fn max_price(&self) -> Option<Price>
fn min_price(&self) -> Option<Price>
fn ts_event(&self) -> UnixNanos
fn ts_init(&self) -> UnixNanos
fn strike_price(&self) -> Option<Price>
fn activation_ns(&self) -> Option<UnixNanos>
fn expiration_ns(&self) -> Option<UnixNanos>
fn max_notional(&self) -> Option<Money>
fn min_notional(&self) -> Option<Money>
fn symbol(&self) -> Symbol
fn venue(&self) -> Venue
fn margin_init(&self) -> Decimal
fn margin_maint(&self) -> Decimal
fn maker_fee(&self) -> Decimal
fn taker_fee(&self) -> Decimal
Source§fn make_price(&self, value: f64) -> Price
fn make_price(&self, value: f64) -> Price
Price
from the given value
with the correct price precision for the instrument.Source§fn make_qty(&self, value: f64) -> Quantity
fn make_qty(&self, value: f64) -> Quantity
Quantity
from the given value
with the correct size precision for the instrument.Source§impl IntoPy<Py<PyAny>> for CryptoFuture
impl IntoPy<Py<PyAny>> for CryptoFuture
Source§impl PartialEq for CryptoFuture
impl PartialEq for CryptoFuture
Source§impl PyClass for CryptoFuture
impl PyClass for CryptoFuture
Source§impl PyClassImpl for CryptoFuture
impl PyClassImpl for CryptoFuture
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§type ThreadChecker = SendablePyClass<CryptoFuture>
type ThreadChecker = SendablePyClass<CryptoFuture>
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny
by default, and when you declare
#[pyclass(extends=PyDict)]
, it’s PyDict
.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
fn dict_offset() -> Option<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyClassNewTextSignature<CryptoFuture> for PyClassImplCollector<CryptoFuture>
impl PyClassNewTextSignature<CryptoFuture> for PyClassImplCollector<CryptoFuture>
fn new_text_signature(self) -> Option<&'static str>
Source§impl<'a, 'py> PyFunctionArgument<'a, 'py> for &'a CryptoFuture
impl<'a, 'py> PyFunctionArgument<'a, 'py> for &'a CryptoFuture
Source§impl<'a, 'py> PyFunctionArgument<'a, 'py> for &'a mut CryptoFuture
impl<'a, 'py> PyFunctionArgument<'a, 'py> for &'a mut CryptoFuture
Source§impl PyMethods<CryptoFuture> for PyClassImplCollector<CryptoFuture>
impl PyMethods<CryptoFuture> for PyClassImplCollector<CryptoFuture>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for CryptoFuture
impl PyTypeInfo for CryptoFuture
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object_bound(py: Python<'_>) -> Bound<'_, PyType>
fn type_object_bound(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of_bound(object: &Bound<'_, PyAny>) -> bool
fn is_type_of_bound(object: &Bound<'_, PyAny>) -> bool
object
is an instance of this type or a subclass of this type.§fn is_exact_type_of_bound(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of_bound(object: &Bound<'_, PyAny>) -> bool
object
is an instance of this type.Source§impl Serialize for CryptoFuture
impl Serialize for CryptoFuture
impl Copy for CryptoFuture
impl DerefToPyAny for CryptoFuture
impl Eq for CryptoFuture
Auto Trait Implementations§
impl Freeze for CryptoFuture
impl RefUnwindSafe for CryptoFuture
impl Send for CryptoFuture
impl Sync for CryptoFuture
impl Unpin for CryptoFuture
impl UnwindSafe for CryptoFuture
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.