Skip to content

benheckmann/ai-powered-holiday-search

Repository files navigation

Check24 GenDev Challenge Submission: UrlaubGPT - Your AI Assisted Holiday Planner 🤖🌊

Screen Recording

Screen Recording GIF The screen recording as HD video is available on Google Drive.

Introduction

In this README, I will explain my concept, approach, the design choices I made and the optimizations I've implemented. I'll also discuss my ideas for future enhancements.

Core Idea

With the current development of large language models (LLMs), the way we interact with digital systems will drastically evolve. With this in mind, I have designed UrlaubGPT, a travel platform integrated with an AI travel agent, aiming to merge human-like interactions with the common controls of modern travel platform. The platform leverages ChatGPT to handle text input, making search input not only more flexible but also interactive.

User Experience

The user interface of UrlaubGPT is designed to be minimal yet powerful. The landing page of the platform presents a single search bar, which invites the user to input their holiday preferences in a conversational manner. The user might type in something like: "A kitesurf holiday in Europe with my children," or "A trip to Mallorca with my wife anytime in September." The LLM then interprets this input, auto-adjusting the search filters on the portal, and responds to the user by providing additional destination suggestions, asking follow-up questions, and so on. The user is then directed to the results page, where they can either adjust the filters manually or chat with the AI for more tips and to refine their search. The chat window can be hidden to allow a full-screen view of the results.

Design

Inspired by Check24's corporate design, UrlaubGPT's design emphasizes simple, functional aesthetics. The platform uses square offer cards to prioritize images, providing visual appeal and enabling more offers to be displayed simultaneously.

Tech Stack

UrlaubGPT is built with a robust and modern tech stack, aiming for speed of development, efficiency, and scalability: Architecture Diagram

  • Database: Azure MySQL: A fully managed relational database service, Azure MySQL provides a scalable database solution, ensuring secure data management. Its ability to handle large volumes of data and flexible scaling options make it ideal for the application.

  • Large Language Model: ChatGPT: ChatGPT is used as the underlying LLM for handling and interpreting user input. Using ChatGPT enabled quicker development times compared to hosting an open-source model, as it reduced the need for setup, fine-tuning, and maintenance.

  • Application: The application is built using the T3 Stack, comprising several modern technologies designed for optimal performance and development efficiency:

    • Next.js: A React-based framework for building scalable, high-performance web applications. Next.js provides powerful features like server-side rendering and static site generation, which help to optimize the performance and user experience of the application.
    • TypeScript: TypeScript, a statically-typed superset of JavaScript, allows me to write more reliable, maintainable code. The benefits of static typing, such as improved autocomplete, refactoring, and error-checking capabilities, have greatly contributed to the robustness of the codebase.
    • Prisma: Prisma is a simple, typesafe ORM (Object-Relational Mapping) tool that simplifies database access and manipulation. Prisma enables us to interact with the MySQL database using TypeScript, promoting better code maintainability and reducing the risk of runtime errors.
    • Tailwind CSS: A utility-first CSS framework that allows me to create custom designs with ease. Tailwind CSS greatly simplifies the process of writing CSS, making it easier to maintain a consistent design throughout the application.
    • tRPC: An RPC framework built for TypeScript developers, tRPC allows me to build and consume fully typesafe APIs without having to deal with schemas or code generation. It integrates well with Next.js and TypeScript, enabling me to create reliable and efficient data communication paths within the application.

Current Optimizations

Several optimizations have been implemented to enhance the system's performance and reliability:

  • Fallback mechanism for wrong LLM outputs: JSON responses are parsed and checked against the expected schema. In the case of a mismatch, the response is sent back to the LLM with the necessary schema for correction. If the LLM fails to generate a response that adheres to the schema again, a default error message is displayed to the user.
  • Database Indexing: Optimized database indexing ensures quick data retrieval, contributing to the application's overall responsiveness.
  • Session-based chat: User chat history is stored in a session (with the session id being stored in the browsers localStorage), maintaining chat persistence across page refreshes without requiring user accounts.
  • Split result pages: To optimize data loading, the results are divided across multiple pages, allowing efficient retrieval and display of database results.

Future Optimizations and Improvements

While the current system performs quite well, I have identified a number of potential improvements and optimizations for future development:

  • Introducing sorting options: Allowing users to sort search results based on their preferences would significantly improve the platform's usability.
  • Migrating to a fine-tuned version of an open-source LLM (such as Facebook's LLaMA) hosted with a German cloud provider. This would not only reduce costs but also improve data privacy in compliance with GDPR regulations.
  • Implementing a websocket connection between the server and client, enabling real-time streaming of LLM responses (i.e. the answer appears word by word) and enhancing the user's sense of interaction. The user would get to start reading the response right away and would not experience any waiting time (assuming that the LLM would output the words faster than the user reads).
  • Integrating the Google Maps API: This could allow more advanced, location-based queries such as "beach holidays within a 500 km radius".
  • Adding airport code mappings: Implementing a mapping system between city names and IATA codes to enable additional validity checks and enhance search accuracy.

How to Run the Project Locally

  1. Clone the repository:
git clone https://github.com/benheckmann/check24-gendev-challenge.git
  1. Add a .env file following .env.example in the root directory of the project.
cp .env.example .env

Replace the placeholders in .env with your MySQL connection string and OpenAI API key.

# Prisma
DATABASE_URL=mysql://USER:PASSWORD@HOST:PORT/DATABASE
# OpenAI
OPENAI_API_KEY=key
  1. Install dependencies & run the project:
yarn install
yarn dev

You can alternatively build & run the project's docker image (instead of step 2. & 3.):

docker build -t ct3a-docker --build-arg NEXT_PUBLIC_CLIENTVAR=clientvar .
docker run -p 3000:3000 -e DATABASE_URL="database_url_goes_here" -e OPENAI_API_KEY="key_goes_here" ct3a-docker
  1. Setup Database

Upload two tables into your MySQL database, one for the hotels, and one for the offers. The expected table names, column names and types are specified in the file schema.prisma (and follow the provided challenge data). Upload the two tables to match this schema and optionally change the table names in this file as well by modifying @@map("your_custom_table_name"). For reference, this is what you should get in the MySQL command line:

mysql> show columns from newoffers;
+---------------------------+--------------+------+-----+---------+----------------+
| Field                     | Type         | Null | Key | Default | Extra          |
+---------------------------+--------------+------+-----+---------+----------------+
| offerid                   | int(11)      | NO   | PRI | NULL    | auto_increment |
| hotelid                   | int(11)      | NO   | MUL | NULL    |                |
| outbounddeparturedatetime | datetime(3)  | NO   | MUL | NULL    |                |
| inbounddeparturedatetime  | datetime(3)  | NO   |     | NULL    |                |
| countadults               | int(11)      | NO   | MUL | NULL    |                |
| countchildren             | int(11)      | NO   | MUL | NULL    |                |
| price                     | float        | NO   | MUL | NULL    |                |
| inbounddepartureairport   | varchar(191) | NO   |     | NULL    |                |
| outboundarrivalairport    | varchar(191) | NO   | MUL | NULL    |                |
| inboundarrivaldatetime    | datetime(3)  | NO   | MUL | NULL    |                |
| outbounddepartureairport  | varchar(191) | NO   | MUL | NULL    |                |
| inboundarrivalairport     | varchar(191) | NO   | MUL | NULL    |                |
| outboundarrivaldatetime   | datetime(3)  | NO   |     | NULL    |                |
| mealtype                  | varchar(191) | NO   |     | NULL    |                |
| oceanview                 | varchar(191) | NO   |     | NULL    |                |
| roomtype                  | varchar(191) | NO   |     | NULL    |                |
+---------------------------+--------------+------+-----+---------+----------------+
16 rows in set (0.03 sec)

mysql> show columns from newhotels;
+------------+--------------+------+-----+---------+-------+
| Field      | Type         | Null | Key | Default | Extra |
+------------+--------------+------+-----+---------+-------+
| hotelid    | int(11)      | NO   | PRI | NULL    |       |
| hotelname  | varchar(191) | NO   |     | NULL    |       |
| hotelstars | int(11)      | NO   | MUL | NULL    |       |
+------------+--------------+------+-----+---------+-------+
3 rows in set (0.12 sec)

Conclusion

UrlaubGPT is an exploration of the AI's potential in the travel industry, demonstrating how language models can reinvigorate user interaction. It's a prototype that highlights a future where planning a holiday feels as simple as having a conversation. Though it may not fulfill all challenge requirements, it offers insights in the implementation and challenges and prompts us to consider AI as a significant component in the evolution of travel platforms.

I'm proud of what I've built and excited about the skills I've learned along the way. I hope you enjoy using UrlaubGPT as much as I enjoyed building it!

About

LLM-based Holiday Search Engine for the Check24's GenDev Challenge 2023.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published