lazhen
2024-09-13 b343b593893e2f3278f2695d1411f3aacaeedfc8
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_AccountAssignmentCostDriverVolume() )
      {
        totalCost := sum( this, LaneLeg.Trip.PeriodTaskLaneLeg, ptll,
                          ptll.UnitPeriod().Period_MP() = period,
                          ptll.GetTotalBaseCostForVolume( this.UnitAccount() ) );
      }    
      else if( this.CostDriver() = Translations::MP_AccountAssignmentCostDriverTime() )
      {
        totalCost := sum( this, LaneLeg.Trip.PeriodTaskLaneLeg, ptll,
                          ptll.UnitPeriod().Period_MP() = period,
                          ptll.GetTotalBaseCostForHour( this.UnitAccount() ) );
      } 
      else if( this.CostDriver() = Translations::MP_AccountAssignmentCostDriverLot() ) 
      {
        totalCost := sum( this, LaneLeg.Trip.PeriodTaskLaneLeg, ptll,
                          ptll.UnitPeriod().Period_MP() = period,
                          ptll.GetTotalBaseCostForLot( 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, LaneLeg.Trip.PeriodTaskLaneLeg, ptll, ptll.UnitPeriod().Period_MP() = period )
      {
        traverse( ptll.UnitPeriod().GetChildrenOfPeriodDimension(), Elements, childspip )
        {
          totalCost := totalCost + this.GetActualCosts( childspip.Period_MP() );
        }
      }                  
    }
  *]
}