BybitMinOrderSize

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.
- 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.
- //
Biblioteca Pine
Fiel al espíritu de TradingView, el autor ha publicado este código de Pine como biblioteca de código abierto, para que otros programadores Pine de nuestra comunidad puedan reutilizarlo. ¡Enhorabuena al autor! Puede usar esta biblioteca de forma privada o en otras publicaciones de código abierto, pero la reutilización de este código en publicaciones está sujeta a nuestras Normas internas.
Exención de responsabilidad
Biblioteca Pine
Fiel al espíritu de TradingView, el autor ha publicado este código de Pine como biblioteca de código abierto, para que otros programadores Pine de nuestra comunidad puedan reutilizarlo. ¡Enhorabuena al autor! Puede usar esta biblioteca de forma privada o en otras publicaciones de código abierto, pero la reutilización de este código en publicaciones está sujeta a nuestras Normas internas.