From 9ddc8b38b23c249a2e2ed192da9e7f2fb1543de8 Mon Sep 17 00:00:00 2001 From: Dave Date: Tue, 17 Sep 2024 14:45:28 +0200 Subject: [PATCH] add sanity check and switch back to gpt 4 --- docs/tools/fix_grammar_gpt.py | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/docs/tools/fix_grammar_gpt.py b/docs/tools/fix_grammar_gpt.py index 71bed48445..4013f759f6 100644 --- a/docs/tools/fix_grammar_gpt.py +++ b/docs/tools/fix_grammar_gpt.py @@ -17,7 +17,7 @@ # constants BASE_DIR = "../website/docs" -GPT_MODEL = "gpt-4o-2024-05-13" +GPT_MODEL = "gpt-4-turbo" MAX_CHUNK_SIZE = 4000 # make sure that this is below the context window size of the model to not have cut off files SYSTEM_PROMPT = """\ @@ -73,6 +73,9 @@ with open(file_path, "r", encoding="utf-8") as f: doc = f.readlines() + with open(file_path, "r", encoding="utf-8") as f: + doc_length = len(f.read()) + def get_chunk_length(chunk: List[str]) -> int: count = 0 for line in chunk: @@ -111,14 +114,16 @@ def get_chunk_length(chunk: List[str]) -> int: # sanity test, make sure we still have the full doc assert doc == functools.reduce(lambda a, b: a + b, chunks) - fmt.note(f"Created {len(chunks)} chunks") + + # count chars in doc + fmt.note(f"Created {len(chunks)} chunks for {doc_length} chars") fixed_chunks: List[str] = [] for chunk in chunks: client = OpenAI() input = "".join(chunk) response = client.chat.completions.create( - seed=1239812398, + seed=123981298, model=GPT_MODEL, messages=[ {"role": "system", "content": SYSTEM_PROMPT}, @@ -128,6 +133,13 @@ def get_chunk_length(chunk: List[str]) -> int: ) fixed_chunks.append(response.choices[0].message.content) # type: ignore + + # here we check that no part of the doc was swallowed by gpt + fixed_doc_length = functools.reduce(lambda count, chunk: count + len(chunk), fixed_chunks, 0) + if fixed_doc_length / doc_length < 0.9: + fmt.error("Doc length reduced too much during processing, skipping saving, please check manually") + continue + with open(file_path, "w", encoding="utf-8") as f: for c in fixed_chunks: f.write(c)