lazhen
2024-07-29 6715f79ffe09dcac0157fa189b4d37844ee1d863
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
41
42
43
44
45
46
Quintiq file version 2.0
#parent: #root
MethodOverride AddTermsForDelayedSalesDemandsForward (
  CapacityPlanningSuboptimizer_CapacityPlanningAlgorithm program,
  MPConstraint constr,
  Real coefficient,
  const LibOpt_Scope scope,
  const CapacityPlanningSuboptimizer subopt,
  Number optminpostponementperiod
) const
{
  TextBody:
  [*
    scalefactor_delayeddisaggregadSDQty_constr := subopt.ScaleConstraintTerm( typeof( MPDelayedDisaggregatedSalesDemandQtyVariable ),
                                                                              typeofexpression( constr ) );
    
    pispip := this.AsPlanningBaseSalesDemandInPeriod();
    nextpispip := pispip.NextPlanningPISPIP();
    
    for( i := 2;
         i <= optminpostponementperiod
         and not isnull( nextpispip );
         i++
       )
    {
      nextpispip := nextpispip.NextPlanningPISPIP();
    }
    
    for( i := optminpostponementperiod;
         i <= this.MaxPostponementPeriod()      // within the maximum number of postponement periods
         and not isnull( nextpispip );          // the next pispip exists
         i++ )
    {
      if( scope.Contains( nextpispip.PISPIPInOptimizerRun() ) )
      {
        var := program.DelayedDisaggregatedSalesDemandQtyVariables().Find( this, nextpispip.Period_MP() );
        
        if( not isnull( var ) )
        {
          constr.NewTerm( coefficient * scalefactor_delayeddisaggregadSDQty_constr , var );
        }
      }
      nextpispip := nextpispip.NextPlanningPISPIP();
    }
  *]
}