Spaces:
Running
Running
File size: 4,446 Bytes
62f966f 9997b7b 62f966f b9fbe45 62f966f 9997b7b e8ebf39 fde76b0 3ae0627 d387a99 d251baf 13f46f5 ebe573d 13f46f5 9e4289a 6170d15 3ae0627 532d210 610033d 9eb2cb5 7bf070f cd17f01 d454fcb 182ca2f 919822b 47ed2dc cd17f01 f5ab635 cd17f01 7bf070f 6f2a39c 0b28b48 fcde626 0b28b48 9eb2cb5 6f2a39c cd17f01 6170d15 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 |
---
title: Scientific Document Insights Q/A
emoji: 📝
colorFrom: yellow
colorTo: pink
sdk: streamlit
sdk_version: 1.27.2
app_file: streamlit_app.py
pinned: false
license: apache-2.0
---
# DocumentIQA: Scientific Document Insights Q/A
**Work in progress** :construction_worker:
<img src="https://github.com/lfoppiano/document-qa/assets/15426/f0a04a86-96b3-406e-8303-904b93f00015" width=300 align="right" />
## Introduction
Question/Answering on scientific documents using LLMs: ChatGPT-3.5-turbo, Mistral-7b-instruct and Zephyr-7b-beta.
The streamlit application demonstrate the implementaiton of a RAG (Retrieval Augmented Generation) on scientific documents, that we are developing at NIMS (National Institute for Materials Science), in Tsukuba, Japan.
Differently to most of the projects, we focus on scientific articles.
We target only the full-text using [Grobid](https://github.com/kermitt2/grobid) that provide and cleaner results than the raw PDF2Text converter (which is comparable with most of other solutions).
Additionally, this frontend provides the visualisation of named entities on LLM responses to extract <span stype="color:yellow">physical quantities, measurements</span> (with [grobid-quantities](https://github.com/kermitt2/grobid-quantities)) and <span stype="color:blue">materials</span> mentions (with [grobid-superconductors](https://github.com/lfoppiano/grobid-superconductors)).
The conversation is kept in memory up by a buffered sliding window memory (top 4 more recent messages) and the messages are injected in the context as "previous messages".
(The image on the right was generated with https://huggingface.co/spaces/stabilityai/stable-diffusion)
**Demos**:
- (stable version): https://lfoppiano-document-qa.hf.space/
- (unstable version): https://document-insights.streamlit.app/
## Getting started
- Select the model+embedding combination you want ot use
- Enter your API Key ([Open AI](https://platform.openai.com/account/api-keys) or [Huggingface](https://huggingface.co/docs/hub/security-tokens)).
- Upload a scientific article as PDF document. You will see a spinner or loading indicator while the processing is in progress.
- Once the spinner stops, you can proceed to ask your questions
![screenshot2.png](docs%2Fimages%2Fscreenshot2.png)
## Documentation
### Context size
Allow to change the number of blocks from the original document that are considered for responding.
The default size of each block is 250 tokens (which can be changed before uploading the first document).
With default settings, each question uses around 1000 tokens.
**NOTE**: if the chat answers something like "the information is not provided in the given context", **changing the context size will likely help**.
### Chunks size
When uploaded, each document is split into blocks of a determined size (250 tokens by default).
This setting allow users to modify the size of such blocks.
Smaller blocks will result in smaller context, yielding more precise sections of the document.
Larger blocks will result in larger context less constrained around the question.
### Query mode
Indicates whether sending a question to the LLM (Language Model) or to the vector storage.
- LLM (default) enables question/answering related to the document content.
- Embeddings: the response will consist of the raw text from the document related to the question (based on the embeddings). This mode helps to test why sometimes the answers are not satisfying or incomplete.
### NER (Named Entities Recognition)
This feature is specifically crafted for people working with scientific documents in materials science.
It enables to run NER on the response from the LLM, to identify materials mentions and properties (quantities, masurements).
This feature leverages both [grobid-quantities](https://github.com/kermitt2/grobid-quanities) and [grobid-superconductors](https://github.com/lfoppiano/grobid-superconductors) external services.
## Development notes
To release a new version:
- `bump-my-version bump patch`
- `git push --tags`
To use docker:
- docker run `lfoppiano/document-insights-qa:latest`
To install the library with Pypi:
- `pip install document-qa-engine`
## Acknolwedgement
This project is developed at the [National Institute for Materials Science](https://www.nims.go.jp) (NIMS) in Japan in collaboration with the [Lambard-ML-Team](https://github.com/Lambard-ML-Team).
|