haorenhui
2023-10-30 6d6cc10d9e8e242661da7fd655dec155a09d676c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
Quintiq file version 2.0
#parent: #root
Method AddPTQtyGoal (
  const LibOpt_Scope scope,
  CapacityPlanningSuboptimizer_CapacityPlanningAlgorithm program,
  MPGoal goal
) const
{
  TextBody:
  [*
    if ( this.IsExecutePTQtyDoInventoryBased() ) 
    {
      traverse( scope.GetPISPIPInOptimizerRunConst(), Elements.astype( ProductInStockingPointInPeriodPlanningLeaf ), pispip, not pispip.ProductInStockingPoint_MP().IsNegativeInventoryAllowed() ) 
      {
        var := program.InvQtyVariables().Get(  pispip ); 
        goal.NewTerm( -1.0, var ); 
      }
    }
    else
    {
      traverse( scope.GetOperationInOptimizerRunConst(), Elements, operation )
      {
        periods := this.GetPeriodsForOperation( scope, operation );
        traverse( periods, Elements, period )
        {
          // PTQty variable UoM: Unit
          var := program.PTQtyVariables().Get( operation, period );
          goal.NewTerm( -1.0, var ) 
        }
      }
      
      traverse( scope.GetProductInTripInOptimizerRunConst(), Elements, productintrip )
      {
        var := program.TripNewSupplyVariables().Get( productintrip ); // The supply quantity for product in trip
        goal.NewTerm( -1.0, var )   
      }  
    }
  *]
  InterfaceProperties { Accessibility: 'Module' }
}