From 8e570e865dfce61126f87c6402d23f5544688929 Mon Sep 17 00:00:00 2001 From: rakow Date: Tue, 14 May 2024 21:35:34 +0200 Subject: [PATCH] adding features useful for intersections --- .../sumo/SumoNetworkFeatureExtractor.java | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/contribs/sumo/src/main/java/org/matsim/contrib/sumo/SumoNetworkFeatureExtractor.java b/contribs/sumo/src/main/java/org/matsim/contrib/sumo/SumoNetworkFeatureExtractor.java index a060e98ee76..f6e4150cd8d 100644 --- a/contribs/sumo/src/main/java/org/matsim/contrib/sumo/SumoNetworkFeatureExtractor.java +++ b/contribs/sumo/src/main/java/org/matsim/contrib/sumo/SumoNetworkFeatureExtractor.java @@ -1,5 +1,7 @@ package org.matsim.contrib.sumo; +import it.unimi.dsi.fastutil.objects.Object2IntMap; +import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap; import org.apache.commons.csv.CSVPrinter; import org.matsim.contrib.osm.networkReader.LinkProperties; @@ -116,7 +118,10 @@ public List getHeader() { return List.of("linkId", "highway_type", "speed", "length", "num_lanes", "change_num_lanes", "change_speed", "num_to_links", "num_conns", "num_response", "num_foes", "dir_multiple_s", "dir_l", "dir_r", "dir_s", "dir_exclusive", "curvature", "junction_type", "junction_inc_lanes", "priority_higher", "priority_equal", "priority_lower", - "is_secondary_or_higher", "is_primary_or_higher", "is_motorway", "is_link", "has_merging_link", "is_merging_into"); + "is_secondary_or_higher", "is_primary_or_higher", "is_motorway", + "is_link", "has_merging_link", "is_merging_into", + "num_connections", "num_left", "num_right", "num_straight" + ); } public void print(CSVPrinter out) { @@ -157,12 +162,18 @@ public void print(CSVPrinter out, String linkId, SumoNetworkHandler.Edge edge) t Set dirs = new HashSet<>(); boolean multipleDirS = false; boolean exclusiveDirs = true; + + // Number of connections per direction + Object2IntMap numConnections = new Object2IntOpenHashMap<>(); + for (SumoNetworkHandler.Connection c : connections) { Set d = directionSet(c); if (dirs.contains('s') && d.contains('s')) multipleDirS = true; + d.forEach(dir -> numConnections.mergeInt(dir, 1, Integer::sum)); + Set intersection = new HashSet<>(dirs); // use the copy constructor intersection.retainAll(d); if (!intersection.isEmpty()) @@ -233,6 +244,10 @@ public void print(CSVPrinter out, String linkId, SumoNetworkHandler.Edge edge) t out.print(bool(highwayType.contains("link"))); out.print(bool(merging)); out.print(mergingHighest); + out.print(connections.size()); + out.print(numConnections.getInt('l')); + out.print(numConnections.getInt('r')); + out.print(numConnections.getInt('s')); out.println(); }