-
Notifications
You must be signed in to change notification settings - Fork 1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add 'transferParameters' build config field #6215
base: dev-2.x
Are you sure you want to change the base?
Add 'transferParameters' build config field #6215
Conversation
…th the 'carsAllowedStopMaxTransferDurationsForMode' build config parameter.
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## dev-2.x #6215 +/- ##
=============================================
- Coverage 69.85% 69.82% -0.04%
- Complexity 17917 17965 +48
=============================================
Files 2035 2045 +10
Lines 76497 76765 +268
Branches 7822 7843 +21
=============================================
+ Hits 53436 53598 +162
- Misses 20325 20423 +98
- Partials 2736 2744 +8 ☔ View full report in Codecov by Sentry. |
There are some conflicts |
…into car-transferrequest-filtering
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've had too many reviews today already so I didn't go properly through this. However, inspired by some concerns from @t2gran, I think to avoid issues we should do a couple of things:
- Introduce
carsAllowedStopMaxAccessEgressDurationsForMode
. This is to prevent weird back-and-forth transfers to avoid access and egress duration limitations. - Prevent these transfers from being used by other street modes. I don't know if this is already done or not but I think at least previously all the transfers were in the same collection. This could again lead to weird back and forth travel by walking for example to escape some other restrictions.
mBuilder.withEgressMode(StreetMode.WALK); | ||
mBuilder.withDirectMode(StreetMode.CAR); | ||
// This is used in transfer cache request calculations. | ||
mBuilder.withAllStreetModes(StreetMode.CAR); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I know this builder method wasn't introduced in this pr but this name is really confusing. Idk what we call Access+Transfer+Egress+Direct. It's difficult to come up with a name that doesn't confuse you into thinking that all modes are enabled. Just making this singular would maybe make it less confusing.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I changed it to set each mode separately for more clarity
@@ -60,6 +68,23 @@ public DirectTransferGenerator( | |||
this.issueStore = issueStore; | |||
this.radiusByDuration = radiusByDuration; | |||
this.transferRequests = transferRequests; | |||
this.carsAllowedStopMaxTransferDurationsForMode = DurationForEnum.of(StreetMode.class).build(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe we should always include this with some default value that is the same as the normal transfer duration limit.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This has changed quite a lot, but you can look at how I handle an empty parameter
.stream() | ||
.map(StopLocation::getId) | ||
.map(graph::getStopVertexForStopId) | ||
.filter(TransitStopVertex.class::isInstance) // filter out null values if no TransitStopVertex is found for ID |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Inline comments are not allowed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Removed
I'm changing this to a draft for now. I'll return to this once the work on the separate transfer request collections for modes has been completed. |
…into car-transferrequest-filtering
HashMap<StreetMode, NearbyStopFinder> defaultNearbyStopFinders = new HashMap<>(); | ||
/* These are used for calculating transfers only between carsAllowedStops. */ | ||
HashMap<StreetMode, NearbyStopFinder> carsAllowedStopNearbyStopFinders = new HashMap<>(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would call these xNearbyStopFinderForMode
as the plural makes me think these are lists.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Changed to the suggestion.
// Parse the transfer configuration from the parameters given in the build config. | ||
parseTransferParameters( | ||
defaultTransferRequests, | ||
carsAllowedStopTransferRequests, | ||
flexTransferRequests, | ||
defaultNearbyStopFinders, | ||
carsAllowedStopNearbyStopFinders, | ||
nearbyStopFinder | ||
); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think I would prefer this method to return a private record which contains the different transfer requests and stop finders instead of initializing them here and populating them inside this method, but we could discuss this in a dev meeting.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We discussed this in a dev meeting and agreed that we should return a record "result" from the method.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This now returns a record.
@@ -180,6 +213,39 @@ public void buildGraph() { | |||
} | |||
} | |||
} | |||
// Calculate transfers between stops that can use trips with cars if configured. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
// Calculate transfers between stops that can use trips with cars if configured. | |
// Calculate transfers between stops that are visited by trips that allow cars, if configured. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Changed to the suggestion.
for (NearbyStop sd : carsAllowedStopNearbyStopFinders | ||
.get(mode) | ||
.findNearbyStops(ts0, transferProfile, transferProfile.journey().transfer(), false)) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These for statements that span over multiple lines are difficult to read. Put the list in a variable and use that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Changed to the suggestion.
// Disable normal transfer calculations for the specific mode, if disableDefaultTransfers is set in the build config. | ||
// WALK mode transfers can not be disabled. For example, flex transfers need them. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we enforce this restriction with a warning/crash when reading in the configuration?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I changed it to throw an IllegalArgumentException
when WALK mode transfers are configured to be disabled. Should a check also be made for a transferRequests
field without the WALK mode?
application/src/main/java/org/opentripplanner/graph_builder/module/TransferParameters.java
Show resolved
Hide resolved
.description( | ||
""" | ||
This field enables configuring mode-specific parameters for transfer calculations. | ||
To configure mode-specific parameters, the modes should also be used in the `transferRequests` field in the build config. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we enfore this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The parsing method now throws an IllegalArgumentException
when a mode is used in the transferParameters
but not in the transferRequests
builder.withMaxTransferDuration( | ||
c | ||
.of("maxTransferDuration") | ||
.summary("This overwrites the `maxTransferDuration` for the given mode.") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Clarify that it overrides the default maxTransferDuration
as currently this can be understood in a couple of different ways.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added the word default, is this good?
c | ||
.of("carsAllowedStopMaxTransferDuration") | ||
.summary( | ||
"This is used for specifying a `maxTransferDuration` value to use with transfers between stops that have trips with cars." |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"This is used for specifying a `maxTransferDuration` value to use with transfers between stops that have trips with cars." | |
"This is used for specifying a `maxTransferDuration` value to use with transfers between stops which are visited by trips that allow cars." |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same for the description.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I changed it to the suggestion.
@@ -56,14 +60,31 @@ public DirectTransferGenerator( | |||
Graph graph, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this constructor used only for testing? If so, can you add Javadoc?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added a short javadoc
this.transferRequests = transferRequests; | ||
this.transferParametersForMode = Collections.emptyMap(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this.transferParametersForMode = Collections.emptyMap(); | |
this.transferParametersForMode = Map.of(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I changed this to the suggestion.
.get(mode) | ||
.findNearbyStops(ts0, transferProfile, transferProfile.journey().transfer(), false)) { | ||
// Skip the origin stop, loop transfers are not needed. | ||
if (sd.stop == stop) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Isn't this block a copy&paste job from the one above? Can it be reused?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I created a method for creating the PathTransfer and TransferKey. Is this fine?
…errors when invalid transferParameters are given.
Should this bump the serialization id since the path transfers are now mode dependent? |
| [maxDataImportIssuesPerFile](#maxDataImportIssuesPerFile) | `integer` | When to split the import report. | *Optional* | `1000` | 2.0 | | ||
| maxElevationPropagationMeters | `integer` | The maximum distance to propagate elevation to vertices which have no elevation. | *Optional* | `2000` | 1.5 | | ||
| [maxStopToShapeSnapDistance](#maxStopToShapeSnapDistance) | `double` | Maximum distance between route shapes and their stops. | *Optional* | `150.0` | 2.1 | | ||
| maxTransferDuration | `duration` | Transfers up to this duration with the default walk speed value will be pre-calculated and included in the Graph. | *Optional* | `"PT30M"` | 2.1 | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should this parameter be moved to be inside transferParameters? Also, I think the description is wrong since this can be used for other types of transfers as well. There might be one or two other parameters that could be moved to be under transferParameters such as discardMinTransferTimes
and maybe stationTransferPreference
.
Duration carsAllowedStopMaxTransferDuration, | ||
boolean disableDefaultTransfers | ||
) { | ||
public static final Duration DEFAULT_MAX_TRANSFER_DURATION = Duration.ZERO; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Isn't the default 30 minutes? I think the default should be set only in one place and then used from there elsewhere.
boolean disableDefaultTransfers | ||
) { | ||
public static final Duration DEFAULT_MAX_TRANSFER_DURATION = Duration.ZERO; | ||
public static final Duration DEFAULT_CARS_ALLOWED_STOP_MAX_TRANSFER_DURATION = Duration.ZERO; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't know if the default value for this should be the same as the normal default or null.
@@ -287,6 +293,7 @@ When set to true (it is false by default), the elevation module will include the | |||
"Transfers up to this duration with the default walk speed value will be pre-calculated and included in the Graph." | |||
) | |||
.asDuration(Duration.ofMinutes(30)); | |||
transferParametersForMode = TransferConfig.map(root, "transferParameters"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This variable should be renamed if we decide to make the transferParameters
used for other transfer parameters as well.
import org.opentripplanner.graph_builder.module.TransferParameters; | ||
import org.opentripplanner.standalone.config.framework.json.NodeAdapter; | ||
|
||
public class TransferParametersMapper { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These parameters don't show up in the BuildConfiguration.md
now. If I remember correctly, you should at least add them to https://github.com/opentripplanner/OpenTripPlanner/blob/dev-2.x/application/src/test/resources/standalone/config/build-config.json and https://github.com/opentripplanner/OpenTripPlanner/blob/dev-2.x/application/src/test/java/org/opentripplanner/generate/doc/framework/NodeAdapterHelper.java#L8-L20 as well.
.description( | ||
""" | ||
This parameter configures additional transfers to be calculated for the specified mode only between stops that have trips with cars. | ||
The transfers are calculated for the mode in a range based on the given duration. | ||
By default, these transfers are not calculated for the specified mode. | ||
""" | ||
) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since this parameter is rather odd on the first glance, you could explain a bit here that this might be useful when there are ferries that sort of extend the road network.
builder.withDisableDefaultTransfers( | ||
c | ||
.of("disableDefaultTransfers") | ||
.summary("This disables default transfer calculations.") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You could add a bit more descriptive description for what the default transfer calculations means and why you might want to do this.
Summary
This PR adds the
transferParameters
build config field for configuring transfers. These parameters can be configured for all transfer modes:disableDefaultTransfers
: allows disabling default transfer calculationsmaxTransferDuration
: allows configuring a mode-specificmaxTransferDuration
carsAllowedStopMaxTransferDuration
: allows changing max transfer durations between stops that allow carsThis is a follow-up PR related to #5966. Example configuration:
Issue
This is a follow-up PR related to issue #5875.
Unit tests
I created new unit tests for testing the changes to the
DirectTransferGenerator
Documentation
Changes to
BuildConfiguration.md
Bumping the serialization version id
This change affects how transfers are calculated and adds a new field to the
build-config.json
file.