Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/patrickpang/geeder
Create Anki cards from textbook excerpt using LLM
https://github.com/patrickpang/geeder
anki dominate fastapi groq htmx llm python tailwind
Last synced: 22 days ago
JSON representation
Create Anki cards from textbook excerpt using LLM
- Host: GitHub
- URL: https://github.com/patrickpang/geeder
- Owner: patrickpang
- Created: 2024-05-01T02:53:02.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-11-29T13:54:09.000Z (about 1 month ago)
- Last Synced: 2024-11-29T14:43:54.664Z (about 1 month ago)
- Topics: anki, dominate, fastapi, groq, htmx, llm, python, tailwind
- Language: Python
- Homepage:
- Size: 717 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Geeder
![Screenshot](https://github.com/patrickpang/geeder/assets/944420/d0172fd2-bbff-499b-b4e6-4fcaff5c3680)
## Motivation
You are reading a textbook for revision. You have an exam coming up. What would you do?
Anki! Of course it is great to have some flashcards to remember important facts. However, creating Anki cards alongside reading isn't smooth. You often have to switch context and think about what cards to create.
Try Geeder. We use LLM (Groq for its low latency LPU) to create Anki cards, and add to your existing Anki decks. Copy a section from the textbook, paste into Geeder, and your new cards are just one button away!
## Installation
1. Download from [GitHub Releases](https://github.com/patrickpang/geeder/releases). Currently only macOS app bundle is available for download.
2. Obtain an API token from [Groq](https://console.groq.com/) and persist it as environment variable `GROQ_API_KEY`. Using macOS as example:
```bash
$ cat ~/.zprofile
export GROQ_API_KEY=
```
3. Extract the archive and launch the app. Profit!## Web
The web tech stack is a simple server-side rendered architecture:
* [FastAPI](https://fastapi.tiangolo.com/): types-first web framework with great async performance
* [Htmx](https://htmx.org/): declarative client side interactivity without JavaScript
* [Dominate](https://pypi.org/project/dominate/): HTML templating using Python functions
* [Tailwind](https://tailwindcss.com/): utilty-first CSS framework that makes inline CSS enjoyablePython is used to develop the prototype of this app in Jupyter Notebook, so most of the code is adapted for the web app.
This web app is designed to be local first, because integration with Anki via localhost is on the roadmap.
## LLM
The [prompt](https://github.com/patrickpang/geeder/blob/main/llm.py#L14) we use is relatively simple. ndjson has been chosen as the output format instead of plaintext or JSON, because experiments show that LLMs perform better in this particular setting. We also intend to parse the output and create Anki cards directly via AnkiConnect, so a structured output is preferred. Function calling in Groq is in beta and we intend to explore that in the future also.
### Groq
We use Groq for LLM inference API instead of OpenAPI / Claude / Gemini for its low latency response over custom-built LPU. The task is essentially relatively simple - text summarization and structured output. No deep domain knowledge or Internet browsing is required.
### Llama 3.1
Llama 3.1 is the state-of-the-art open source LLM as of 2024 Sep, and we chose the 70b model as experiments showed less hallucination compared to 8b model.
## Develop
VS Code is recommended for development, and we have devcontainer set up. To launch the dev server, find the corresponding task in VS Code.
## CI/CD
GitHub Actions is used for CI/CD. We mainly rely on Nuitka to build release bundle as it produces the small executable with static compilation. To mitigate the slow compilation speed for development and potential incompatibility, we also have a PyInstaller setup.