yanyuan
2023-11-10 143ef74e2eeee697ac8fda3d9032a790fbb4e146
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
Quintiq file version 2.0
#parent: #root
MethodOverride GetBaseCostPerQuantity () declarative remote as Real
{
  TextBody:
  [*
    // For performance purpose, we derived this formula.
    // NewSupply.BaseCostPerQuantity = PeriodTask.BaseCost / Sum of NewSupply.Quantity
    //                               = PeriodTask.QuantityToProcess * PeriodTask.BaseCostPerQuantity / PeriodTask.Quantity           ( Sum of NewSupply.Quantity = PeriodTask.Quantity )
    //                               = PeriodTask.Process.QuantityToProcessFactor * PeriodTask.QuantityOut * PeriodTask.BaseCostPerQuantity / PeriodTask.Quantity
    //                               = PeriodTask.Process.QuantityToProcessFactor * PeriodTask.BaseCostPerQuantity
    
    value := 0.0;
    periodtask := this.PeriodTask_MP();
    
    quantitytoprocessfactor := periodtask.Process_MP().QuantityToProcessFactor();
    
    traverse( periodtask, Process_MP.AsProcess_MP.UnitAccount, aa )
    {
      costperqty := 0.0;
    
      if( aa.CostDriver() = Translations::MP_AccountAssignmentCostDriverVolume() )
      {
        costperqty := periodtask.Process_MP().GetBaseCostPerQuantityForVolume( aa, periodtask.UnitPeriod() ) * quantitytoprocessfactor;
      }
      else if( aa.CostDriver() = Translations::MP_AccountAssignmentCostDriverTime() )
      {
        costperqty := periodtask.Process_MP().GetBaseCostPerQuantityForHour( aa, periodtask.UnitPeriod(), periodtask.RequiredCapacity() ) * quantitytoprocessfactor;
      }
    
      value := value + costperqty;
    }
    
    return value;
  *]
}