prettygraph is a Python-based web application developed by @yoheinakajima to demonstrate a new UI pattern for text-to-knowledge graph generation. This project is a quick hack and not intended to be a robust framework, but a simple UI idea for dynamically highlighting the text input when generating knowledge graphs.
Original Documentation
prettygraph is a Python-based web application developed by @yoheinakajima to demonstrate a new UI pattern for text-to-knowledge graph generation. This project is a quick hack and not intended to be a robust framework, but a simple UI idea for dynamically highlighting the text input when generating knowledge graphs.
The application uses Flask for the backend, rendering templates for the front end, and LiteLLM for generating predictions which transform text inputs into JSON formatted graph data. This data is then visualized using Cytoscape.js. It's important to note that the graph regenerates on every period insertion with real-time updates in the UI, providing an interactive experience.
- Text-to-Graph Generation: Converts user input text into a knowledge graph.
- Dynamic UI Updates: Graph updates with each text input that ends with a period.
- Color-Coded Visualization: Nodes and edges in the graph are color-coded for better visual distinction.
This project uses Poetry for dependency management. To set up the project:
-
Clone the repository:
git clone https://github.com/yoheinakajima/prettygraph
-
Navigate to the project directory:
cd prettygraph
-
Install dependencies using Poetry:
poetry install
-
Run the Flask application:
poetry run python main.py
To run this application, you need to set up the OPENAI_API_KEY
environment variable. Create a file named .env
in the root directory of your project and add the following line:
OPENAI_API_KEY=your_openai_api_key_here
Once the application is running and the environment variables are set, open your web browser and navigate to http://localhost/
. Input text into the editable text box, and watch as the knowledge graph updates with each sentence termination (period).
- Improved Tracking: Enhance the logic for tracking nodes and edges through their flow in the text, moving away from simple keyword matching to a more sophisticated relationship mapping.
- Manual Graph Update: Introduce a manual update button to generate the graph as needed, reducing computational load and API costs.
- Loading Animation: Add a loading animation during graph generation to improve user experience by indicating processing is underway.
- Incremental Graph Building: Instead of regenerating the entire graph with each input, modify the existing graph by adding new elements and deduplicating nodes similarly to mindgraph.
While prettygraph is not intended to be maintained as a robust framework, contributions are welcome. Feel free to fork the repository and submit pull requests.
This project is open-sourced under the MIT License. See the LICENSE file for more details.
For those interested in exploring more about knowledge graphs:
- InstaGraph - Web-based tool for generating knowledge graphs. Or for a web UI, try out instagraph.ai - has knowledge graph generation but not the color coded highlights.
- mindgraph - For generating large knowledge graphs with deduping of nodes using an LLM as new graphs are added.
This is an experimental project and may not handle all edge cases or inputs effectively.
- got rid of poetry (I prefer
uv
->setuptools_scm
etc) - use
marvin
instead oflite-llm
(disclaimer: I'm the co-author ofmarvin
) flask
->fastapi
(I preferfastapi
overflask
) andlogfire
has out-of-the-box support forfastapi
- add
logfire
for logging / tracing
gh repo clone zzstoatzz/prettygraph
cd prettygraph
uv venv
source .venv/bin/activate
uv pip install . -U
uvicorn main:app --reload