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

Prefer to avoid sidewalks? #123

Open
graue opened this issue May 15, 2023 · 2 comments
Open

Prefer to avoid sidewalks? #123

graue opened this issue May 15, 2023 · 2 comments
Assignees

Comments

@graue
Copy link

graue commented May 15, 2023

While debugging a different thing, I got this route that says to cut the corner going on the sidewalk while turning from westbound Market right onto northbound Battery:

image

This is easy enough to ignore visually but makes the written itinerary confusing ("Turn right" and "Turn left" onto... nothing).

Factors that seem responsible for this:

  1. This lane of Market Street appears to curve away from Battery making it a longer distance but this is just an artifact of it being mapped as a separate OSM way to go around the transit boarding island.
  2. Market is a highway=tertiary which is AVOID
  3. The way is, at the time of writing, only tagged cycleway:right=shared_lane (and not bicycle=designated), and the router currently ignores cycleway:right when assigning penalties, which would otherwise mitigate the highway=tertiary penalty never mind, this wasn't true
  4. We don't avoid footways at all and assign a relatively high speed of 14 vs 18 for most streets

Don't think there's any action to take about factors 1 and 2, and I'm separately working on a chance to address factor 3. But why aren't footways discouraged and treated as requiring going slow?

@rsarathy rsarathy self-assigned this May 25, 2024
@graue
Copy link
Author

graue commented May 25, 2024

Re-reading the code, I think my point 4 above was wrong, because getSpeed() seems to be overriding the speed of 14 for footways, lowering it to PUSHING_SECTION_SPEED (4) unless the footway has a tag such as bicycle=yes, bicycle=designated, etc. (In fact, if it does have bicycle=yes etc., the code is also overriding that, but to a higher value. That value of 14 seems to never get used.)

So in my example above (where the sidewalk does not have tags such as bicycle=yes) it's being treated as 4.5x slower (18/4) because it's a sidewalk, and is being preferred anyway. This means that the artifact of the Market Street bike lane curving slightly away isn't enough to explain it, and some other weird thing is going on here, maybe bad elevation data again.

@rsarathy
Copy link

In this particular case, bad elevation data is solely responsible for the turn onto the pair of sidewalks. Bikehopper thinks that the little diagonal Market St segment in your image has an elevation gain of ~30m, giving it the steepest grade possible. This results in our encoder jacking up the penalty from 1.0 to 12.0.

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

No branches or pull requests

2 participants