kilian bfc0c9adae
Some checks failed
Build and deploy the backend to staging / Build and push image (pull_request) Failing after 59s
Build and deploy the backend to staging / Deploy to staging (pull_request) Has been skipped
Run linting on the backend code / Build (pull_request) Successful in 2m7s
Run testing on the backend code / Build (pull_request) Failing after 56s
added the option to enable/disable the cluster search in get-nearby endpoint
2025-10-19 22:05:43 +02:00
2025-07-27 18:32:24 +02:00
2024-06-04 00:20:54 +02:00
2024-09-10 10:12:53 +02:00
2025-02-11 08:25:02 +00:00
2025-01-23 17:57:17 +01:00
2025-02-18 18:24:04 +01:00

AnyWay - plan city trips your way

AnyWay is a mobile application that helps users plan city trips. The app allows users to specify their preferences and constraints, and then generates a personalized itinerary for them. The planning follows some guiding principles:

  • Personalization:The user's preferences should be reflected in the choice of destinations.
  • Efficiency:The itinerary should be optimized for the user's constraints.
  • Flexibility: We aknowledge that tourism is a dynamic activity, and that users may want to change their plans on the go.
  • Discoverability: Tourism is an inherently exploratory activity. Once a rough itinerary is generated, detours and spontaneous decisions should be encouraged.

Architecture

This project is divided into two main components: a frontend and a backend. The frontend is a Flutter application that runs on Android and iOS. The backend is a python server that runs on a cloud provider. The two components communicate via a REST API. Since both components are very interdependent and share many data structures, we opted for a monorepo approach.

Frontend

See the frontend README for more information. The application is centered around its map view, which displays the user's itinerary. This is based on the Google Maps API.

Backend

See the backend README for more information. The backend is responsible for generating the itinerary based on the user's preferences and constraints. Rather than using google maps, we use the OpenStreetMap database through the Overpass API, which is much more flexible.

Getting Started

Refer to the READMEs in the frontend and backend directories for instructions on how to run the application locally. Notable prerequisites include:

  • Flutter SDK
    • google_maps_flutter plugin
  • Python 3
    • fastapi
    • numpy
    • pydantic
  • Docker

Releases

The project is still in its early stages. We are currently working on a prototype that demonstrates the core functionality of the application.

Official releases will be made available on the Google Play Store and the Apple App Store.

Roadmap

See the project board:

Description
No description provided
Readme 38 MiB
Languages
Python 44.7%
Dart 27.9%
HTML 20.9%
CMake 2.7%
Ruby 1.7%
Other 2.1%