PINE LIBRARY
Atualizado 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.
Notas de Lançamento
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.
- //
Biblioteca do Pine
Em verdadeiro espírito TradingView, o autor publicou este código Pine como uma biblioteca de código aberto para que outros programadores Pine da nossa comunidade possam reutilizá-lo. Parabéns ao autor! Você pode usar esta biblioteca de forma privada ou em outras publicações de código aberto, mas a reutilização deste código em publicações é regida pelas Regras da Casa.
Aviso legal
As informações e publicações não se destinam a ser, e não constituem, conselhos ou recomendações financeiras, de investimento, comerciais ou de outro tipo fornecidos ou endossados pela TradingView. Leia mais nos Termos de Uso.
Biblioteca do Pine
Em verdadeiro espírito TradingView, o autor publicou este código Pine como uma biblioteca de código aberto para que outros programadores Pine da nossa comunidade possam reutilizá-lo. Parabéns ao autor! Você pode usar esta biblioteca de forma privada ou em outras publicações de código aberto, mas a reutilização deste código em publicações é regida pelas Regras da Casa.
Aviso legal
As informações e publicações não se destinam a ser, e não constituem, conselhos ou recomendações financeiras, de investimento, comerciais ou de outro tipo fornecidos ou endossados pela TradingView. Leia mais nos Termos de Uso.