PINE LIBRARY

strategy

Mis à jour
Library "strategy"
Library containing few key calculations for strategy involving leveraged limit and stop orders

getQty(entry, stop, riskPercentage)
  calculate qty and leverage based on entry and stop price for given risk percentage.
  Parameters:
    entry: Entry Price
    stop: Stop Price
    riskPercentage: risk percentage per trade
  Returns: [quantity, leverage] - Quantity based on the risk and calculated leverage on position including existing positions

bracketOrder(entry, stop, target, maxLeverage, isLimitOrder, riskPercentage)
  Calculates position size based on risk and creates bracket orders for given entry/stop/target
  Parameters:
    entry: Entry Price
    stop: Stop Price
    target: Target Price
    maxLeverage: Maximum leverage allowed
    isLimitOrder: if true, places limit order for entry, else places stop order.
    riskPercentage: risk percentage per trade
  Returns: orderPlaced - true if orders successfully placed, false otherwise.

order(entry, stop, maxLeverage, isLimitOrder, riskPercentage)
  Calculates position size based on risk and creates order for given entry/stop
  Parameters:
    entry: Entry Price
    stop: Stop Price
    maxLeverage: Maximum leverage allowed
    isLimitOrder: if true, places limit order for entry, else places stop order.
    riskPercentage: risk percentage per trade
  Returns: orderPlaced - true if orders successfully placed, false otherwise.
Notes de version
v2

Added:
bracketOrderWithoutLeverage(id, entry, stop, target, isLimitOrder)
  Creates bracket orders for given entry/stop/target without leverage and qty calculation. (Uses the values from strategy definition)
  Parameters:
    id
    entry: Entry Price
    stop: Stop Price
    target: Target Price
    isLimitOrder: if true, places limit order for entry, else places stop order.
  Returns: orderPlaced - true if orders successfully placed, false otherwise.
Notes de version
v3
Notes de version
v4

Updated:
getQty(entry, stop, riskAmount, riskType)
  calculate qty and leverage based on entry and stop price for given risk percentage.
  Parameters:
    entry: Entry Price
    stop: Stop Price
    riskAmount: risk percentage per trade or risk cash per trade
    riskType: Can be either trategy.percent_of_equity or strategy.cash
  Returns: [quantity, leverage] - Quantity based on the risk and calculated leverage on position including existing positions

bracketOrder(id, entry, stop, target, maxLeverage, isLimitOrder, riskAmount, riskType)
  Calculates position size based on risk and creates bracket orders for given entry/stop/target
  Parameters:
    id
    entry: Entry Price
    stop: Stop Price
    target: Target Price
    maxLeverage: Maximum leverage allowed
    isLimitOrder: if true, places limit order for entry, else places stop order.
    riskAmount: risk percentage per trade or risk cash per trade
    riskType: Can be either trategy.percent_of_equity or strategy.cash
  Returns: orderPlaced - true if orders successfully placed, false otherwise.

order(id, entry, stop, maxLeverage, isLimitOrder, riskAmount, riskType)
  Calculates position size based on risk and creates order for given entry/stop
  Parameters:
    id
    entry: Entry Price
    stop: Stop Price
    maxLeverage: Maximum leverage allowed
    isLimitOrder: if true, places limit order for entry, else places stop order.
    riskAmount: risk percentage per trade or risk cash per trade
    riskType: Can be either trategy.percent_of_equity or strategy.cash
  Returns: orderPlaced - true if orders successfully placed, false otherwise.
Notes de version
v5

Corrected calculation logic for newPosition in getQty function. Thanks to serkany88 for highlighting
hewhomustnotbenamedstrategiestrendoscope

Bibliothèque Pine

Dans le plus pur esprit TradingView, l'auteur a publié ce code Pine en tant que 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 en privé ou dans d'autres publications à code source ouvert, mais la réutilisation de ce code dans une publication est régie par nos Règles.

Clause de non-responsabilité