No description
Find a file
2024-05-26 09:49:39 +02:00
.data Intermidiate commit 2024-04-24 19:35:36 +02:00
.dlt fix: remove obsolete code 2024-03-13 10:19:03 +01:00
.github fix db engine config 2024-05-25 20:17:43 +02:00
assets Added star history 2024-05-25 08:27:49 +02:00
bin Build the docker and push 2023-12-16 15:25:32 +01:00
cognee Updates to the configs 2024-05-26 09:49:39 +02:00
cognee-frontend feat: add llm config 2024-05-22 22:36:30 +02:00
docs Improve processing, update networkx client, and Neo4j, and dspy (#69) 2024-04-20 19:05:40 +02:00
evals add test for linter 2024-05-25 22:18:07 +02:00
notebooks feat: add initial cognee frontend 2024-05-17 13:42:14 +02:00
tests add test for linter 2024-05-25 22:15:28 +02:00
tools Cog 174 (#84) 2024-04-26 00:16:03 +02:00
.env.template chore: rename package in files 2024-03-13 16:27:07 +01:00
.gitignore feat: add llm config 2024-05-22 22:36:30 +02:00
.pylintrc feat: add create-memory and remember API endpoints 2024-02-25 23:56:50 +01:00
.python-version chore: update python version to 3.11 2024-03-29 14:10:20 +01:00
CONTRIBUTING.md Build the docker and push 2023-12-16 15:25:32 +01:00
docker-compose.yml feat: add llm config 2024-05-22 22:36:30 +02:00
Dockerfile Update docs 2024-03-17 15:36:30 +01:00
entrypoint.sh Update docs 2024-03-17 15:36:30 +01:00
LICENSE Update LICENSE 2024-03-30 11:57:07 +01:00
mkdocs.yml Improve processing, update networkx client, and Neo4j, and dspy (#69) 2024-04-20 19:05:40 +02:00
mypy.ini Improve processing, update networkx client, and Neo4j, and dspy (#69) 2024-04-20 19:05:40 +02:00
poetry.lock implement settings 2024-05-25 18:21:19 +02:00
pyproject.toml implement settings 2024-05-25 18:21:19 +02:00
pytest.ini Updates and fixes for the lib 2024-05-25 13:51:38 +02:00
README.md Added star history 2024-05-25 08:37:16 +02:00

cognee

Deterministic LLMs Outputs for AI Engineers using graphs, LLMs and vector retrieval

Cognee logo

Open-source framework for creating self-improving deterministic outputs for LLMs.

cognee forks cognee stars cognee pull-requests cognee releases

Cognee Demo

Try it in a Google collab notebook or have a look at our documentation

Join our Discord community

📦 Installation

With pip

pip install cognee

With poetry

poetry add cognee

💻 Usage

Setup

import os

os.environ["OPENAI_API_KEY"] = "YOUR OPENAI_API_KEY"

You can also use Ollama or Anyscale as your LLM provider. For more info on local models check our docs

Run

import cognee

text = """Natural language processing (NLP) is an interdisciplinary
       subfield of computer science and information retrieval"""

cognee.add([text], "example_dataset") # Add a new piece of information

cognee.cognify() # Use LLMs and cognee to create knowledge

search_results = cognee.search("SIMILARITY", "computer science") # Query cognee for the knowledge

for result_text in search_results[0]:
    print(result_text)

Add alternative data types:

cognee.add("file://{absolute_path_to_file}", dataset_name)

Or

cognee.add("data://{absolute_path_to_directory}", dataset_name)

# This is useful if you have a directory with files organized in subdirectories.
# You can target which directory to add by providing dataset_name.
# Example:
#            root
#           /    \
#      reports  bills
#     /       \
#   2024     2023
#
# cognee.add("data://{absolute_path_to_root}", "reports.2024")
# This will add just directory 2024 under reports.

Read more here.

Vector retrieval, Graphs and LLMs

Cognee supports a variety of tools and services for different operations:

  • Local Setup: By default, LanceDB runs locally with NetworkX and OpenAI.

  • Vector Stores: Cognee supports Qdrant and Weaviate for vector storage.

  • Language Models (LLMs): You can use either Anyscale or Ollama as your LLM provider.

  • Graph Stores: In addition to LanceDB, Neo4j is also supported for graph storage.

Demo

Check out our demo notebook here

How it works

Image

Star History

Star History Chart