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

Incorporate LTN edits into map_model #1079

Open
dabreegster opened this issue Apr 10, 2023 · 2 comments
Open

Incorporate LTN edits into map_model #1079

dabreegster opened this issue Apr 10, 2023 · 2 comments

Comments

@dabreegster
Copy link
Collaborator

#995 is about referring to roads, intersections, turns, etc using geometry and robustly handling upstream OSM changes. While thinking through how to make this change just for the LTN tool, I've been revisiting why the LTN proposal save file is different from the older map_model::MapEdits format. Another problem with the LTN savefile is that it currently writes all existing filters. We want a command-based approach to sanely handle undo/redo, reduce the size of the savefiles, and handle upstream changes to existing filters. That command-based approach already exists. I started LTN savefiles as something different from MapEdits in the beginning to iterate rapidly on unknown requirements, but now it's time to go back and make the formats / representations be the same.

So the change:

  • Lift LTN concepts into map_model
    • Filters and crossings are optional (type, distance) tuples on a Road
    • Diagonal filters are optional on an Intersection
  • Make new EditCmds to modify these things
    • Following the current approach, this'll probably be a blunt "set filters on road 123 to X" rather than a more granular "delete filter X", "add filter Y"
  • Possibly move the LTN tool's "transform existing filters" step into the importer pipeline
    • But maybe not yet. This would affect the other A/B Street apps; they'd need to understand filters for rendering, pathfinding, A/B Street's detailed road editor mode, etc. Since that's a bigger step, maybe don't do this yet.

This won't quite let us replace the LTN savefile with the classic PermanentMapEdits just yet, because of boundaries / partitioning. I also want to stop saving all neighbourhood boundaries and only represent edits. But this is trickier, and I think first requires a big user-visible change to boundary management. More on that later.

This change is orthogonal to #995, and could be done in either order. But both together will be great, also because it opens the way for other people to produce and consume A/B Street edit files, without needing to understand a bunch of weird internal implementation details.

Alternative considered: reinvent map edits from scratch in the LTN crate

Since we're also switching to GeoJSON output and using geometry to ID things, I thought about starting from scratch with map edits for the LTN tool. But this'd wind up reinventing lots of logic that's already working fine in MapEdits, like compacting changes and efficiently applying a diff.

Alternative considered: base map edits v2 on top of osm2streets instead of map_model

osm2streets in many ways has been acting as a v2 of map_model, so maybe all these new ideas for map edits should be implemented there. Eventually I do want the concept of edits to live there, but not yet -- too huge a step. The LTN tool can't just rely on osm2streets today, because it needs areas, buildings, and file loading from map_model. #1041 would maybe be some intermediate step here, but it's not important yet.

@dabreegster
Copy link
Collaborator Author

In-progress at https://github.com/a-b-street/abstreet/tree/ltn_map_edits. High confidence I can finish this with another uninterrupted day of work!

dabreegster added a commit that referenced this issue May 1, 2023
…r the LTN tool. #1079

1) Merge intersection control and crosswalk edits into a larger intersection edit command.

2) Use FnOnce for edit_*_cmd, so we don't have to clone for no reason

3) Get rid of the old merge_zones hack

4) Track the original road state instead of changed roads, to be
   consistent with intersections

These are breaking changes to the map edit format, without any backwards
compatibility built-in. I'm giving up on that for now.
dabreegster added a commit that referenced this issue May 1, 2023
1) Move a bunch of types into map_model, adding them to the edit
  commands (in a totally backwards incompatible way)

2) Rip out the ad-hoc proposal and undo system in the LTN tool, and just
   use MapEdits
dabreegster added a commit that referenced this issue May 1, 2023
1) Move a bunch of types into map_model, adding them to the edit
  commands (in a totally backwards incompatible way)

2) Rip out the ad-hoc proposal and undo system in the LTN tool, and just
   use MapEdits
@dabreegster
Copy link
Collaborator Author

dabreegster commented May 1, 2023

  • Check performance of map edits. (Resnapping buildings constantly is probably bad)
  • The overall UX of saving / file management is still weird. Autosave would match user expectations much better and not be hard...
  • The assigned proposal name is very strange, especially when forking a new proposal. (Note that new_edits can't generate unique ones -- different directory!)
  • When we try to auto-filter an area, we no longer cancel empty edits
  • We no longer batch together a bunch of filters added at once with freehand. Undo gets chunky/weird.

dabreegster added a commit that referenced this issue May 1, 2023
1) Move a bunch of types into map_model, adding them to the edit
  commands (in a totally backwards incompatible way)

2) Rip out the ad-hoc proposal and undo system in the LTN tool, and just
   use MapEdits
dabreegster added a commit that referenced this issue May 2, 2023
… snapping step when lane config doesn't change. #1079
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

1 participant