Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lfnovo/open-notebook
An Open Source implementation of Notebook LM with more flexibility and features
https://github.com/lfnovo/open-notebook
assistant learning note-taking notebook notes-app self-learning
Last synced: 6 days ago
JSON representation
An Open Source implementation of Notebook LM with more flexibility and features
- Host: GitHub
- URL: https://github.com/lfnovo/open-notebook
- Owner: lfnovo
- License: mit
- Created: 2024-10-21T17:58:46.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2024-11-20T16:02:49.000Z (about 2 months ago)
- Last Synced: 2025-01-02T04:07:22.775Z (13 days ago)
- Topics: assistant, learning, note-taking, notebook, notes-app, self-learning
- Language: Python
- Homepage: https://www.open-notebook.ai
- Size: 4.36 MB
- Stars: 806
- Watchers: 9
- Forks: 45
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- StarryDivineSky - lfnovo/open-notebook
README
[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]
[![MIT License][license-shield]][license-url]
Open Notebook
An open source, privacy-focused alternative to Google's Notebook LM!
Checkout our website Β»
Get Started (Setup)
Β·
Features
## π’ Open Notebook is under very active development
> Open Notebook is under active development! We're moving fast and making improvements every week. Your feedback is incredibly valuable to me during this exciting phase and it gives me motivation to keep improving and building this amazing tool. Please feel free to star the project if you find it useful, and don't hesitate to reach out with any questions or suggestions. I'm excited to see how you'll use it and what ideas you'll bring to the project! Let's build something amazing together! π
>
> β οΈ **API Changes**: As we optimize and enhance the project, some APIs and interfaces might change. We'll do our best to document these changes and minimize disruption.
>
> π **We Need Your Feedback**: Please try out Open Notebook and let us know what you think! Submit issues, feature requests, or just share your experience through:
> - GitHub Issues
> - Discussions
> - Pull Requests
>
> Together, we can make it even better!Table of Contents
## About The Project
![New Notebook](docs/assets/asset_list.png)
An open source, privacy-focused alternative to Google's Notebook LM. Why give Google more of our data when we can take control of our own research workflows?
In a world dominated by Artificial Intelligence, having the ability to think π§ and acquire new knowledge π‘, is a skill that should not be a privilege for a few, nor restricted to a single provider.
Open Notebook empowers you to manage your research, generate AI-assisted notes, and interact with your contentβon your terms.
Learn more about our project at [https://www.open-notebook.ai](https://www.open-notebook.ai)
### Built With
[![Python][Python]][Python-url] [![SurrealDB][SurrealDB]][SurrealDB-url] [![LangChain][LangChain]][LangChain-url] [![Streamlit][Streamlit]][Streamlit-url]
## βοΈ Setting Up
Go to the [Setup Guide](docs/SETUP.md) to learn how to set up the tool in details.
You don't need to clone this repo if you just want to use the app without building from source!
Take a look at the [Open Notebook Boilerplate](https://github.com/lfnovo/open-notebook-boilerplate) repo with a sample of how to set it up for maximum feature usability.### Running from source
Start by cloning this repo and cd into it.
```bash
git clone https://github.com/lfnovo/open-notebook
cd open-notebook
```Rename `.env.example` into `.env` and set up your API keys.
Also, repeat the process for `docker.env` if you plan to run this using docker.```bash
cp .env.example .env
cp .env.example docker.env
```Edit .env for your API keys.
To run the source code locally and experiment with the code, you just need to run:
```bash
poetry install
docker compose --profile db_only up
poetry run streamlit run app_home.py
```If you don't want to mess around with the code and just want to run it as a docker image:
```bash
docker compose --profile multi up
```## Usage
Go to the [Usage](docs/USAGE.md) page to learn how to use all features.
## Features
- **Multi-Notebook Support**: Organize your research across multiple notebooks effortlessly.
- **Multi-model support**: Open AI, Anthropic, Gemini, Vertex AI, Open Router, Ollama.
- **Podcast Generator**: Automatically convert your notes into a podcast format.
- **Broad Content Integration**: Works with links, PDFs, EPUB, Office, TXT, Markdown files, YouTube videos, Audio files, Video files and pasted text.
- **AI-Powered Notes**: Write notes yourself or let the AI assist you in generating insights.
- **Integrated Search Engines**: Built-in full-text and vector search for faster information retrieval.
- **Fine-Grained Context Management**: Choose exactly what to share with the AI to maintain control.## π New Features
### v0.1 - Release Candidate
- Better citations and improved search capabilities
- The "Ask" feature is much smarter now and let's you check its thinking
- Enabled support for X.AI and Groq models
- Select default transformations to apply to all content
- Save insights as custom notes
- Items are added to context by default### v0.0.10 - Gemini podcast model
- Added the Gemini model for generating much more fluid and engaging podcasts
### v0.0.9 - Ask your Documents and Citations β
- Ask questions about your documents and get answers with citations
### v0.0.7 - Model Management ποΈ
- Manage your AI models and providers in a single interface
- Define default models for several tasks such as chat, transformation, embedding, etc
- Enabled support for Embedding models from Gemini, Vertex and Ollama### v0.0.6 - ePub and Office files support π
You can now process ePub and Office files (Word, Excel, PowerPoint), extracting text and insights from them. Perfect for books, reports, presentations, and more.
### v0.0.5 - Audio and Video support π½οΈ
You can now process audio and video files, extracting transcripts and insights from them. Perfect for podcasts, interviews, lectures, and more.
### v0.0.4 - Podcasts ποΈ
You can now build amazing custom podcasts based on your own data. Customize your speakers, episode structure, cadence, voices, etc.
Check out a sample using my own voice created on Eleven Labs and a interview format.
[![Check out our podcast sample](https://img.youtube.com/vi/D-760MlGwaI/0.jpg)](https://www.youtube.com/watch?v=D-760MlGwaI)
You can generate your podcast in dozens of languages.
Head to the [Podcasts](docs/PODCASTS.md) page for more info
### v0.0.3 - Transformations β¨
We just release a much more powerful way to create more value from your sources.
Transformations enable you do extract an unlimited amount of insights from your content.
It's 100% customizable and you can extend it to your own needs, like Paper Analysis, Article Writing, etc.Head to the [Transformations](docs/TRANSFORMATIONS.md) page for more info
### v0.0.2 - Several new providers are supported now:
- OpenAI
- Anthropic
- Open Router
- LiteLLM
- Vertex AI
- Ollama### π Notebook Page
Three intuitive columns to streamline your work:
1. **Sources**: Manage all research materials.
2. **Notes**: Create or AI-generate notes.
3. **Chat**: Chat with the AI, leveraging your content.### βοΈ Context Configuration
Take control of your data. Decide what gets sent to the AI with three context options:
- No context
- Summary only
- Full contentPlus, you can add your project description to help the AI provide more accurate and helpful responses.
### π Integrated Search for Your Items
Locate anything across your research with ease using full-text and vector-based search.
### π¬ Powerful open prompts
Jinja based prompts that are easy to customize to your own preferences.
## Roadmap
- [ ] **Live Front-End Updates**: Real-time UI updates for a smoother experience.
- [ ] **Async Processing**: Faster UI through asynchronous content processing.
- [ ] **Cross-Notebook Sources and Notes**: Reuse research notes across projects.
- [ ] **Bookmark Integration**: Integrate with your favorite bookmarking app.
- β **Multi-model support**: Open AI, Anthropic, Vertex AI, Open Router, Ollama, etc.
- β **Insight Generation**: New tools for creating insights - [transformations](docs/TRANSFORMATIONS.md)
- β **Podcast Generator**: Automatically convert your notes into a podcast format.
- β **Multiple Chat Sessions**: Juggle different discussions within the same notebook.
- β **Enhanced Citations**: Improved layout and finer control for citations.
- β **Better Embeddings & Summarization**: Smarter ways to distill information.See the [open issues](https://github.com/lfnovo/open-notebook/issues) for a full list of proposed features (and known issues).
## Contributing
We would love your contributions! Specifically, we're looking for help with:
- **Front-End Development**: Improve the UI/UX by moving beyond Streamlit.
- **Testing & Bug Fixes**: Help make Open Notebook more robust.
- **Feature Development**: Letβs make the coolest note-taking tool together!See more at [CONTRIBUTING](CONTRIBUTING.md)
## License
Open Notebook is MIT licensed. See the [LICENSE](LICENSE) file for details.
## Contact
Luis Novo - [@lfnovo](https://twitter.com/lfnovo)
## Acknowledgments
This project uses some amazing third-party libraries
* [Podcastfy](https://github.com/souzatharsis/podcastfy) - Licensed under the Apache License 2.0
[contributors-shield]: https://img.shields.io/github/contributors/lfnovo/open-notebook.svg?style=for-the-badge
[contributors-url]: https://github.com/lfnovo/open-notebook/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/lfnovo/open-notebook.svg?style=for-the-badge
[forks-url]: https://github.com/lfnovo/open-notebook/network/members
[stars-shield]: https://img.shields.io/github/stars/lfnovo/open-notebook.svg?style=for-the-badge
[stars-url]: https://github.com/lfnovo/open-notebook/stargazers
[issues-shield]: https://img.shields.io/github/issues/lfnovo/open-notebook.svg?style=for-the-badge
[issues-url]: https://github.com/lfnovo/open-notebook/issues
[license-shield]: https://img.shields.io/github/license/lfnovo/open-notebook.svg?style=for-the-badge
[license-url]: https://github.com/lfnovo/open-notebook/blob/master/LICENSE.txt
[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?style=for-the-badge&logo=linkedin&colorB=555
[linkedin-url]: https://linkedin.com/in/lfnovo
[product-screenshot]: images/screenshot.png
[Streamlit]: https://img.shields.io/badge/Streamlit-FF4B4B?style=for-the-badge&logo=streamlit&logoColor=white
[Streamlit-url]: https://streamlit.io/
[Python]: https://img.shields.io/badge/Python-3776AB?style=for-the-badge&logo=python&logoColor=white
[Python-url]: https://www.python.org/
[LangChain]: https://img.shields.io/badge/LangChain-3A3A3A?style=for-the-badge&logo=chainlink&logoColor=white
[LangChain-url]: https://www.langchain.com/
[SurrealDB]: https://img.shields.io/badge/SurrealDB-FF5E00?style=for-the-badge&logo=databricks&logoColor=white
[SurrealDB-url]: https://surrealdb.com/