xiaoding721
2024-10-15 07c079e2fc3c995498638a7c67968942c59fd435
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
Quintiq file version 2.0
#parent: #root
FunctionOverride CalcMaximumQuantity
{
  TextBody:
  [*
    value := 0.0;
    
    if( this.IsPlanning() or this.IsBase() )
    {
      planningup := ifexpr( this.IsPlanning(), 
                            this,                                                  // Case 1: planning UnitPeriod
                            this.PlanningUP().astype( UnitPeriodTransportQuantity ) ); // Case 2: base, non planning UnitPeriod: disaggregate value from planning UnitPeriod
      if( not isnull( planningup ) )
      {
        ratio := PeriodSpecification_MP::GetLengthOfTimeAndTimeUnitRatio( planningup.Period_MP().TimeUnit(),
                                                                          this.TimeUnitForCapacitiesCalculation(),
                                                                          1 /*NrOfTimeUnit*/,
                                                                          planningup.Start(),
                                                                          planningup.Duration() );
        
        planningvalue := ratio * this.MaxCapacityPerTimeUnit();
        
        value := this.PlanningSystemRatio() * planningvalue;
      }    
    }
    else
    { // Case 3: aggregated UnitPeriod: aggregate values from base  
      value := sum( this.GetChildrenOfPeriodDimension(), Elements.astype( UnitPeriodTransportBase ), e, e.MaximumQuantity() );  
    }
    
    this.MaximumQuantity( value );
  *]
}