lazhen
2025-01-09 8afe90b633046db39042aada36b88193062f8cff
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
Quintiq file version 2.0
#parent: #root
MethodOverride InitConstraintsForUnitPeriodCapacities (
  CapacityPlanningSuboptimizer_CapacityPlanningAlgorithm program,
  Boolean enableminconst,
  Real totalmincapacity,
  Real totalmaxcapacity,
  const RunContextForCapacityPlanning runcontext,
  const LibOpt_Scope scope,
  const CapacityPlanningSuboptimizer subopt
) const
{
  TextBody:
  [*
    // defining minimum capacities for unit, Sum of PT Qty + not met >= UP.MinCapacity
    // minconstup constraint UoM: Unit
    minconstup := program.MinUnitCapacityQtyConstraints().New( this );
    minconstup.Sense( '>=' );
    
    // RHS UoM: Unit
    minconstup.RHSValue( subopt.ScaleConstraintRHS( typeofexpression( minconstup ), totalmincapacity ) );
    // Term UoM: Unit
    var := this.GetCapacityNotMetVariable( program ); 
    minconstup.NewTerm( 1.0 * subopt.ScaleConstraintTerm( typeofexpression( var ), typeofexpression( minconstup ) )
                        , var );
    minconstup.Enabled( enableminconst )
    
    // defining maximum capacities for unit, Sum of PT Qty <= UP.AvailableCapacity
    // maxconstup constraint UoM: Unit
    maxconstup := program.MaxUnitCapacityQtyConstraints().New( this );
    maxconstup.Sense( '<=' );
    // RHS UoM: Unit
    maxconstup.RHSValue( subopt.ScaleConstraintRHS( typeofexpression( maxconstup ), totalmaxcapacity ) );
    maxconstup.Enabled( not this.IsPlannedInfinite() );
    
    this.InitConstraintsForCapacityUsage( program, minconstup, maxconstup, runcontext, scope, subopt  );
    
    //--------------------------------------------------------
    //--------------------------------------------------------
    //init constraints for secondary capacity definition
    if( this.HasSecondaryCapacityDefinition() )
    {
      // defining minimum capacities for unit, Sum of PT Qty + not met >= UP.MinCapacity
      // minconstup constraint UoM: Unit
      minseconddaryconstup := program.MinUnitSecondaryCapacityQtyConstraints().New( this );
      minseconddaryconstup.Sense( '>=' );
    
      totalsecondarymincapacity := this.TotalSecondaryMinimumQuantity();
      // RHS UoM: Unit
      minseconddaryconstup.RHSValue( subopt.ScaleConstraintRHS( typeofexpression( minseconddaryconstup ), totalsecondarymincapacity ) );
      // Term UoM: Unit
    
      minseconddaryconstup.NewTerm( 1.0 * subopt.ScaleConstraintTerm( typeof( MPUnitSecondaryCapacityNotMetVariable ), typeofexpression( minseconddaryconstup ) )
                          , program.UnitSecondaryCapacityNotMetVariables().Get( this ) );
      minseconddaryconstup.Enabled( this.TotalSecondaryMinimumQuantity() > 0 )
      
      // defining maximum capacities for unit, Sum of PT Qty <= UP.AvailableCapacity
      totalsecondarymaxcapacity := this.TotalSecondaryMaximumQuantity();
      // maxconstup constraint UoM: Unit
      maxsecondaryconstup := program.MaxUnitSecondaryCapacityQtyConstraints().New( this );
      maxsecondaryconstup.Sense( '<=' );
      // RHS UoM: Unit
      maxsecondaryconstup.RHSValue( subopt.ScaleConstraintRHS( typeofexpression( maxconstup ), totalsecondarymaxcapacity ) );
      maxsecondaryconstup.Enabled( not this.IsPlannedInfinite() );
      
      this.InitConstraintsForSecondaryCapacityUsage( program, minseconddaryconstup, maxsecondaryconstup, runcontext, scope, subopt );                
    }
  *]
}