PINE LIBRARY
Cập nhật 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.
Phát hành các Ghi chú
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.
- //
Thư viện Pine
Theo đúng tinh thần TradingView, tác giả đã công bố mã Pine này như một thư viện mã nguồn mở để các lập trình viên Pine khác trong cộng đồng có thể tái sử dụng. Chúc mừng tác giả! Bạn có thể sử dụng thư viện này cho mục đích cá nhân hoặc trong các ấn phẩm mã nguồn mở khác, nhưng việc tái sử dụng mã này trong các ấn phẩm phải tuân theo Nội Quy.
Thông báo miễn trừ trách nhiệm
Thông tin và các ấn phẩm này không nhằm mục đích, và không cấu thành, lời khuyên hoặc khuyến nghị về tài chính, đầu tư, giao dịch hay các loại khác do TradingView cung cấp hoặc xác nhận. Đọc thêm tại Điều khoản Sử dụng.
Thư viện Pine
Theo đúng tinh thần TradingView, tác giả đã công bố mã Pine này như một thư viện mã nguồn mở để các lập trình viên Pine khác trong cộng đồng có thể tái sử dụng. Chúc mừng tác giả! Bạn có thể sử dụng thư viện này cho mục đích cá nhân hoặc trong các ấn phẩm mã nguồn mở khác, nhưng việc tái sử dụng mã này trong các ấn phẩm phải tuân theo Nội Quy.
Thông báo miễn trừ trách nhiệm
Thông tin và các ấn phẩm này không nhằm mục đích, và không cấu thành, lời khuyên hoặc khuyến nghị về tài chính, đầu tư, giao dịch hay các loại khác do TradingView cung cấp hoặc xác nhận. Đọc thêm tại Điều khoản Sử dụng.