From 18aab7d6156b93d65c1b18809d924cbb214d737a Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 26 Feb 2021 16:04:03 +0800
Subject: [PATCH] Merge branch 'whole_new' of http://120.27.238.55:7000/r/exchange into whole_new
---
src/main/java/com/xcong/excoin/utils/CalculateUtil.java | 13 +++++--------
1 files changed, 5 insertions(+), 8 deletions(-)
diff --git a/src/main/java/com/xcong/excoin/utils/CalculateUtil.java b/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
index 183a4a4..935f1f3 100644
--- a/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
+++ b/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
@@ -80,7 +80,7 @@
/**
* 全仓模式 -- 预估强平价
- * 开仓价 - (权益 - 其他币种成本)/当前币种成本 * (开仓价 * 杠杆)
+ * 开仓价 - (权益 - 其他币种成本)/当前币种成本 * (开仓价 * 1/杠杆)
*/
public static BigDecimal getForceSetPriceForWhole(String currentSymbol, @NotNull MemberEntity memberEntity) {
ContractHoldOrderDao holdOrderDao = SpringContextHolder.getBean(ContractHoldOrderDao.class);
@@ -97,8 +97,6 @@
for (String symbol : symbols) {
// 其他币种成本
BigDecimal totalBondAmount = BigDecimal.ZERO;
- // 当前币种手续费
- BigDecimal symbolFeeAmount = BigDecimal.ZERO;
// 当前币种保证金
BigDecimal symbolBondAmount = BigDecimal.ZERO;
@@ -116,8 +114,7 @@
if (holdOrderEntity.getOpeningType() == ContractHoldOrderEntity.OPENING_TYPE_MORE) {
isAloneLess = false;
}
- symbolFeeAmount = symbolFeeAmount.add(holdOrderEntity.getOpeningFeeAmount());
- symbolBondAmount = symbolBondAmount.add(bondAmount);
+ symbolBondAmount = symbolBondAmount.add(bondAmount.subtract(holdOrderEntity.getOpeningFeeAmount()));
if (openPrice.compareTo(BigDecimal.ZERO) == 0) {
openPrice = holdOrderEntity.getOpeningPrice();
@@ -132,8 +129,8 @@
}
// log.info("{}, {}, {}, {}, {}, {}", totalBondAmount, symbolBondAmount, symbolFeeAmount, openPrice, profitOrLoss, leverRatio);
- BigDecimal equity = walletContract.getTotalBalance().add(profitOrLoss);
- BigDecimal sub = equity.subtract(symbolFeeAmount).subtract(totalBondAmount);
+ BigDecimal equity = walletContract.getTotalBalance().add(profitOrLoss).subtract(walletContract.getFrozenBalance());
+ BigDecimal sub = equity.subtract(totalBondAmount);
// log.info("sub -- {}", sub);
if (sub.compareTo(symbolBondAmount) <= 0) {
BigDecimal multi = BigDecimal.valueOf(10);
@@ -166,7 +163,7 @@
return result;
}
- private static BigDecimal calProfitOrLoss(ContractHoldOrderEntity holdOrderEntity, MemberEntity memberEntity) {
+ public static BigDecimal calProfitOrLoss(ContractHoldOrderEntity holdOrderEntity, MemberEntity memberEntity) {
CacheSettingUtils cacheSettingUtils = SpringContextHolder.getBean(CacheSettingUtils.class);
RedisUtils redisUtils = SpringContextHolder.getBean(RedisUtils.class);
BigDecimal lotNumber = cacheSettingUtils.getSymbolSku(holdOrderEntity.getSymbol());
--
Gitblit v1.9.1