OliveSensorAPI/scripts/qa_generation
2024-03-16 13:12:15 +08:00
..
config QA clean 2024-03-16 13:12:15 +08:00
model QA clean 2024-03-16 13:12:15 +08:00
util QA clean 2024-03-16 13:12:15 +08:00
choose_prompt.md QA clean 2024-03-16 13:12:15 +08:00
Clean_QA.md QA clean 2024-03-16 13:12:15 +08:00
main.py QA clean 2024-03-16 13:12:15 +08:00
QA_clean.py QA clean 2024-03-16 13:12:15 +08:00
README_EN.md QA clean 2024-03-16 13:12:15 +08:00
README.md QA clean 2024-03-16 13:12:15 +08:00
requirements.txt QA Generation - Update requirements.txt 2024-03-07 23:58:05 +08:00
system_prompt_v1_EN.md 新增ENmd文档 2024-03-10 15:52:18 +08:00
system_prompt_v1.md Rename system_prompt.md to system_prompt_v1.md 2024-03-07 22:40:28 +08:00
system_prompt_v2_EN.md 新增ENmd文档 2024-03-10 15:52:18 +08:00
system_prompt_v2.md Create system_prompt_v2.md 2024-03-07 22:52:32 +08:00

QA Generation Pipeline

1. Use method

  1. Check whether the dependencies in requirements.txt are satisfied.
  2. Adjust the system_promptin the code to ensure that it is consistent with the latest version of the repo to ensure the diversity and stability of the generated QA.
  3. Put the txt file into the data folder in the same directory as model.
  4. Configure the required API KEY in config/config.py and start from main.py. The generated QA pairs are stored in the jsonl format under data/generated.

1.1 API KEY obtaining method

Currently only qwen is included.

1.1.1 Qwen

Tomodel service spirit product - API - KEY management (aliyun.com)click on "create a new API - KEY", Fill in the obtained API KEY to DASHSCOPE_API_KEY in config/config.py.

2. Precautions

2.1 The System Prompt is displayed

Note that the current parsing scheme is based on the premise that the model generates json blocks of markdown wraps, and you need to make sure that this remains the case when you change the system prompt.

2.2 Sliding Window

Both window_size and overlap_size of the sliding window can be changed in the get_txt_content function in util/data_loader.py. Currently it is a sliding window divided by sentence.

2.3 Corpus Format

At present, only txt format is supported, and the cleaned book text can be placed under the data folder, and the program will recursively retrieve all txt files under the folder.

TODO

  1. Support more models (Gemini, GPT, ChatGLM...)
  2. Support multi-threaded call model
  3. Support more text formats (PDF...)
  4. Support more ways to split text