Dijkstra examples - ObjectVision/GeoDMS GitHub Wiki

Configuration examples Dijkstra examples

example

unit<uint64> Dijkstra_cut := 
   dijkstra_m64('bidirectional(link_flag);startPoint(Node_rel);endPoint(Node_rel)
   ;cut(OrgZone_max_imp);od:OrgZone_rel,DstZone_rel'
       , NetworkSpec/OrgToDest/impedance
       , NetworkSpec/OrgToDest/F1
       , NetworkSpec/OrgToDest/F2
       , NetworkSpec/OrgToDest/LinkSet/roadtype    != classifications/OSM/roadtype/V/motorway  
	 && NetworkSpec/OrgToDest/LinkSet/roadtype != classifications/OSM/roadtype/V/motorway_link 
	 // motor way en motor way link, snelwegen zijn niet bidirectional
       , NetworkSpec/OrgToDest/nr_orgNode
       , NetworkSpec/OrgToDest/nr_destNode
       , MaxTravelTime
   ), FreeData = "false"
{
   attribute<int32> Inhabitants           := dest/Inhabitants_2019[DstZone_rel];
   attribute<int32> Inhabitants_org (org) := sum(Inhabitants, OrgZone_rel);
}
unit<uint64> Dijkstra_fullOD := //calculation a full origin-destination matrix
   dijkstra_m64('bidirectional(link_flag);startPoint(Node_rel);endPoint(Node_rel)
      ;od:impedance,OrgZone_rel,DstZone_rel'
       , NetworkSpec/OrgToDest/impedance
       , NetworkSpec/OrgToDest/F1
       , NetworkSpec/OrgToDest/F2
       , NetworkSpec/OrgToDest/LinkSet/roadtype    != classifications/OSM/roadtype/V/motorway 
         && NetworkSpec/OrgToDest/LinkSet/roadtype != classifications/OSM/roadtype/V/motorway_link 
         // motor way en motor way link, snelwegen zijn niet bidirectional
       , NetworkSpec/OrgToDest/nr_orgNode
       , NetworkSpec/OrgToDest/nr_destNode
   ), FreeData = "false"
{
   attribute<string> impedance_min := string(round(impedance / 60f)); 
   //Convert the impedance from seconds to minutes, round it off, and store it as a string value.

   unit<uint32> Matrix_Array := org
   {
       attribute<string> org_name           := org/label;
       attribute<string> impedance_min_list := AsList(impedance_min, ';', OrgZone_rel);
   }

   unit<uint32> Header : nrofrows = 1
   {
       attribute<string> values := AsList(dest/name, ';', const(0[Header],dest));
   }

   unit<uint32> Matrix_met_header := union_unit(Header, Matrix_Array) 
   //This unit can easily be exported to csv and used in other applications.
   {
       attribute<string> org_name := union_data(., const('',Header), Matrix_Array/org_name);
       attribute<string> values   := union_data(., Header/values, Matrix_Array/impedance_min_list) ;
   }
}
unit<uint64> Dijkstra_limit :=
   dijkstra_m64('bidirectional(link_flag);startPoint(Node_rel):max_imp
      ;endPoint(Node_rel);limit(OrgZone_max_mass,DstZone_mass)'
       , NetworkSpec/OrgToDest/impedance
       , NetworkSpec/OrgToDest/F1
       , NetworkSpec/OrgToDest/F2
       , NetworkSpec/OrgToDest/LinkSet/roadtype    != classifications/OSM/roadtype/V/motorway  
         && NetworkSpec/OrgToDest/LinkSet/roadtype != classifications/OSM/roadtype/V/motorway_link 
	 // motor way en motor way link, snelwegen zijn niet bidirectional
       , NetworkSpec/OrgToDest/nr_orgNode
       , NetworkSpec/OrgToDest/nr_destNode
       , MaxInhabitants, dest/Inhabitants_2019[float32]
   );

attribute<float32> DistanceToNearestDest (NodeSet) := 
   dijkstra_s('bidirectional(link_flag);startPoint(Node_rel)'
       , LinkSet/length
       , LinkSet/F1
       , LinkSet/F2
       , NetwerkSpec/OrgToDest/LinkSet/wegtype    != classifications/OSM/wegtype/v/motorway 
         && NetwerkSpec/OrgToDest/LinkSet/wegtype != classifications/OSM/wegtype/v/motorway_link
       , NetwerkSpec/OrgToDest/nr_destNode
   );
⚠️ **GitHub.com Fallback** ⚠️