Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/extrawest/movies-ai-search-demo

LangChain4j Neo4j Graph RAG - Movies Search Demo. An AI-powered movie database application built with Java 21, Spring Boot 3.3.3, and Neo4j. The app uses LangChain4j to enable natural language queries, providing personalized recommendations, interactive graph visualizations, and dynamic data exploration.
https://github.com/extrawest/movies-ai-search-demo

ai graph java21 langchain4j maven neo4j rag spring spring-boot togetherai

Last synced: about 1 month ago
JSON representation

LangChain4j Neo4j Graph RAG - Movies Search Demo. An AI-powered movie database application built with Java 21, Spring Boot 3.3.3, and Neo4j. The app uses LangChain4j to enable natural language queries, providing personalized recommendations, interactive graph visualizations, and dynamic data exploration.

Awesome Lists containing this project

README

        

# LangChain4j Neo4j Graph RAG - Movies Search Demo

[![Maintenance](https://img.shields.io/badge/Maintained%3F-yes-green.svg)]()
[![Maintainer](https://img.shields.io/static/v1?label=Yevhen%20Ruban&message=Maintainer&color=red)](mailto:[email protected])
[![Ask Me Anything !](https://img.shields.io/badge/Ask%20me-anything-1abc9c.svg)]()
[![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
![GitHub release](https://img.shields.io/badge/release-v1.0.0-blue)

An AI-powered movie database application built with Java 21, Spring Boot 3.3.3, and Neo4j. The app uses LangChain4j to enable natural language queries, providing personalized recommendations, interactive graph visualizations, and dynamic data exploration. Users can effortlessly explore movies, actors, genres, and directors. Featuring scalable architecture and robust security, the platform delivers a seamless, personalized, and engaging movie discovery experience.

https://github.com/user-attachments/assets/f573f19c-702b-470f-97b6-82f5490a2eaa

1. Query example:
```bash
MATCH p=()-[:IN_GENRE]->() RETURN p LIMIT 25;
```
Output:
![visualisation (2)](https://github.com/user-attachments/assets/877fd8c3-f490-4398-aff7-f2639e0dbd64)

## Key Features
- **Natural Language Query Support**: Leverage LangChain4j to allow users to ask movie-related questions in plain language, translating them into Cypher queries for Neo4j.
- **AI-Powered Recommendations**: Provide personalized movie, actor, and genre recommendations based on user queries, search history, and preferences.
- **Interactive Graph Visualizations**: Showcase relationships between movies, actors, directors, and genres using Neo4j's graph data in an intuitive and interactive format.
- **LangChain4j-Powered Insights**: Leverage LangChain4j for natural language understanding and effective query handling, ensuring accurate and contextually relevant responses.
- **TogetherAI Integration**: Facilitate smooth and intelligent agent interactions using TogetherAI for a cohesive user experience.
- **Spring Boot Scalability**: Built on Spring Boot 3.3.3, ensuring a reliable and scalable backend architecture for seamless performance.
- **Dynamic Search and Recommendations**: Allow users to search for movies, actors, genres, or directors and receive personalized recommendations based on search results or user preferences.

## Tech Stack

- **Java 21**
- **SpringBoot 3.3.3**: Backend framework for building fast and scalable applications.
- **Together AI**: Provides models for describe image. Model: meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo
- **Langchain4j**: Supercharge your Java application with the power of LLMs.

## Running On Local Machine (Linux):

1. Set up the following environment variables.
- export TOGETHER_AI_API_KEY=your_api_key;
- export NEO4J_URI=your_neo4j_uri;
- export NEO4J_PASSWORD=your_neo4j_password;
2. Run the command: mvn exec:java -Dspring.profiles.active=local
3. Open the following link in your browser: http://localhost:8208/api/swagger-ui/index.html#/

## Contributing

Feel free to open issues or submit pull requests to improve the project. Contributions are welcome!