/sec-insights

A real world full-stack application using LlamaIndex

Primary LanguageTypeScriptMIT LicenseMIT

SEC Insights 🏦

SEC Insights uses the Retrieval Augmented Generation (RAG) capabilities of LlamaIndex to answer questions about SEC 10-K & 10-Q documents.

You can start using the application now at secinsights.ai

You can also check out our End-to-End tutorial guide on YouTube for this project! This video covers product features, system architecture, development environment setup, and how to use this application with your own custom documents (beyond just SEC filings!). The video has chapters so you can skip to the section most relevant to you.

Why did we make this? 🤔

As RAG applications look to move increasingly from prototype to production, we thought our developer community would find value in having a complete example of a working real world RAG application.

SEC Insights works as well locally as it does in the cloud. It also comes with many product features that will be immediately applicable to most RAG applications.

Use this repository as a reference when building out your own RAG application or fork it entirely to start your project off with a solid foundation.

Product Features 😎

  • Chat-based Document Q&A against a pool of documents
  • Citation of source data that LLM response was based on
  • PDF Viewer with highlighting of citations
  • Use of API-based tools (polygon.io) for answering quantitative questions
  • Token-level streaming of LLM responses via Server-Sent Events
  • Streaming of Reasoning Steps (Sub-Questions) within Chat

Development Features 🤓

  • Infrastructure-as-code for deploying directly to Vercel & Render
  • Robust local environment setup making use of LocalStack & Docker compose
  • Monitoring & Profiling provided by Sentry
  • Load Testing provided by Loader.io
  • Variety of python scripts for REPL-based interaction & data management

Tech Stack ⚒️

System Architecture

System Architecture

Usage 💻

See README.md files in frontend/ & backend/ folders for individual setup instructions for each. As mentioned above, we also have a YouTube tutorial here that covers how to setup up this project's development environment.

We've also included a config for a Github Codespace in .devcontainer/devcontainer.json. If you choose to use Github Codespaces, your codespace will come pre-configured with a lot of the libraries and system dependencies that are needed to run this project. This is probably the fastest way to get this project up and running!

If you have any questions when trying to run this project, you may find your answer quickly by reviewing our FAQ or by searching through our Github issues! If you don't see a satisfactory answer to your question, feel free to open a Github issue so we may assist you!

Caveats 🧐

  • The frontend currently doesn't support Mobile
  • Our main goal with this project is to provide a solid foundation for full-stack RAG apps. There is still room for improvement in terms of RAG performance!

Contributing 💡

We remain very open to contributions! We're looking forward to seeing the ideas and improvements the LlamaIndex community is able to provide.

Huge shoutout to @Evanc123 for his fantastic work building the frontend for this project!