Skip to content
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 'transfers' build config field #6215

Open
wants to merge 19 commits into
base: dev-2.x
Choose a base branch
from

Conversation

VillePihlava
Copy link
Contributor

@VillePihlava VillePihlava commented Nov 1, 2024

Summary

This PR adds the transfers build config field for configuring transfers. These parameters can be configured for all transfer modes:

  • disableDefaultTransfers: allows disabling default transfer calculations
  • maxTransferDuration: allows configuring a mode-specific maxTransferDuration
  • carsAllowedStopMaxTransferDuration: allows changing max transfer durations between stops that allow cars

This is a follow-up PR related to #5966. Example configuration:

  "transfers": {
    "CAR": {
      "disableDefaultTransfers": true,
      "carsAllowedStopMaxTransferDuration": "3h"
    },
    "BIKE": {
      "maxTransferDuration": "30m",
      "carsAllowedStopMaxTransferDuration": "3h"
    }
  },

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.

@VillePihlava VillePihlava requested a review from a team as a code owner November 1, 2024 11:15
Copy link

codecov bot commented Nov 1, 2024

Codecov Report

Attention: Patch coverage is 78.22581% with 27 lines in your changes missing coverage. Please review.

Project coverage is 69.86%. Comparing base (3a37262) to head (2e57c2f).
Report is 4 commits behind head on dev-2.x.

Files with missing lines Patch % Lines
...e/config/buildconfig/TransferParametersMapper.java 0.00% 20 Missing ⚠️
.../graph_builder/module/DirectTransferGenerator.java 91.78% 2 Missing and 4 partials ⚠️
.../standalone/config/buildconfig/TransferConfig.java 85.71% 1 Missing ⚠️
Additional details and impacted files
@@              Coverage Diff              @@
##             dev-2.x    #6215      +/-   ##
=============================================
+ Coverage      69.85%   69.86%   +0.01%     
- Complexity     17917    17939      +22     
=============================================
  Files           2035     2038       +3     
  Lines          76497    76609     +112     
  Branches        7822     7834      +12     
=============================================
+ Hits           53436    53524      +88     
- Misses         20325    20347      +22     
- Partials        2736     2738       +2     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@habrahamsson-skanetrafiken
Copy link
Contributor

There are some conflicts

Copy link
Member

@optionsome optionsome left a 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:

  1. Introduce carsAllowedStopMaxAccessEgressDurationsForMode. This is to prevent weird back-and-forth transfers to avoid access and egress duration limitations.
  2. 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);
Copy link
Member

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.

Copy link
Contributor Author

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();
Copy link
Member

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.

Copy link
Contributor Author

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
Copy link
Member

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.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Removed

@VillePihlava
Copy link
Contributor Author

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.

@VillePihlava VillePihlava marked this pull request as draft November 12, 2024 11:14
@VillePihlava VillePihlava changed the title Add carsAllowedStopMaxTransferDurationsForMode build config parameter Add 'transfers build config field Dec 3, 2024
@VillePihlava VillePihlava changed the title Add 'transfers build config field Add 'transfers' build config field Dec 3, 2024
@VillePihlava VillePihlava marked this pull request as ready for review December 17, 2024 08:10
Comment on lines +97 to +99
HashMap<StreetMode, NearbyStopFinder> defaultNearbyStopFinders = new HashMap<>();
/* These are used for calculating transfers only between carsAllowedStops. */
HashMap<StreetMode, NearbyStopFinder> carsAllowedStopNearbyStopFinders = new HashMap<>();
Copy link
Member

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.

Comment on lines +133 to +141
// Parse the transfer configuration from the parameters given in the build config.
parseTransferParameters(
defaultTransferRequests,
carsAllowedStopTransferRequests,
flexTransferRequests,
defaultNearbyStopFinders,
carsAllowedStopNearbyStopFinders,
nearbyStopFinder
);
Copy link
Member

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.

Copy link
Member

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.

@@ -180,6 +213,39 @@ public void buildGraph() {
}
}
}
// Calculate transfers between stops that can use trips with cars if configured.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// 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.

Comment on lines +220 to +222
for (NearbyStop sd : carsAllowedStopNearbyStopFinders
.get(mode)
.findNearbyStops(ts0, transferProfile, transferProfile.journey().transfer(), false)) {
Copy link
Member

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.

Comment on lines +328 to +329
// 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.
Copy link
Member

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?

import java.time.Duration;
import org.opentripplanner.utils.tostring.ToStringBuilder;

public record TransferParameters(
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In general we try to avoid exposing records in core code but in this context it might be ok.

Copy link
Member

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 decided that using a record in this case is ok.

.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.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we enfore this?

builder.withMaxTransferDuration(
c
.of("maxTransferDuration")
.summary("This overwrites the `maxTransferDuration` for the given mode.")
Copy link
Member

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.

c
.of("carsAllowedStopMaxTransferDuration")
.summary(
"This is used for specifying a `maxTransferDuration` value to use with transfers between stops that have trips with cars."
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
"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."

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same for the description.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants