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
47
48
49
50
51
52
53
54
55
56
57
58
59
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:
  [*
    algorithm := subopt; 
    
    // defining minimum capacities for unit, Sum of PT Qty + not met >= UP.MinCapacity
    // minconstup constraint UoM: Unit
    minconstup := null( MPConstraint );
    
    if( this.Unit().HasCapacityTypeTransportTime() ) 
    {
      minconstup := program.MinUnitCapacityTimeConstraints().New( this );
    }
    else
    {
      minconstup := program.MinUnitCapacityQtyConstraints().New( this );
    }
    
    minconstup.Sense( '>=' );
    
    // RHS UoM: Unit
    minconstup.RHSValue( algorithm.ScaleConstraintRHS( typeofexpression( minconstup ), totalmincapacity ) );
    // Term UoM: Unit
    var := this.GetCapacityNotMetVariable( program ); 
    minconstup.NewTerm( 1.0 * algorithm.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 := null( MPConstraint );
    if( this.Unit().HasCapacityTypeTransportTime() )
    {
      maxconstup := program.MaxUnitCapacityTimeConstraints().New( this );
    }
    else
    {
      maxconstup := program.MaxUnitCapacityQtyConstraints().New( this );
    }
    
    maxconstup.Sense( '<=' );
    // RHS UoM: Unit
    maxconstup.RHSValue( algorithm.ScaleConstraintRHS( typeofexpression( maxconstup ), totalmaxcapacity ) );
    maxconstup.Enabled( not this.IsPlannedInfinite() );
    
    this.InitConstraintsForCapacityUsage( program, minconstup, maxconstup, runcontext, scope, subopt );
  *]
}