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
35
36
37
38
39
40
41
42
43
44
45
46
47
Quintiq file version 2.0
#parent: #root
Method GetActualCostPerPeriodSpecification (
  Period_MP period,
  output Real totalCost
) remote
{
  Description: 'Get the cost as per IsPlanning/IsBase/Others'
  TextBody:
  [*
    if( period.IsPlanning() ) //planning period, derive calculation
    {
      if( this.CostDriver() = Translations::MP_AccountAssignmentCostDriverFixed() )
      {
        totalCost := sum( this, Unit.PlanningUnitPeriod, pup,
                        pup.Period_MP() = period,
                        pup.GetFixedBaseCost( this.AccountAssignment(), null( UnitCost ) ) );
      }    
      else if( this.CostDriver() = Translations::MP_AccountAssignmentCostDriverStaffing() )
      {
        totalCost := sum( this, Unit.PlanningUnitPeriod, pup,
                          pup.Period_MP() = period,
                          pup.GetStaffingBaseCost( this.AccountAssignment(), null( UnitCost ) ) );
      }
      else if( this.CostDriver() = Translations::MP_AccountAssignmentCostDriverChangeover() )
      {
        totalCost := sum( this, Unit.PlanningUnitPeriod.astype( UnitPeriodTime ), pup,
                          pup.Period_MP() = period,
                          pup.GetBaseCostForChangeover( this.UnitAccount() ) );
      }        
    }
    else if( period.IsBase() ) //base period, disaggregate from planning period
    {
      totalCost := this.GetActualCosts( period.PlanningPeriod() ) * period.PlanningSystemRatio();
    }
    else  //non base non planning, sum from planning
    {
      traverse( this, Unit.UnitPeriod, spip, spip.Period_MP() = period )
      {
        traverse( spip.GetChildrenOfPeriodDimension(), Elements, childspip )
        {
          totalCost := totalCost + this.GetActualCosts( childspip.Period_MP() );
        }
      }                  
    }
  *]
}