Add logic to all models to avoid selling and immediately buying back the same security as this is considered a Wash Trade and is illegal.
This commit is contained in:
@@ -392,6 +392,7 @@ namespace MarketData.Generator.CMMomentum
|
||||
else
|
||||
{
|
||||
Positions slotPositions = ActivePositions[slotIndex];
|
||||
List<String> slotSymbols = slotPositions.ConvertAll(x=>x.Symbol); // capture sell symbols to exclude from purchases to eliminate wash trades
|
||||
SellPositions(slotPositions, TradeDate);
|
||||
DisplaySales(slotPositions, TradeDate);
|
||||
MDTrace.WriteLine(LogLevel.DEBUG, "********************* S E L L *********************");
|
||||
@@ -401,7 +402,7 @@ namespace MarketData.Generator.CMMomentum
|
||||
ActivePositions[slotIndex].Clear();
|
||||
DisplayBalance();
|
||||
double cashAllocation = Math.Min(CashBalance, (ActivePositions.GetExposure() + CashBalance) / HoldingPeriod); // Even out the cash allocation so that no one slot eats up all the cash
|
||||
Positions positions=BuyPositions(slotIndex,TradeDate,AnalysisDate,cashAllocation,SymbolsHeld());
|
||||
Positions positions=BuyPositions(slotIndex,TradeDate,AnalysisDate,cashAllocation,new List<String>(SymbolsHeld().Concat(slotSymbols)));
|
||||
DisplayPurchases(positions, TradeDate);
|
||||
MDTrace.WriteLine(LogLevel.DEBUG,"********************** B U Y ********************");
|
||||
positions.Display();
|
||||
|
||||
Reference in New Issue
Block a user