lazhen
2024-08-26 dcfc6e79e2f5ea56458f0b542750e22b1f6a2d7a
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
Quintiq file version 2.0
#parent: #root
Method Start () as stream[JSON]
{
  Description:
  [*
    Start of the preprocessing step of the optimization run. 
    The actual start of the run happens in `StartAfterPreprocessing`.
  *]
  TextBody:
  [*
    this.CheckStart();
    
    this.MDSIDRun( this.MDSID() ); 
    
    
    time := OS::PrecisionCounter();
    this.StartedOnPrecision( time / OS::PrecisionCounterFrequency() );
    
    start_link := this.LinkStart();
    start_link.Sync();
    
    traverse( this, Channel, channel )
    {
      channel.AnalyzeGraph();
    }
    
    this.RequestedOn( DateTime::Now() );
    
    result := null( stream[JSON] );
    if( this.IsRunControllerEnabled() )
    {
      result := this.CheckOptimizerRunController();
    }
    else
    {
      result := this.StartAfterPreprocessing();
    }
    return result;
  *]
}