PINE LIBRARY
Mis à jour BybitMinOrderSize

Bybit Order Quantity Compliance Library
Problem:
Bybit enforces two strict rules on every order submitted:
Solution (This Library):
This library embeds full Bybit contract metadata, including:
It also exposes utility functions to automatically make your quantities valid:
Use Cases:
This library is recommended for:
Source: bybit.com/en/announcement-info/transact-parameters/
Updated: 2025-11-25 — Bybit contract metadata
normalizeTicker(symbol)
Normalizes Bybit perpetual tickers by removing the ".P" suffix.
precisionFromMinOrder(minOrder)
Derives precision (decimal places) from minimum order size.
getMinOrderSize(symbol)
Retrieves the minimum order size for the current or given symbol.
getPrecisionForTicker(symbol)
Retrieves the required quantity precision (decimal places) for a given Bybit symbol.
floorQty(qty, symbol)
Rounds a quantity down to the nearest valid minimum order size for a given symbol.
roundQty(qty, symbol)
Rounds a quantity to the valid precision for the specified symbol.
This library provides all utility functions required for TradingView strategies
that execute orders on Bybit via webhooks.
Problem:
Bybit enforces two strict rules on every order submitted:
- Minimum Order Size – each symbol has its own minimum quantity.
- Quantity Precision– each symbol requires rounding to the correct number of decimals.
TradingView does not expose this metadata, so strategies can easily submit
quantities that Bybit rejects as invalid.
Solution (This Library):
This library embeds full Bybit contract metadata, including:
- A complete mapping of Bybit symbols → minimum order size
- A complete mapping of Bybit symbols → allowed precision (decimal places)
- A helper to normalize tickers (removing `.P` suffix for Bybit perpetuals)
It also exposes utility functions to automatically make your quantities valid:
- `normalizeTicker()` — removes `.P` for consistent lookup
- `getMinOrderSize()` — returns the correct minimum order size
- `getPrecisionForTicker()` — returns required quantity precision
- `floorQty()` — floors quantities to valid minimum increments
- `roundQty()` — rounds quantities to valid decimal precision
Use Cases:
- Ensuring webhook strategies never send too-small orders
- Rounding limit/market orders correctly before execution
- Making Pine strategies execution-accurate for Bybit
- Avoiding "order rejected: qty too small / invalid precision" errors
This library is recommended for:
- Live trading via TradingView → Bybit webhooks
- Backtesting strategies that simulate real Bybit constraints
Source: bybit.com/en/announcement-info/transact-parameters/
Updated: 2025-11-25 — Bybit contract metadata
normalizeTicker(symbol)
Normalizes Bybit perpetual tickers by removing the ".P" suffix.
precisionFromMinOrder(minOrder)
Derives precision (decimal places) from minimum order size.
getMinOrderSize(symbol)
Retrieves the minimum order size for the current or given symbol.
getPrecisionForTicker(symbol)
Retrieves the required quantity precision (decimal places) for a given Bybit symbol.
floorQty(qty, symbol)
Rounds a quantity down to the nearest valid minimum order size for a given symbol.
roundQty(qty, symbol)
Rounds a quantity to the valid precision for the specified symbol.
Notes de version
Changelog v2.0:- Performance: `floorQty` and `roundQty` now accept optional `minOrderSize` and `precision` parameters respectively.
- Optimization: Strategies can now pass cached or user-defined values to skip redundant internal lookups on every call.
- Compatibility: Fully backward compatible; defaults to automatic lookup if optional parameters are omitted.
- //
Bibliothèque Pine
Dans l'esprit TradingView, l'auteur a publié ce code Pine sous forme de bibliothèque open source afin que d'autres programmeurs Pine de notre communauté puissent le réutiliser. Bravo à l'auteur! Vous pouvez utiliser cette bibliothèque à titre privé ou dans d'autres publications open source, mais la réutilisation de ce code dans des publications est régie par nos Règles.
Clause de non-responsabilité
Les informations et publications ne sont pas destinées à être, et ne constituent pas, des conseils ou recommandations financiers, d'investissement, de trading ou autres fournis ou approuvés par TradingView. Pour en savoir plus, consultez les Conditions d'utilisation.
Bibliothèque Pine
Dans l'esprit TradingView, l'auteur a publié ce code Pine sous forme de bibliothèque open source afin que d'autres programmeurs Pine de notre communauté puissent le réutiliser. Bravo à l'auteur! Vous pouvez utiliser cette bibliothèque à titre privé ou dans d'autres publications open source, mais la réutilisation de ce code dans des publications est régie par nos Règles.
Clause de non-responsabilité
Les informations et publications ne sont pas destinées à être, et ne constituent pas, des conseils ou recommandations financiers, d'investissement, de trading ou autres fournis ou approuvés par TradingView. Pour en savoir plus, consultez les Conditions d'utilisation.