yanweiyuan3
2023-08-09 588bc7829387dfc761cc25f06f77d4c81818bd10
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
Quintiq file version 2.0
#parent: #root
Method InitConstraintsForShiftPatternOnePerPeriod (
  CapacityPlanningSuboptimizer_CapacityPlanningAlgorithm program,
  const UnitPeriod up,
  Real scalefactor_spisused_const,
  Real scalefactor_rhs_const
) const
{
  Description: 'Checks that each unit period has exactly one shift pattern planned.'
  TextBody:
  [*
    constname := typeof( MPOneShiftPatternPerUnitPeriodConstraint );
    
    scalefactor_spisused_const := this.ScaleConstraintTerm( typeof( MPShiftPatternIsUsedVariable ), constname );
    
    scalefactor_rhs_const := this.ScaleConstraintRHS( constname, 1.0 );
    
    // Constraint: one shift pattern per unit period
    onespconstr := program.OneShiftPatternPerUnitPeriodConstraints().New( up );
    onespconstr.Sense( "=" );
    onespconstr.RHSValue( 1.0 * scalefactor_rhs_const );
    
    traverse( up, Unit.UnitShiftPatternAllowed.ShiftPattern, sp ) 
    {
      onespconstr.NewTerm( 1.0 * scalefactor_spisused_const, program.ShiftPatternIsUsedVariables().Get( sp, up ) );
    }
  *]
  InterfaceProperties { Accessibility: 'Module' }
}