Trading with Leverage¶
Beta feature
This feature is still in it's testing phase. Should you notice something you think is wrong please let us know via Discord or via Github Issue.
Multiple bots on one account
You can't run 2 bots on the same account with leverage. For leveraged / margin trading, freqtrade assumes it's the only user of the account, and all liquidation levels are calculated based on this assumption.
Trading with leverage is very risky
Do not trade with a leverage > 1 using a strategy that hasn't shown positive results in a live run using the spot market. Check the stoploss of your strategy. With a leverage of 2, a stoploss of 0.5 (50%) would be too low, and these trades would be liquidated before reaching that stoploss. We do not assume any responsibility for eventual losses that occur from using this software or this mode.
Please only use advanced trading modes when you know how freqtrade (and your strategy) works. Also, never risk more than what you can afford to lose.
Please read the strategy migration guide to migrate your strategy from a freqtrade v2 strategy, to v3 strategy that can short and trade futures.
Shorting¶
Shorting is not possible when trading with trading_mode
set to spot
. To short trade, trading_mode
must be set to margin
(currently unavailable) or futures
, with margin_mode
set to cross
(currently unavailable) or isolated
For a strategy to short, the strategy class must set the class variable can_short = True
Please read strategy customization for instructions on how to set signals to enter and exit short trades.
Understand trading_mode
¶
The possible values are: spot
(default), margin
(Currently unavailable) or futures
.
Spot¶
Regular trading mode (low risk)
- Long trades only (No short trades).
- No leverage.
- No Liquidation.
- Profits gained/lost are equal to the change in value of the assets (minus trading fees).
Leverage trading modes¶
With leverage, a trader borrows capital from the exchange. The capital must be re-payed fully to the exchange (potentially with interest), and the trader keeps any profits, or pays any losses, from any trades made using the borrowed capital.
Because the capital must always be re-payed, exchanges will liquidate (forcefully sell the traders assets) a trade made using borrowed capital when the total value of assets in the leverage account drops to a certain point (a point where the total value of losses is less than the value of the collateral that the trader actually owns in the leverage account), in order to ensure that the trader has enough capital to pay the borrowed assets back to the exchange. The exchange will also charge a liquidation fee, adding to the traders losses.
For this reason, DO NOT TRADE WITH LEVERAGE IF YOU DON'T KNOW EXACTLY WHAT YOUR DOING. LEVERAGE TRADING IS HIGH RISK, AND CAN RESULT IN THE VALUE OF YOUR ASSETS DROPPING TO 0 VERY QUICKLY, WITH NO CHANCE OF INCREASING IN VALUE AGAIN.
Margin (currently unavailable)¶
Trading occurs on the spot market, but the exchange lends currency to you in an amount equal to the chosen leverage. You pay the amount lent to you back to the exchange with interest, and your profits/losses are multiplied by the leverage specified.
Futures¶
Perpetual swaps (also known as Perpetual Futures) are contracts traded at a price that is closely tied to the underlying asset they are based off of (ex.). You are not trading the actual asset but instead are trading a derivative contract. Perpetual swap contracts can last indefinitely, in contrast to futures or option contracts.
In addition to the gains/losses from the change in price of the futures contract, traders also exchange funding fees, which are gains/losses worth an amount that is derived from the difference in price between the futures contract and the underlying asset. The difference in price between a futures contract and the underlying asset varies between exchanges.
To trade in futures markets, you'll have to set trading_mode
to "futures".
You will also have to pick a "margin mode" (explanation below) - with freqtrade currently only supporting isolated margin.
"trading_mode": "futures",
"margin_mode": "isolated"
Margin mode¶
The possible values are: isolated
, or cross
(currently unavailable)
Isolated margin mode¶
Each market(trading pair), keeps collateral in a separate account
"margin_mode": "isolated"
Cross margin mode (currently unavailable)¶
One account is used to share collateral between markets (trading pairs). Margin is taken from total account balance to avoid liquidation when needed.
"margin_mode": "cross"
Understand liquidation_buffer
¶
Defaults to 0.05
A ratio specifying how large of a safety net to place between the liquidation price and the stoploss to prevent a position from reaching the liquidation price. This artificial liquidation price is calculated as:
freqtrade_liquidation_price = liquidation_price ± (abs(open_rate - liquidation_price) * liquidation_buffer)
±
=+
for long trades±
=-
for short trades
Possible values are any floats between 0.0 and 0.99
ex: If a trade is entered at a price of 10 coin/USDT, and the liquidation price of this trade is 8 coin/USDT, then with liquidation_buffer
set to 0.05
the minimum stoploss for this trade would be \(8 + ((10 - 8) * 0.05) = 8 + 0.1 = 8.1\)
A liquidation_buffer
of 0.0, or a low liquidation_buffer
is likely to result in liquidations, and liquidation fees
Currently Freqtrade is able to calculate liquidation prices, but does not calculate liquidation fees. Setting your liquidation_buffer
to 0.0, or using a low liquidation_buffer
could result in your positions being liquidated. Freqtrade does not track liquidation fees, so liquidations will result in inaccurate profit/loss results for your bot. If you use a low liquidation_buffer
, it is recommended to use stoploss_on_exchange
if your exchange supports this.
Unavailable funding rates¶
For futures data, exchanges commonly provide the futures candles, the marks, and the funding rates. However, it is common that whilst candles and marks might be available, the funding rates are not. This can affect backtesting timeranges, i.e. you may only be able to test recent timeranges and not earlier, experiencing the No data found. Terminating.
error. To get around this, add the futures_funding_rate
config option as listed in configuration.md, and it is recommended that you set this to 0
, unless you know a given specific funding rate for your pair, exchange and timerange. Setting this to anything other than 0
can have drastic effects on your profit calculations within strategy, e.g. within the custom_exit
, custom_stoploss
, etc functions.
This will mean your backtests are inaccurate.
This will not overwrite funding rates that are available from the exchange, but bear in mind that setting a false funding rate will mean backtesting results will be inaccurate for historical timeranges where funding rates are not available.
Developer¶
Margin mode¶
For shorts, the currency which pays the interest fee for the borrowed
currency is purchased at the same time of the closing trade (This means that the amount purchased in short closing trades is greater than the amount sold in short opening trades).
For longs, the currency which pays the interest fee for the borrowed
will already be owned by the user and does not need to be purchased. The interest is subtracted from the close_value
of the trade.
All Fees are included in current_profit
calculations during the trade.
Futures mode¶
Funding fees are either added or subtracted from the total amount of a trade