Quintiq file version 2.0 
 | 
#parent: #root 
 | 
Function CalcATCFDistance 
 | 
{ 
 | 
  TextBody: 
 | 
  [* 
 | 
    // tyg2 Mar-31-2016 (created) 
 | 
     
 | 
    /* 
 | 
    see http://mathworld.wolfram.com/GreatCircle.html 
 | 
    */ 
 | 
    value := 0.0; 
 | 
     
 | 
    earthRadius := 6378 
 | 
     
 | 
    orileg := guard( this.AsOriginStockingPointLeg().StockingPoint_MP().GIS_StockingPointAddress().GIS_StockingPointGeocodeResult().Selected(), null( LibGIS_GeocodedAddress ) ); 
 | 
    destleg := guard( this.AsDestinationStockingPointLeg().StockingPoint_MP().GIS_StockingPointAddress().GIS_StockingPointGeocodeResult().Selected(), null( LibGIS_GeocodedAddress ) ); 
 | 
     
 | 
    if( not ( isnull( orileg ) or isnull( destleg ) ) ) 
 | 
    { 
 | 
     
 | 
      unitlat := pi * orileg.Y() / 180.0 
 | 
      unitlong := pi * orileg.X() / 180.0 
 | 
      splat := pi * destleg.Y() / 180.0 
 | 
      splong := pi * destleg.X() / 180.0 
 | 
     
 | 
      theCos := cos( splat ) * cos( unitlat )* cos( splong  - unitlong )  + sin( splat ) * sin ( unitlat ) 
 | 
     
 | 
      // round-off errors. 
 | 
      // M AF Putting the 1.0 as the first parameter causes trouble, submited rfc 
 | 
      theCos := maxvalue( theCos,  -1.0 ) 
 | 
      theCos := minvalue( theCos,  1.0 ) 
 | 
     
 | 
      angle :=  acos( theCos ) 
 | 
     
 | 
      value := angle * earthRadius; 
 | 
    } 
 | 
     
 | 
    this.ATCFDistance( value ); 
 | 
  *] 
 | 
} 
 |