| 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
 | | Quintiq file version 2.0 |  | #parent: #root |  | Method AddIntermediateSalesDemand |  | { |  |   TextBody: |  |   [* |  |     startdate := Date::Construct( 2020, 7, 1 );  |  |     enddate := Date::Construct( 2020, 10, 1 );  |  |     qty := 100000.0;  |  |     traverse( this, SalesSegment_MP, ss, ss.Name() = 'FakeSD' )  |  |     { |  |       traverse( ss, SalesDemand, sd )  |  |       { |  |         sd.Delete();  |  |       } |  |     } |  |      |  |     traverse( this, Priority, prio, prio.Name() = 'FakeSD' )  |  |     { |  |       traverse( prio, SalesDemand, sd )  |  |       { |  |         sd.Delete();  |  |       } |  |     } |  |     traverse( this, StockingPoint_MP, sp, not sp.Name() ~ '624' ) // 624 means customer beyond the distribution  |  |     { |  |       debuginfo(  'Creating fake products for SP ', sp.Name(), 'nr products', sp.ProductInStockingPoint_MP( relsize ) );  |  |        |  |       cnt := 0;  |  |       traverse( sp, ProductInStockingPoint_MP, pisp )  |  |       { |  |         cnt++;  |  |         if ( cnt mod 1000 = 0 )  |  |         { |  |           debuginfo(  'processed', cnt, ' products' );  |  |         } |  |         product := pisp.Product_MP();  |  |         if ( not product.Name() ~ 'RAW'  and product.IsLeaf() )  |  |         { |  |           Forecast::Create(  product, sp, pisp.StockingPointID() + pisp.ProductID(), startdate, enddate, qty,  1.0, 'FakeSD', 'FakeSD', 'EUR', 'm3', 0.0, false, false );  |  |         } |  |       } |  |     } |  |   *] |  |   InterfaceProperties { Accessibility: 'Module' } |  | } | 
 |