diff --git a/pom.xml b/pom.xml
index ac71377..28b6112 100644
--- a/pom.xml
+++ b/pom.xml
@@ -6,7 +6,7 @@
matsim-all
- 2025.0-PR3402
+ 2025.0-PR3501
@@ -15,7 +15,7 @@
4.0.0
com.github.matsim-scenarios
matsim-kelheim
- 3.x-SNAPSHOT
+ 2024.2-SNAPSHOT
MATSim Kelheim Model
A transport model of the district of Kelheim and it's surroundings
@@ -212,7 +212,7 @@
org.apache.avro
avro
- 1.11.3
+ 1.12.0
diff --git a/src/main/java/org/matsim/analysis/postAnalysis/NoiseAverageAnalysis.java b/src/main/java/org/matsim/analysis/postAnalysis/NoiseAverageAnalysis.java
index 2749a67..e4526db 100644
--- a/src/main/java/org/matsim/analysis/postAnalysis/NoiseAverageAnalysis.java
+++ b/src/main/java/org/matsim/analysis/postAnalysis/NoiseAverageAnalysis.java
@@ -4,9 +4,9 @@
import org.apache.avro.file.DataFileReader;
import org.apache.avro.file.DataFileWriter;
import org.apache.avro.file.FileReader;
-import org.apache.avro.generic.GenericData;
import org.apache.avro.generic.GenericDatumReader;
import org.apache.avro.generic.GenericRecord;
+import org.apache.avro.generic.PrimitivesArrays;
import org.apache.avro.io.DatumWriter;
import org.apache.avro.specific.SpecificDatumWriter;
import org.apache.avro.util.Utf8;
@@ -215,10 +215,8 @@ private XYTData calcAvroMeans(List recordList, String dataFieldNa
getCoordData(object1, xCoords);
getCoordData(object2, yCoords);
-
-// TODO: for the example data even for the hourly data there was only one time stamp. This might be different with real data. this needs to be checked
- if (object3 instanceof GenericData.Array>) {
- List ints = new ArrayList<>((GenericData.Array) object3);
+ if (object3 instanceof PrimitivesArrays.IntArray intArray) {
+ List ints = new ArrayList<>(intArray);
if (!timeStamps.equals(ints)) {
if (timeStamps.isEmpty()) {
@@ -235,8 +233,8 @@ private XYTData calcAvroMeans(List recordList, String dataFieldNa
List values = new ArrayList<>();
for (Map.Entry, ?> entry : ((HashMap, ?>) object4).entrySet()) {
- if (entry.getKey() instanceof Utf8 && entry.getKey().toString().equals(dataFieldName) && entry.getValue() instanceof GenericData.Array>) {
- values.addAll((GenericData.Array) entry.getValue());
+ if (entry.getKey() instanceof Utf8 && entry.getKey().toString().equals(dataFieldName) && entry.getValue() instanceof PrimitivesArrays.FloatArray floatArray) {
+ values.addAll(floatArray);
String entryString = ((Utf8) entry.getKey()).toString();
@@ -265,8 +263,8 @@ private XYTData calcAvroMeans(List recordList, String dataFieldNa
}
private void getCoordData(Object object, List target) {
- if (object instanceof GenericData.Array>) {
- List floats = new ArrayList<>((GenericData.Array) object);
+ if (object instanceof PrimitivesArrays.FloatArray floatArray) {
+ List floats = new ArrayList<>(floatArray);
if (!target.equals(floats)) {
if (target.isEmpty()) {
diff --git a/src/main/java/org/matsim/dashboard/AverageKelheimEmissionsDashboard.java b/src/main/java/org/matsim/dashboard/AverageKelheimEmissionsDashboard.java
index fa369af..b5263be 100644
--- a/src/main/java/org/matsim/dashboard/AverageKelheimEmissionsDashboard.java
+++ b/src/main/java/org/matsim/dashboard/AverageKelheimEmissionsDashboard.java
@@ -21,17 +21,12 @@
package org.matsim.dashboard;
import org.matsim.analysis.postAnalysis.emissions.EmissionsPostProcessingAverageAnalysis;
-import org.matsim.simwrapper.Dashboard;
-import org.matsim.simwrapper.Data;
-import org.matsim.simwrapper.Header;
-import org.matsim.simwrapper.Layout;
+import org.matsim.simwrapper.*;
import org.matsim.simwrapper.viz.*;
import java.util.ArrayList;
import java.util.List;
-import static org.matsim.dashboard.AverageKelheimNoiseDashboard.*;
-
/**
* Average emissions dashboard for several runs with the same config but a different random seed.
*/
@@ -130,21 +125,16 @@ public void configure(Header header, Layout layout) {
layout.row("second").el(GridMap.class, (viz, data) -> {
viz.title = "CO₂ Emissions";
viz.description = "per day. Be aware that CO2 values are provided in the simulation sample size!";
- setGridMapStandards(viz);
+ DashboardUtils.setGridMapStandards(viz, data, "EPSG:25832");
viz.file = postProcess(data, "mean_emissions_grid_per_day.xyt.csv");
});
layout.row("third")
.el(GridMap.class, (viz, data) -> {
viz.title = "CO₂ Emissions";
viz.description = "per hour. Be aware that CO2 values are provided in the simulation sample size!";
- setGridMapStandards(viz);
+ DashboardUtils.setGridMapStandards(viz, data, "EPSG:25832");
viz.file = postProcess(data, "mean_emissions_grid_per_hour.csv");
});
}
- private static void setGridMapStandards(GridMap viz) {
- viz.projection = "EPSG:25832";
- viz.setColorRamp(new double[]{30, 40, 50, 60, 70}, new String[]{DARK_BLUE, LIGHT_BLUE, YELLOW, SAND, ORANGE, RED});
- viz.height = 12.0;
- }
}
diff --git a/src/main/java/org/matsim/dashboard/AverageKelheimNoiseDashboard.java b/src/main/java/org/matsim/dashboard/AverageKelheimNoiseDashboard.java
index b4715dd..d3d175e 100644
--- a/src/main/java/org/matsim/dashboard/AverageKelheimNoiseDashboard.java
+++ b/src/main/java/org/matsim/dashboard/AverageKelheimNoiseDashboard.java
@@ -1,10 +1,7 @@
package org.matsim.dashboard;
import org.matsim.analysis.postAnalysis.NoiseAverageAnalysis;
-import org.matsim.simwrapper.Dashboard;
-import org.matsim.simwrapper.Data;
-import org.matsim.simwrapper.Header;
-import org.matsim.simwrapper.Layout;
+import org.matsim.simwrapper.*;
import org.matsim.simwrapper.viz.ColorScheme;
import org.matsim.simwrapper.viz.GridMap;
import org.matsim.simwrapper.viz.MapPlot;
@@ -23,12 +20,7 @@ public class AverageKelheimNoiseDashboard implements Dashboard {
private final List dirs;
private final Integer noRuns;
private static final String NOISE = "noise";
- static final String DARK_BLUE = "#1175b3";
- static final String LIGHT_BLUE = "#95c7df";
- static final String ORANGE = "#f4a986";
- static final String RED = "#cc0c27";
- static final String SAND = "#dfb095";
- static final String YELLOW = "#dfdb95";
+
public AverageKelheimNoiseDashboard(List dirs, Integer noRuns) {
this.dirs = dirs;
@@ -78,38 +70,28 @@ public void configure(Header header, Layout layout) {
.el(GridMap.class, (viz, data) -> {
viz.title = "Noise Immissions (Grid)";
viz.description = "Total Noise Immissions per day";
- setGridMapStandards(viz, data);
+ DashboardUtils.setGridMapStandards(viz, data, "EPSG:25832");
viz.file = postProcess(data, "mean_immission_per_day.avro");
})
.el(GridMap.class, (viz, data) -> {
viz.title = "Hourly Noise Immissions (Grid)";
viz.description = "Noise Immissions per hour";
- setGridMapStandards(viz, data);
+ DashboardUtils.setGridMapStandards(viz, data, "EPSG:25832");
viz.file = postProcess(data, "mean_immission_per_hour.avro");
});
layout.row("damages")
.el(GridMap.class, (viz, data) -> {
viz.title = "Daily Noise Damages (Grid)";
viz.description = "Total Noise Damages per day [€]";
- setGridMapStandards(viz, data);
+ DashboardUtils.setGridMapStandards(viz, data, "EPSG:25832");
viz.file = postProcess(data, "mean_damages_receiverPoint_per_day.avro");
})
.el(GridMap.class, (viz, data) -> {
viz.title = "Hourly Noise Damages (Grid)";
viz.description = "Noise Damages per hour [€]";
- setGridMapStandards(viz, data);
+ DashboardUtils.setGridMapStandards(viz, data, "EPSG:25832");
viz.file = postProcess(data, "mean_damages_receiverPoint_per_hour.avro");
});
}
- private static void setGridMapStandards(GridMap viz, Data data) {
- viz.height = 12.0;
- viz.cellSize = 250;
- viz.opacity = 0.1;
- viz.maxHeight = 40;
- viz.projection = "EPSG:25832";
- viz.center = data.context().getCenter();
- viz.zoom = data.context().mapZoomLevel;
- viz.setColorRamp(new double[]{30, 40, 50, 60, 70}, new String[]{DARK_BLUE, LIGHT_BLUE, YELLOW, SAND, ORANGE, RED});
- }
}
diff --git a/src/main/java/org/matsim/dashboard/KelheimEmissionsDashboard.java b/src/main/java/org/matsim/dashboard/KelheimEmissionsDashboard.java
index 80141b0..f59d55e 100644
--- a/src/main/java/org/matsim/dashboard/KelheimEmissionsDashboard.java
+++ b/src/main/java/org/matsim/dashboard/KelheimEmissionsDashboard.java
@@ -23,6 +23,7 @@
import org.matsim.analysis.postAnalysis.emissions.KelheimOfflineAirPollutionAnalysisByEngineInformation;
import org.matsim.application.prepare.network.CreateGeoJsonNetwork;
import org.matsim.simwrapper.Dashboard;
+import org.matsim.simwrapper.DashboardUtils;
import org.matsim.simwrapper.Header;
import org.matsim.simwrapper.Layout;
import org.matsim.simwrapper.viz.GridMap;
@@ -94,21 +95,16 @@ public void configure(Header header, Layout layout) {
layout.row("second").el(GridMap.class, (viz, data) -> {
viz.title = "CO₂ Emissions";
viz.description = "per day. Be aware that CO2 values are provided in the simulation sample size!";
- setGridMapStandards(viz, 12.0, data.compute(KelheimOfflineAirPollutionAnalysisByEngineInformation.class, "emissions_grid_per_day.xyt.csv", new String[0]));
-
+ DashboardUtils.setGridMapStandards(viz, data, "EPSG:25832");
+ viz.file = data.compute(KelheimOfflineAirPollutionAnalysisByEngineInformation.class, "emissions_grid_per_day.xyt.csv", new String[0]);
});
layout.row("third")
.el(GridMap.class, (viz, data) -> {
viz.title = "CO₂ Emissions";
viz.description = "per hour. Be aware that CO2 values are provided in the simulation sample size!";
- setGridMapStandards(viz, 12., data.compute(KelheimOfflineAirPollutionAnalysisByEngineInformation.class, "emissions_grid_per_hour.csv"));
+ DashboardUtils.setGridMapStandards(viz, data, "EPSG:25832");
+ viz.file = data.compute(KelheimOfflineAirPollutionAnalysisByEngineInformation.class, "emissions_grid_per_hour.csv");
});
}
- private static void setGridMapStandards(GridMap viz, double height, String data) {
- viz.height = height;
- viz.projection = "EPSG:25832";
- viz.file = data;
- viz.setColorRamp(new double[]{30, 40, 50, 60, 70}, new String[]{DARK_BLUE, LIGHT_BLUE, YELLOW, SAND, ORANGE, RED});
- }
}
diff --git a/src/main/java/org/matsim/dashboard/KelheimSimWrapperRunner.java b/src/main/java/org/matsim/dashboard/KelheimSimWrapperRunner.java
index 01b3c3a..7baec11 100644
--- a/src/main/java/org/matsim/dashboard/KelheimSimWrapperRunner.java
+++ b/src/main/java/org/matsim/dashboard/KelheimSimWrapperRunner.java
@@ -106,7 +106,7 @@ public Integer call() throws Exception {
new DrtDashboardProvider().getDashboards(config, sw).forEach(sw::addDashboard);
}
if (noise){
- sw.addDashboard(new NoiseDashboard());
+ sw.addDashboard(new NoiseDashboard(config.global().getCoordinateSystem()));
}
try {
diff --git a/src/main/java/org/matsim/run/KelheimPtFareModule.java b/src/main/java/org/matsim/run/KelheimPtFareModule.java
deleted file mode 100644
index 2f82374..0000000
--- a/src/main/java/org/matsim/run/KelheimPtFareModule.java
+++ /dev/null
@@ -1,34 +0,0 @@
-package org.matsim.run;
-
-import org.matsim.api.core.v01.TransportMode;
-import org.matsim.core.config.ConfigUtils;
-import org.matsim.core.controler.AbstractModule;
-import playground.vsp.pt.fare.DistanceBasedPtFareHandler;
-import playground.vsp.pt.fare.DistanceBasedPtFareParams;
-import playground.vsp.pt.fare.PtFareConfigGroup;
-import playground.vsp.pt.fare.PtFareUpperBoundHandler;
-
-/**
- * Module to install classes for pt fare.
- */
-public class KelheimPtFareModule extends AbstractModule {
- @Override
- public void install() {
- // Set the money related thing in the config (planCalcScore) file to 0.
- getConfig().scoring().getModes().get(TransportMode.pt).setDailyMonetaryConstant(0);
- getConfig().scoring().getModes().get(TransportMode.pt).setMarginalUtilityOfDistance(0);
-
- // Initialize config group (and also write in the output config)
- PtFareConfigGroup ptFareConfigGroup = ConfigUtils.addOrGetModule(this.getConfig(), PtFareConfigGroup.class);
- DistanceBasedPtFareParams distanceBasedPtFareParams = ConfigUtils.addOrGetModule(this.getConfig(), DistanceBasedPtFareParams.class);
-
-
- // Add bindings
- addEventHandlerBinding().toInstance(new DistanceBasedPtFareHandler(distanceBasedPtFareParams));
- if (ptFareConfigGroup.getApplyUpperBound()) {
- PtFareUpperBoundHandler ptFareUpperBoundHandler = new PtFareUpperBoundHandler(ptFareConfigGroup.getUpperBoundFactor());
- addEventHandlerBinding().toInstance(ptFareUpperBoundHandler);
- addControlerListenerBinding().toInstance(ptFareUpperBoundHandler);
- }
- }
-}
diff --git a/src/main/java/org/matsim/run/RunKelheimScenario.java b/src/main/java/org/matsim/run/RunKelheimScenario.java
index d146f38..0a243b6 100644
--- a/src/main/java/org/matsim/run/RunKelheimScenario.java
+++ b/src/main/java/org/matsim/run/RunKelheimScenario.java
@@ -43,6 +43,7 @@
import org.matsim.contrib.dvrp.run.DvrpModule;
import org.matsim.contrib.dvrp.run.DvrpQSimComponents;
import org.matsim.contrib.dvrp.trafficmonitoring.DvrpModeLimitedMaxSpeedTravelTimeModule;
+import org.matsim.contrib.vsp.pt.fare.PtFareModule;
import org.matsim.contrib.vsp.scenario.SnzActivities;
import org.matsim.core.api.experimental.events.EventsManager;
import org.matsim.core.config.Config;
@@ -62,8 +63,8 @@
import org.matsim.simwrapper.SimWrapperModule;
import org.matsim.vehicles.VehicleType;
import picocli.CommandLine;
-import playground.vsp.pt.fare.DistanceBasedPtFareParams;
-import playground.vsp.pt.fare.PtFareConfigGroup;
+import org.matsim.contrib.vsp.pt.fare.DistanceBasedPtFareParams;
+import org.matsim.contrib.vsp.pt.fare.PtFareConfigGroup;
import playground.vsp.scoring.IncomeDependentUtilityOfMoneyPersonScoringParameters;
import javax.annotation.Nullable;
@@ -221,16 +222,18 @@ protected Config prepareConfig(Config config) {
// Minimum fare (e.g. short trip or 1 zone ticket)
distanceBasedPtFareParams.setMinFare(2.0);
- // Division between long trip and short trip (unit: m)
- distanceBasedPtFareParams.setLongDistanceTripThreshold(50000);
- // y = ax + b --> a value, for short trips
- distanceBasedPtFareParams.setNormalTripSlope(0.00017);
- // y = ax + b --> b value, for short trips
- distanceBasedPtFareParams.setNormalTripIntercept(1.6);
- // y = ax + b --> a value, for long trips
- distanceBasedPtFareParams.setLongDistanceTripSlope(0.00025);
- // y = ax + b --> b value, for long trips
- distanceBasedPtFareParams.setLongDistanceTripIntercept(30);
+
+ distanceBasedPtFareParams.setTransactionPartner("pt-operator");
+ DistanceBasedPtFareParams.DistanceClassLinearFareFunctionParams shortDistance = distanceBasedPtFareParams.getOrCreateDistanceClassFareParams(50000);
+ shortDistance.setFareIntercept(1.6);
+ shortDistance.setFareSlope(0.00017);
+
+ DistanceBasedPtFareParams.DistanceClassLinearFareFunctionParams longDistance = distanceBasedPtFareParams.getOrCreateDistanceClassFareParams(Double.POSITIVE_INFINITY);
+ longDistance.setFareIntercept(30);
+ longDistance.setFareSlope(0.00025);
+ distanceBasedPtFareParams.setOrder(1);
+
+ ptFareConfigGroup.addParameterSet(distanceBasedPtFareParams);
//enable plan inheritance analysis
config.planInheritance().setEnabled(true);
@@ -291,7 +294,7 @@ protected void prepareControler(Controler controler) {
controler.addOverridingModule(new AbstractModule() {
@Override
public void install() {
- install(new KelheimPtFareModule());
+ install(new PtFareModule());
install(new SwissRailRaptorModule());
install(new PersonMoneyEventsAnalysisModule());
install(new SimWrapperModule());
@@ -377,17 +380,6 @@ public void install() {
// TODO: when to include AV?
//estimatorConfig.addParameterSet(new DrtEstimatorConfigGroup("av"));
-
-// if (intermodal){
-// controler.addOverridingModule(new IntermodalTripFareCompensatorsModule());
-// controler.addOverridingModule(new PtIntermodalRoutingModesModule());
-// controler.addOverridingModule(new AbstractModule() {
-// @Override
-// public void install() {
-// bind(RaptorIntermodalAccessEgress.class).to(EnhancedRaptorIntermodalAccessEgress.class);
-// }
-// });
-// }
}
}
}