#[repr(C)]pub struct PerpetualContract {Show 27 fields
pub id: InstrumentId,
pub raw_symbol: Symbol,
pub underlying: Ustr,
pub asset_class: AssetClass,
pub base_currency: Option<Currency>,
pub quote_currency: Currency,
pub settlement_currency: Currency,
pub is_inverse: bool,
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 info: Option<Params>,
pub ts_event: UnixNanos,
pub ts_init: UnixNanos,
}Expand description
Represents a perpetual contract instrument (perpetual swap).
Supports perpetuals on any asset class including FX, equities, commodities, indexes, and cryptocurrencies.
Fields§
§id: InstrumentIdThe instrument ID for the instrument.
raw_symbol: SymbolThe raw/local/native symbol for the instrument, assigned by the venue.
underlying: UstrThe underlying asset identifier (e.g., “EURUSD”, “NVDA”, “GC”).
asset_class: AssetClassThe asset class of the perpetual contract.
base_currency: Option<Currency>The base currency (optional, set for FX/crypto underlyings).
quote_currency: CurrencyThe quote currency.
settlement_currency: CurrencyThe settlement currency.
is_inverse: boolIf the instrument costing is inverse (quantity expressed in quote currency units).
price_precision: u8The price decimal precision.
size_precision: u8The trading size decimal precision.
price_increment: PriceThe minimum price increment (tick size).
size_increment: QuantityThe minimum size increment.
multiplier: QuantityThe contract multiplier.
lot_size: QuantityThe rounded lot unit size (standard/board).
margin_init: DecimalThe initial (order) margin requirement in percentage of order value.
margin_maint: DecimalThe maintenance (position) margin in percentage of position value.
maker_fee: DecimalThe fee rate for liquidity makers as a percentage of order value.
taker_fee: DecimalThe 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.
info: Option<Params>Additional instrument metadata as a JSON-serializable dictionary.
ts_event: UnixNanosUNIX timestamp (nanoseconds) when the data event occurred.
ts_init: UnixNanosUNIX timestamp (nanoseconds) when the data object was initialized.
Implementations§
Source§impl PerpetualContract
impl PerpetualContract
Sourcepub fn new_checked(
instrument_id: InstrumentId,
raw_symbol: Symbol,
underlying: Ustr,
asset_class: AssetClass,
base_currency: Option<Currency>,
quote_currency: Currency,
settlement_currency: Currency,
is_inverse: bool,
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>,
info: Option<Params>,
ts_event: UnixNanos,
ts_init: UnixNanos,
) -> CorrectnessResult<Self>
pub fn new_checked( instrument_id: InstrumentId, raw_symbol: Symbol, underlying: Ustr, asset_class: AssetClass, base_currency: Option<Currency>, quote_currency: Currency, settlement_currency: Currency, is_inverse: bool, 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>, info: Option<Params>, ts_event: UnixNanos, ts_init: UnixNanos, ) -> CorrectnessResult<Self>
Creates a new PerpetualContract instance with correctness checking.
§Notes
PyO3 requires a Result type for proper error handling and stacktrace printing in Python.
§Errors
Returns an error if any input validation fails.
Sourcepub fn new(
instrument_id: InstrumentId,
raw_symbol: Symbol,
underlying: Ustr,
asset_class: AssetClass,
base_currency: Option<Currency>,
quote_currency: Currency,
settlement_currency: Currency,
is_inverse: bool,
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>,
info: Option<Params>,
ts_event: UnixNanos,
ts_init: UnixNanos,
) -> Self
pub fn new( instrument_id: InstrumentId, raw_symbol: Symbol, underlying: Ustr, asset_class: AssetClass, base_currency: Option<Currency>, quote_currency: Currency, settlement_currency: Currency, is_inverse: bool, 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>, info: Option<Params>, ts_event: UnixNanos, ts_init: UnixNanos, ) -> Self
Creates a new PerpetualContract instance.
§Panics
Panics if any input parameter is invalid (see new_checked).
Trait Implementations§
Source§impl Clone for PerpetualContract
impl Clone for PerpetualContract
Source§fn clone(&self) -> PerpetualContract
fn clone(&self) -> PerpetualContract
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for PerpetualContract
impl Debug for PerpetualContract
Source§impl<'de> Deserialize<'de> for PerpetualContract
impl<'de> Deserialize<'de> for PerpetualContract
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 From<PerpetualContract> for InstrumentAny
impl From<PerpetualContract> for InstrumentAny
Source§fn from(v: PerpetualContract) -> InstrumentAny
fn from(v: PerpetualContract) -> InstrumentAny
Source§impl<'a, 'py> FromPyObject<'a, 'py> for PerpetualContractwhere
Self: Clone,
impl<'a, 'py> FromPyObject<'a, 'py> for PerpetualContractwhere
Self: Clone,
Source§impl Hash for PerpetualContract
impl Hash for PerpetualContract
Source§impl Instrument for PerpetualContract
impl Instrument for PerpetualContract
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 base_currency(&self) -> Option<Currency>
fn quote_currency(&self) -> Currency
fn settlement_currency(&self) -> Currency
fn isin(&self) -> Option<Ustr>
fn option_kind(&self) -> Option<OptionKind>
fn exchange(&self) -> Option<Ustr>
fn strike_price(&self) -> Option<Price>
fn activation_ns(&self) -> Option<UnixNanos>
fn expiration_ns(&self) -> Option<UnixNanos>
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_notional(&self) -> Option<Money>
fn min_notional(&self) -> Option<Money>
fn max_price(&self) -> Option<Price>
fn min_price(&self) -> Option<Price>
fn margin_init(&self) -> Decimal
fn margin_maint(&self) -> Decimal
fn maker_fee(&self) -> Decimal
fn taker_fee(&self) -> Decimal
fn ts_event(&self) -> UnixNanos
fn ts_init(&self) -> UnixNanos
fn tick_scheme(&self) -> Option<&dyn TickSchemeRule>
fn symbol(&self) -> Symbol
fn venue(&self) -> Venue
Source§fn cost_currency(&self) -> Currency
fn cost_currency(&self) -> Currency
fn has_expiration(&self) -> bool
fn is_quanto(&self) -> bool
fn min_price_increment_precision(&self) -> u8
fn min_size_increment_precision(&self) -> u8
fn make_price(&self, value: f64) -> Price
Source§fn try_make_qty(&self, value: f64, round_down: Option<bool>) -> Result<Quantity>
fn try_make_qty(&self, value: f64, round_down: Option<bool>) -> Result<Quantity>
fn make_qty(&self, value: f64, round_down: Option<bool>) -> Quantity
Source§fn try_calculate_base_quantity(
&self,
quantity: Quantity,
last_price: Price,
) -> Result<Quantity>
fn try_calculate_base_quantity( &self, quantity: Quantity, last_price: Price, ) -> Result<Quantity>
fn calculate_base_quantity( &self, quantity: Quantity, last_price: Price, ) -> Quantity
Source§fn calculate_notional_value(
&self,
quantity: Quantity,
price: Price,
use_quote_for_inverse: Option<bool>,
) -> Money
fn calculate_notional_value( &self, quantity: Quantity, price: Price, use_quote_for_inverse: Option<bool>, ) -> Money
fn next_bid_price(&self, value: f64, n: i32) -> Option<Price>
fn next_ask_price(&self, value: f64, n: i32) -> Option<Price>
fn next_bid_prices(&self, value: f64, n: usize) -> Vec<Price>
fn next_ask_prices(&self, value: f64, n: usize) -> Vec<Price>
Source§impl<'py> IntoPyObject<'py> for PerpetualContract
impl<'py> IntoPyObject<'py> for PerpetualContract
Source§type Target = PerpetualContract
type Target = PerpetualContract
Source§type Output = Bound<'py, <PerpetualContract as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <PerpetualContract as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PartialEq for PerpetualContract
impl PartialEq for PerpetualContract
Source§impl PyClass for PerpetualContract
impl PyClass for PerpetualContract
Source§impl PyClassImpl for PerpetualContract
impl PyClassImpl for PerpetualContract
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§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = /// Represents a perpetual contract instrument (perpetual swap).
///
/// Supports perpetuals on any asset class including FX, equities,
/// commodities, indexes, and cryptocurrencies.
const RAW_DOC: &'static CStr = /// Represents a perpetual contract instrument (perpetual swap). /// /// Supports perpetuals on any asset class including FX, equities, /// commodities, indexes, and cryptocurrencies.
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type Layout = <<PerpetualContract as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<PerpetualContract>
type Layout = <<PerpetualContract as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<PerpetualContract>
Source§type ThreadChecker = NoopThreadChecker
type ThreadChecker = NoopThreadChecker
type Inventory = Pyo3MethodsInventoryForPerpetualContract
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<PyObjectOffset>
fn dict_offset() -> Option<PyObjectOffset>
§fn weaklist_offset() -> Option<PyObjectOffset>
fn weaklist_offset() -> Option<PyObjectOffset>
Source§impl PyClassNewTextSignature for PerpetualContract
impl PyClassNewTextSignature for PerpetualContract
const TEXT_SIGNATURE: &'static str = "(instrument_id, raw_symbol, underlying, asset_class, quote_currency, settlement_currency, is_inverse, price_precision, size_precision, price_increment, size_increment, ts_event, ts_init, base_currency=None, multiplier=None, lot_size=None, max_quantity=None, min_quantity=None, max_notional=None, min_notional=None, max_price=None, min_price=None, margin_init=None, margin_maint=None, maker_fee=None, taker_fee=None, info=None)"
Source§impl PyStubType for PerpetualContract
impl PyStubType for PerpetualContract
Source§fn type_output() -> TypeInfo
fn type_output() -> TypeInfo
§fn type_input() -> TypeInfo
fn type_input() -> TypeInfo
Source§impl PyTypeInfo for PerpetualContract
impl PyTypeInfo for PerpetualContract
Source§const NAME: &str = <Self as ::pyo3::PyClass>::NAME
const NAME: &str = <Self as ::pyo3::PyClass>::NAME
prefer using ::type_object(py).name() to get the correct runtime value
Source§const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
prefer using ::type_object(py).module() to get the correct runtime value
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type.Source§impl Serialize for PerpetualContract
impl Serialize for PerpetualContract
Source§impl TryInto<PerpetualContract> for InstrumentAny
impl TryInto<PerpetualContract> for InstrumentAny
impl DerefToPyAny for PerpetualContract
impl Eq for PerpetualContract
Auto Trait Implementations§
impl Freeze for PerpetualContract
impl RefUnwindSafe for PerpetualContract
impl Send for PerpetualContract
impl Sync for PerpetualContract
impl Unpin for PerpetualContract
impl UnsafeUnpin for PerpetualContract
impl UnwindSafe for PerpetualContract
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
§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.§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
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
self into an owned Python object, dropping type information and unbinding it
from the 'py lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
self into a Python object. Read more§impl<'py, T> IntoPyObjectNautilusExt<'py> for Twhere
T: IntoPyObjectExt<'py>,
impl<'py, T> IntoPyObjectNautilusExt<'py> for Twhere
T: IntoPyObjectExt<'py>,
§fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>
fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
isinstance and issubclass function. Read more