|
|
@@ -172,37 +172,38 @@ impl AvellanedaStoikov {
|
|
|
pub async fn on_trade(&mut self, trade: &Trade) {
|
|
|
self.trade_vec.push_back(trade.clone());
|
|
|
|
|
|
- if self.trade_vec.deque.len() > 0 {
|
|
|
- // let prev_trade_iter = self.trade_vec.deque.iter().last().unwrap();
|
|
|
- // if trade.price > prev_trade_iter.price {
|
|
|
- // self.flow_in_value += trade.value;
|
|
|
- // } else if trade.price < prev_trade_iter.price {
|
|
|
- // self.flow_out_value += trade.value;
|
|
|
- // } else {
|
|
|
- // if trade.size > Decimal::ZERO {
|
|
|
- // self.flow_in_value += trade.value;
|
|
|
- // } else {
|
|
|
- // self.flow_out_value += trade.value;
|
|
|
- // }
|
|
|
- // }
|
|
|
-
|
|
|
- if trade.size > Decimal::ZERO {
|
|
|
+ if self.trade_vec.deque.len() > 1 {
|
|
|
+ let prev_trade_iter = self.trade_vec.deque.get(self.trade_vec.deque.len() - 2).unwrap();
|
|
|
+ if trade.price > prev_trade_iter.price {
|
|
|
self.flow_in_value += trade.value;
|
|
|
- } else {
|
|
|
+ } else if trade.price < prev_trade_iter.price {
|
|
|
self.flow_out_value += trade.value;
|
|
|
+ } else {
|
|
|
+ // if trade.size > Decimal::ZERO {
|
|
|
+ // self.flow_in_value += trade.value;
|
|
|
+ // } else {
|
|
|
+ // self.flow_out_value += trade.value;
|
|
|
+ // }
|
|
|
}
|
|
|
|
|
|
+ // if trade.size > Decimal::ZERO {
|
|
|
+ // self.flow_in_value += trade.value;
|
|
|
+ // } else {
|
|
|
+ // self.flow_out_value += trade.value;
|
|
|
+ // }
|
|
|
+
|
|
|
if self.flow_out_value + self.flow_in_value > dec!(2_000_000) {
|
|
|
self.flow_out_value = self.flow_out_value * dec!(0.618);
|
|
|
self.flow_in_value = self.flow_in_value * dec!(0.618);
|
|
|
}
|
|
|
- } else {
|
|
|
- if trade.size > Decimal::ZERO {
|
|
|
- self.flow_in_value += trade.value;
|
|
|
- } else {
|
|
|
- self.flow_out_value += trade.value;
|
|
|
- }
|
|
|
}
|
|
|
+ // else {
|
|
|
+ // if trade.size > Decimal::ZERO {
|
|
|
+ // self.flow_in_value += trade.value;
|
|
|
+ // } else {
|
|
|
+ // self.flow_out_value += trade.value;
|
|
|
+ // }
|
|
|
+ // }
|
|
|
|
|
|
// self.flow_in_value = Decimal::ZERO;
|
|
|
// self.flow_out_value = Decimal::ZERO;
|
|
|
@@ -292,25 +293,25 @@ impl AvellanedaStoikov {
|
|
|
if !self.flow_ratio.is_zero() {
|
|
|
if self.flow_ratio_change_long < Decimal::ZERO {
|
|
|
if self.flow_ratio_change_short > Decimal::ZERO {
|
|
|
- self.ask_delta -= self.base_delta * self.flow_ratio_change_short.abs() / dec!(0.03);
|
|
|
- self.bid_delta += self.base_delta * self.flow_ratio_change_short.abs() / dec!(0.03);
|
|
|
+ self.ask_delta -= self.base_delta;
|
|
|
+ self.bid_delta += self.base_delta;
|
|
|
} else if self.flow_ratio_change_short < Decimal::ZERO && self.inventory < Decimal::ZERO {
|
|
|
- self.ask_delta += self.base_delta * self.flow_ratio_change_short.abs() / dec!(0.03);
|
|
|
- self.bid_delta -= self.base_delta * self.flow_ratio_change_short.abs() / dec!(0.03);
|
|
|
+ self.ask_delta += self.base_delta;
|
|
|
+ self.bid_delta -= self.base_delta;
|
|
|
} else {
|
|
|
- self.ask_delta += self.base_delta * dec!(3);
|
|
|
- self.bid_delta += self.base_delta * dec!(3);
|
|
|
+ self.ask_delta += self.base_delta;
|
|
|
+ self.bid_delta += self.base_delta;
|
|
|
}
|
|
|
} else if self.flow_ratio_change_long > Decimal::ZERO {
|
|
|
if self.flow_ratio_change_short > Decimal::ZERO && self.inventory > Decimal::ZERO {
|
|
|
- self.ask_delta -= self.base_delta * self.flow_ratio_change_short.abs() / dec!(0.03);
|
|
|
- self.bid_delta += self.base_delta * self.flow_ratio_change_short.abs() / dec!(0.03);
|
|
|
+ self.ask_delta -= self.base_delta;
|
|
|
+ self.bid_delta += self.base_delta;
|
|
|
} else if self.flow_ratio_change_short < Decimal::ZERO {
|
|
|
- self.ask_delta += self.base_delta * self.flow_ratio_change_short.abs() / dec!(0.03);
|
|
|
- self.bid_delta -= self.base_delta * self.flow_ratio_change_short.abs() / dec!(0.03);
|
|
|
+ self.ask_delta += self.base_delta;
|
|
|
+ self.bid_delta -= self.base_delta;
|
|
|
} else {
|
|
|
- self.ask_delta += self.base_delta * dec!(3);
|
|
|
- self.bid_delta += self.base_delta * dec!(3);
|
|
|
+ self.ask_delta += self.base_delta;
|
|
|
+ self.bid_delta += self.base_delta;
|
|
|
}
|
|
|
}
|
|
|
} else {
|
|
|
@@ -338,7 +339,7 @@ impl AvellanedaStoikov {
|
|
|
}
|
|
|
|
|
|
pub fn update_flow_ratio(&mut self) {
|
|
|
- if self.flow_out_value + self.flow_in_value > dec!(500_000) {
|
|
|
+ if self.flow_out_value + self.flow_in_value > dec!(100_000) {
|
|
|
// 使用EMA來更新資金流,確保平滑性
|
|
|
let a = Decimal::TWO / dec!(50);
|
|
|
let now = (self.flow_in_value - self.flow_out_value) / (self.flow_out_value + self.flow_in_value);
|