61 lines
3.1 KiB
Go
61 lines
3.1 KiB
Go
package models
|
||
|
||
import "github.com/shopspring/decimal"
|
||
|
||
//Liquidation 强平计算公式字段
|
||
type Liquidation struct {
|
||
WalletBalance decimal.Decimal //账户余额,钱包余额= 1,535,443.01
|
||
TMM1 decimal.Decimal //(TMM1)其它合约下的全部保证金(除合约1外)= 71200.81144,维持保证金=名义价值*维持保证金率-维持保证金速算額,名义价值=价格*数量,拿标记价格计算
|
||
UPNL1 decimal.Decimal //全部其它合约的未实现盈亏(除合约1外)= -56,249.35
|
||
CumB decimal.Decimal //单向模式下合约1的维持保证金速算額= 135,365.00
|
||
CumL decimal.Decimal //开多合约1下的维持保证金速算額(双向持仓模式)= 0
|
||
CumS decimal.Decimal //开空合约1下的维持保证金速算額(双向持仓模式)= 0
|
||
Side1BOTH int //合约1的方向(单向持仓模式);“1”代表开多持仓;“-1”代表开空持仓= 1
|
||
Position1BOTH decimal.Decimal //合约1的持仓大小(单向持仓模式);无论开多或开空,取绝对值= 3,683.979
|
||
EP1BOTH decimal.Decimal //合约1的头寸价格(单向持仓模式)=1,456.84
|
||
Position1LONG decimal.Decimal //开多仓位大小(双向持仓模式);无论开多或开空,取绝对值= 0
|
||
EP1LONG decimal.Decimal //开多持仓的头寸(双向持仓模式);无论开多或开空,取绝对值= 0
|
||
Position1SHORT decimal.Decimal //开空仓位大小(双向持仓模式);无论开多或开空,取绝对值= 0
|
||
EP1SHORT decimal.Decimal //开空持仓的头寸(双向持仓模式);无论开多或开空,取绝对值= 0
|
||
MMRB decimal.Decimal //单向持仓模式合约的维持保证金费率= 10%
|
||
MMRL decimal.Decimal //开多合约的维持保证金费率(双向持仓模式)= 0
|
||
MMRS decimal.Decimal //开空合约的维持保证金费率(双向持仓模式)= 0
|
||
}
|
||
|
||
//CalculateLiquidationPrice 计算强平公式
|
||
func (lq Liquidation) CalculateLiquidationPrice() decimal.Decimal {
|
||
//d1=WB-TMM1+UPNL1+CumB+CumL+CumS-Side1BOTH*Position1BOTH*EP1BOTH-Position1LONG*EP1LONG+Position1SHORT*EP1SHORT
|
||
t1 := lq.WalletBalance
|
||
if lq.TMM1.Cmp(decimal.Zero) != 0 {
|
||
t1 = t1.Sub(lq.TMM1)
|
||
}
|
||
if lq.UPNL1.Cmp(decimal.Zero) != 0 {
|
||
t1 = t1.Add(lq.UPNL1)
|
||
}
|
||
if lq.CumB.Cmp(decimal.Zero) != 0 {
|
||
t1 = t1.Add(lq.CumB)
|
||
}
|
||
if lq.CumL.Cmp(decimal.Zero) != 0 {
|
||
t1 = t1.Add(lq.CumL)
|
||
}
|
||
if lq.CumS.Cmp(decimal.Zero) != 0 {
|
||
t1 = t1.Add(lq.CumS)
|
||
}
|
||
|
||
position1BOTH := lq.Position1BOTH
|
||
side1BOTH := decimal.NewFromInt32(int32(lq.Side1BOTH))
|
||
position1LONG := lq.Position1LONG
|
||
position1SHORT := lq.Position1SHORT
|
||
|
||
d1 := t1.Sub(side1BOTH.Mul(position1BOTH).Mul(lq.EP1BOTH)).
|
||
Sub(position1LONG.Mul(lq.EP1LONG)).Add(position1SHORT.Mul(lq.EP1SHORT))
|
||
|
||
//d2=Position1BOTH*MMRB+Position1LONG*MMRL+Position1SHORT*MMRS-Side1BOTH*Position1BOTH-Position1LONG+Position1SHORT
|
||
t2 := position1BOTH.Mul(lq.MMRB).Add(position1LONG.Mul(lq.MMRL)).Add(position1SHORT.Mul(lq.MMRS))
|
||
t2 = t2.Sub(side1BOTH.Mul(position1BOTH))
|
||
d2 := t2.Sub(position1LONG).Add(position1SHORT)
|
||
//LP1= d1/d2
|
||
|
||
return d1.Div(d2)
|
||
}
|