Skip to content

Commit

Permalink
Revert "Revert "NYS-168 second attempt at limited out-of-system trans…
Browse files Browse the repository at this point in the history
…fers""

This reverts commit 0e490b5.
  • Loading branch information
mbsalvatore committed Jan 2, 2024
1 parent 0e490b5 commit d3df8ec
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 5 deletions.
11 changes: 6 additions & 5 deletions src/main/java/org/opentripplanner/routing/core/State.java
Original file line number Diff line number Diff line change
@@ -1,10 +1,8 @@
package org.opentripplanner.routing.core;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Date;
import java.util.Objects;
import java.util.Set;
import java.util.*;

import org.opentripplanner.model.Station;
import org.opentripplanner.routing.algorithm.astar.NegativeWeightException;
import org.opentripplanner.routing.api.request.RoutingRequest;
import org.opentripplanner.routing.edgetype.StreetEdge;
Expand Down Expand Up @@ -40,6 +38,9 @@ public class State implements Cloneable {
// we should DEFINITELY rename this variable and the associated methods.
public double walkDistance;

// keep track of transit stations entered to prevent out-of-system transfers
public List<Station> transitStationList = new ArrayList();

/* CONSTRUCTORS */

/**
Expand Down
14 changes: 14 additions & 0 deletions src/main/java/org/opentripplanner/routing/core/StateEditor.java
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
package org.opentripplanner.routing.core;

import org.opentripplanner.model.Station;
import org.opentripplanner.routing.graph.Edge;
import org.opentripplanner.routing.graph.Vertex;
import org.opentripplanner.routing.api.request.RoutingRequest;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.Collections;
import java.util.Set;

/**
Expand Down Expand Up @@ -393,4 +395,16 @@ public void setBikeRentalNetwork(Set<String> networks) {
public State getBackState() {
return child.getBackState();
}

// record that station was entered
public void markTransitStation(Station station) {
if (station != null)
child.transitStationList.add(station);
}

// how many stations have been entered
public Set<Station> getTransitStationsEntered() {
return Set.copyOf(child.transitStationList);
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,16 @@ else if (s0.isBikeRentingFromStation() && !(s0.mayKeepRentedBicycleAtDestination
int streetToStopTime = getStreetToStopTime();
s1.incrementTimeInSeconds(streetToStopTime);
s1.incrementWeight(STEL_TRAVERSE_COST + streetToStopTime);
if (this instanceof StreetTransitEntranceLink) {
// if we are entering transit mark it, but allow us to leave!
if (isLeavingStreetNetwork(req)) {
if (s1.getTransitStationsEntered().size() > 1) {
// ban this entrance, we've already taken an entrance
return null;
}
s1.markTransitStation(getTransitEntityVertex().getStationElement().getParentStation());
}
}
return s1.makeState();
}

Expand Down

0 comments on commit d3df8ec

Please sign in to comment.