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

Not allowed transfers and support for GTFS transfer points #3792

Merged
merged 26 commits into from
Jan 26, 2022

Conversation

t2gran
Copy link
Member

@t2gran t2gran commented Dec 17, 2021

Summary

Explain in one or two sentences what this PR achieves.

Issue

Link to or create an issue that describes the relevant feature or bug.
You need not create an issue for small bugfixes and code cleanups, but in that case do describe the problem clearly and completely in the "summary" section above.
In the linked issue (or summary section for smaller PRs) please describe:

  • Motivation (problem or need encountered)
  • How the code works
  • Technical approach and any design considerations or decisions

Remember that the PR will be reviewed by another developer who may not be familiar with your use cases or the code you're modifying. It generally takes much less effort for the author of a PR to explain the background and technical details than for a reviewer to infer or deduce them. PRs may be closed if they or their linked issues do not contain sufficient information for a reviewer to proceed.

Add GitHub keywords to this PR's description, for example:

closes #45

Unit tests

Write a few words on how the new code is tested.

  • Were unit tests added/updated?
  • Was any manual verification done?
  • Any observations on changes to performance?
  • Was the code designed so it is unit testable?
  • Were any tests applied to the smallest appropriate unit?
  • Do all tests pass the continuous integration service?

Code style

Have you followed the suggested code style?

Documentation

  • Have you added documentation in code covering design and rationale behind the code?
  • Were all non-trivial public classes and methods documented with Javadoc?
  • Were any new configuration options added? If so were the tables in the configuration documentation updated?

Changelog

The changelog file
is generated from the pull-request title, make sure the title describe the feature or issue fixed.
To exclude the PR from the changelog add [changelog skip] in the title.

@t2gran t2gran added this to the 2.1 milestone Dec 17, 2021
@t2gran t2gran added New Feature Regression This feature is no longer working. labels Dec 17, 2021
@t2gran t2gran force-pushed the otp2_not_allowed_transfers branch from 9d64941 to ca028ac Compare December 20, 2021 08:50
Use a constant, REGULAR_TRANSFER instead of null to represent transfer constraint in boarding events. This enable the
constrained transfer search to return a regular transfer and avoid null checking.
One of the test is disabled, because it fails. I will fix the bug and enable the test in a later commit.
When TripTimes are added to the trip, it trip times are also added to the "local list of trips" - witch is a aggregated temporary list, this has of cause no effect.
When TripTimes are added to the trip, it trip times are also added to the "local list of trips" - witch is a aggregated temporary list, this has of cause no effect.
@t2gran t2gran force-pushed the otp2_not_allowed_transfers branch from ca028ac to 02e1dcb Compare December 20, 2021 14:35
@t2gran t2gran marked this pull request as ready for review December 20, 2021 14:36
@t2gran t2gran requested a review from a team as a code owner December 20, 2021 14:36
Copy link
Member

@leonardehrenfried leonardehrenfried 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 made a few comments about names.

@leonardehrenfried
Copy link
Member

leonardehrenfried commented Dec 21, 2021

I ran this with the GTFS Flex example feed and there I saw a NPE when starting up OTP:

11:17:28.093 ERROR (OTPMain.java:59) An uncaught error occurred inside OTP: null
java.lang.NullPointerException: null
	at org.opentripplanner.routing.algorithm.raptor.transit.constrainedtransfer.TransferIndexGenerator.findTPoints(TransferIndexGenerator.java:134)
	at org.opentripplanner.routing.algorithm.raptor.transit.constrainedtransfer.TransferIndexGenerator.findTPoints(TransferIndexGenerator.java:101)
	at org.opentripplanner.routing.algorithm.raptor.transit.constrainedtransfer.TransferIndexGenerator.generateTransfers(TransferIndexGenerator.java:53)
	at org.opentripplanner.routing.algorithm.raptor.transit.mappers.TransitLayerMapper.map(TransitLayerMapper.java:84)
	at org.opentripplanner.routing.algorithm.raptor.transit.mappers.TransitLayerMapper.map(TransitLayerMapper.java:56)
	at org.opentripplanner.standalone.server.Router.startup(Router.java:92)
	at org.opentripplanner.standalone.OTPMain.startOTPServer(OTPMain.java:167)
	at org.opentripplanner.standalone.OTPMain.main(OTPMain.java:52)

So it seems that you can have a stop with which doesn't have a pattern.

@t2gran t2gran marked this pull request as draft January 6, 2022 14:38
t2gran added 2 commits January 7, 2022 16:44
The StopPattern improve the memory footprint allowing multiple
TripPatterns using the same sequence of stops to ref the same
StopPattern.

review: Get approval for API change in DigitransitStopPropertyMapper
- The Transfer report is improved
- OTP serialization version id incremented
@t2gran t2gran force-pushed the otp2_not_allowed_transfers branch from a956fcf to 1390922 Compare January 11, 2022 14:01
@t2gran t2gran marked this pull request as ready for review January 11, 2022 14:02
t2gran and others added 3 commits January 13, 2022 11:23
Co-authored-by: Leonard Ehrenfried <[email protected]>
  - refactor: Remove unused code in TransferMapper
  - refactor: Rename applyToAllTrips to appliesToAllTrips
@t2gran t2gran requested a review from hannesj January 13, 2022 14:31
@leonardehrenfried
Copy link
Member

I'm going to turn off the codecov bot.

@leonardehrenfried
Copy link
Member

I've committed the configuration file directly to dev-2.x. If you merge again, the codecov bot will disappear.

@leonardehrenfried
Copy link
Member

leonardehrenfried commented Jan 21, 2022

I tested the not-allowed-transfers part of this PR and it does exactly what it's supposed to do.

Regular Boston feed

Screenshot from 2022-01-21 14-50-50

Modified Boston feed where with a not-allowed-transfer at the previous transfer stop

Screenshot from 2022-01-21 14-50-54

This leads to a transfer to a different stop. 👍

@t2gran t2gran force-pushed the otp2_not_allowed_transfers branch from 5ccb134 to 1e82238 Compare January 26, 2022 14:18
…sfers

# Conflicts:
#	src/main/java/org/opentripplanner/routing/stoptimes/StopTimesHelper.java
#	src/test/java/org/opentripplanner/routing/algorithm/mapping/__snapshots__/TransitSnapshotTest.snap
@t2gran t2gran merged commit 540df18 into opentripplanner:dev-2.x Jan 26, 2022
@t2gran t2gran deleted the otp2_not_allowed_transfers branch January 26, 2022 18:23
t2gran pushed a commit that referenced this pull request Jan 26, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
New Feature Regression This feature is no longer working.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants