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)
 | ||
| }
 |