lazhen
2024-11-21 bfc0b1d0712613278dc218c5a7aa2ca797a3fbe2
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
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_delayedSDQty_constr := subopt.ScaleConstraintTerm( typeof( MPDelayedSalesDemandQtyVariable ), typeofexpression( constr ) );
    pispip := this.AsPlanningBaseSalesDemandInPeriod();
    
    if( this.CanBePostponed() and this.NeedsToBePlanned() )
    {
      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.DelayedSalesDemandQtyVariables().Get( this, nextpispip.Period_MP() );     
          constr.NewTerm( coefficient * scalefactor_delayedSDQty_constr , var );
        }
        nextpispip := nextpispip.NextPlanningPISPIP();
      }
    }
  *]
}