Skip to content

Commit

Permalink
I'm an idiot.
Browse files Browse the repository at this point in the history
  • Loading branch information
rmusser01 committed Jan 6, 2025
1 parent b8afc9d commit c88c0df
Show file tree
Hide file tree
Showing 12 changed files with 50 additions and 29 deletions.
11 changes: 4 additions & 7 deletions App_Function_Libraries/Chat/Chat_Functions.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,12 +49,9 @@ def chat_api_call(api_endpoint, api_key, input_data, prompt, temp, system_messag
logging.info(f"Debug - Chat API Call - API Endpoint: {api_endpoint}")
log_counter("chat_api_call_attempt", labels={"api_endpoint": api_endpoint})
start_time = time.time()
if not api_key:
api_key = None
model = None
try:
logging.info(f"Debug - Chat API Call - API Endpoint: {api_endpoint}")
logging.info(f"Debug - Chat API Call - API Key: {api_key}")
logging.info(f"Debug - Chat API Call - API Key: {api_key[:5]}...{api_key[-5:]}")
logging.info(f"Debug - Chat chat_api_call - API Endpoint: {api_endpoint}")
if api_endpoint.lower() == 'openai':
response = chat_with_openai(api_key, input_data, prompt, temp, system_message, streaming, minp, maxp, model)
Expand Down Expand Up @@ -143,7 +140,7 @@ def chat_api_call(api_endpoint, api_key, input_data, prompt, temp, system_messag
return f"An error occurred: {str(e)}"


def chat(message, history, media_content, selected_parts, api_endpoint, api_key, prompt, temperature,
def chat(message, history, media_content, selected_parts, api_endpoint, api_key, custom_prompt, temperature,
system_message=None, streaming=False, minp=None, maxp=None, model=None):
log_counter("chat_attempt", labels={"api_endpoint": api_endpoint})
start_time = time.time()
Expand Down Expand Up @@ -180,10 +177,10 @@ def chat(message, history, media_content, selected_parts, api_endpoint, api_key,

logging.debug(f"Debug - Chat Function - Temperature: {temperature}")
logging.debug(f"Debug - Chat Function - API Key: {api_key[:10]}")
logging.debug(f"Debug - Chat Function - Prompt: {prompt}")
logging.debug(f"Debug - Chat Function - Prompt: {custom_prompt}")

# Use the existing API request code based on the selected endpoint
response = chat_api_call(api_endpoint, api_key, input_data, prompt, temp, system_message, streaming, minp=None, maxp=None, model=None)
response = chat_api_call(api_endpoint, api_key, input_data, custom_prompt, temp, system_message, streaming, minp, maxp, model)

if streaming:
return response
Expand Down
11 changes: 7 additions & 4 deletions App_Function_Libraries/Gradio_UI/Chat_ui.py
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,9 @@ def chat_wrapper(message, history, media_content, selected_parts, api_endpoint,
presence_penalty=None, stop_sequence=None):
try:
if save_conversation:
logging.info("chat_wrapper(): Saving conversation")
if conversation_id is None:
logging.info("chat_wrapper(): Creating a new conversation")
# Create a new conversation
media_id = media_content.get('id', None)
conversation_name = f"Chat about {media_content.get('title', 'Unknown Media')} - {datetime.now().strftime('%Y-%m-%d %H:%M:%S')}"
Expand All @@ -111,11 +113,12 @@ def chat_wrapper(message, history, media_content, selected_parts, api_endpoint,
full_message = message

# Generate bot response
logging.debug("chat_wrapper(): Generating bot response")
bot_message = ""
for chunk in chat(full_message, history, media_content, selected_parts, api_endpoint, api_key, custom_prompt,
temperature, system_prompt, streaming):
temperature, system_prompt, streaming, minp=None, maxp=None, model=None):
bot_message += chunk # Accumulate the streamed response
logging.debug(f"Bot message being returned: {bot_message}")
logging.debug(f"chat_wrapper(): Bot message being returned: {bot_message}")
# Yield the incremental response and updated history
yield bot_message, history + [(message, bot_message)], conversation_id

Expand All @@ -124,8 +127,8 @@ def chat_wrapper(message, history, media_content, selected_parts, api_endpoint,
save_message(conversation_id, role="assistant", content=bot_message)

except Exception as e:
logging.error(f"Error in chat wrapper: {str(e)}")
yield "An error occurred.", history, conversation_id
logging.error(f"chat_wrapper(): Error in chat wrapper: {str(e)}")
yield "chat_wrapper(): An error occurred.", history, conversation_id


def search_conversations(query):
Expand Down
28 changes: 17 additions & 11 deletions App_Function_Libraries/Gradio_UI/Workflows_tab.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,6 @@ def chat_workflows_tab():
with gr.Row():
with gr.Column():
workflow_selector = gr.Dropdown(label="Select Workflow", choices=[wf['name'] for wf in workflows])
# Refactored API selection dropdown
api_selector = gr.Dropdown(
choices=["None"] + [format_api_name(api) for api in global_api_endpoints],
value=default_value,
Expand Down Expand Up @@ -91,8 +90,7 @@ def update_workflow_ui(workflow_name):
logging.error(f"Selected workflow not found: {workflow_name}")
return {"current_step": 0, "max_steps": 0, "conversation_id": None}, "", []

def process_workflow_step(message, history, context, workflow_name, api_endpoint, api_key, workflow_state,
save_conv, temp):
def process_workflow_step(message, history, context, workflow_name, api_endpoint, api_key, workflow_state, save_conv, temp):
logging.info(f"Process workflow step called with message: {message}")
logging.info(f"Current workflow state: {workflow_state}")
try:
Expand All @@ -114,13 +112,20 @@ def process_workflow_step(message, history, context, workflow_name, api_endpoint
full_message = f"{context}\n\nStep {current_step + 1}: {prompt}\nUser: {message}"

logging.info(f"Calling chat_wrapper with full_message: {full_message[:100]}...")
bot_message, new_history, new_conversation_id = chat_wrapper(

# Initialize bot message to accumulate stremed response
bot_message = ""

# call chat _wrapper
for chunk, new_history, new_conversation_id in chat_wrapper(
full_message, history, media_content.value, selected_parts.value,
api_endpoint, api_key, "", workflow_state["conversation_id"],
save_conv, temp, "You are a helpful assistant guiding through a workflow."
)
):
bot_message = chunk # Update bot message with the latest chunk
yield new_history, workflow_state, gr.update(interactive=True)
logging.info(f"Received bot_message: {bot_message[:50]}...")

logging.info(f"Received bot_message: {bot_message[:100]}...")

next_step = current_step + 1
new_workflow_state = {
Expand All @@ -131,15 +136,17 @@ def process_workflow_step(message, history, context, workflow_name, api_endpoint

if next_step >= max_steps:
logging.info("Workflow completed after this step")
return new_history, new_workflow_state, gr.update(interactive=False)
yield history + [(message, bot_message)], new_workflow_state, gr.update(interactive=False)
else:
next_prompt = selected_workflow['prompts'][next_step]
new_history = history + [(message, bot_message)]
new_history.append((None, f"Step {next_step + 1}: {next_prompt}"))
logging.info(f"Moving to next step: {next_step}")
return new_history, new_workflow_state, gr.update(interactive=True)
yield new_history, new_workflow_state, gr.update(interactive=True)

except Exception as e:
logging.error(f"Error in process_workflow_step: {str(e)}")
return history, workflow_state, gr.update(interactive=True)
yield history, workflow_state, gr.update(interactive=True)

workflow_selector.change(
update_workflow_ui,
Expand All @@ -149,8 +156,7 @@ def process_workflow_step(message, history, context, workflow_name, api_endpoint

submit_btn.click(
process_workflow_step,
inputs=[msg, chatbot, context_input, workflow_selector, api_selector, api_key_input, workflow_state,
save_conversation, temperature],
inputs=[msg, chatbot, context_input, workflow_selector, api_selector, api_key_input, workflow_state, save_conversation, temperature],
outputs=[chatbot, workflow_state, msg]
).then(
lambda: gr.update(value=""),
Expand Down
1 change: 1 addition & 0 deletions Docs/Design/DB_Design.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ Migrating to sqlite-vec
https://docs.google.com/document/d/1sJ_S2ggfFmtPJupxIO3C1EZAFuDMUfNYcAytissbFMs/edit?tab=t.0#heading=h.xyau1jyb6vyx
https://github.com/Mozilla-Ocho/llamafile/pull/644

https://ai.plainenglish.io/top-interview-questions-on-data-modeling-concepts-3d1587c86214
https://briandouglas.ie/sqlite-defaults/
https://phiresky.github.io/blog/2020/sqlite-performance-tuning/
https://kerkour.com/sqlite-for-servers
Expand Down
2 changes: 1 addition & 1 deletion Docs/Design/Diagram_Generation.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
https://excalidraw.com/
https://www.napkin.ai/
https://github.com/southbridgeai/diagen

https://levelup.gitconnected.com/uml-diagrams-a-guide-for-software-engineers-71220ffb775f?source=home_following---------57-1--------------------dd5db0ec_9e4b_478a_951e_a16e50e4d723-------3



2 changes: 1 addition & 1 deletion Docs/Design/Prompts.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ https://github.com/microsoft/PromptWizard


https://medium.com/@camauger/crafting-effective-chatgpt-prompts-for-tabletop-roleplaying-games-a-step-by-step-guide-part-1-b81a791d278d

https://towardsdatascience.com/how-i-won-singapores-gpt-4-prompt-engineering-competition-34c195a93d41



Expand Down
2 changes: 1 addition & 1 deletion Docs/Design/Structured_Outputs.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@


https://towardsdatascience.com/diving-deeper-with-structured-outputs-b4a5d280c208

https://generativeai.pub/building-multi-agent-llm-systems-with-pydanticai-framework-a-step-by-step-guide-to-create-ai-5e41fbba2608

## Introduction
This page serves as documentation regarding the structured outputs within tldw and provides context/justification for the decisions made within the module.
Expand Down
3 changes: 3 additions & 0 deletions Docs/Design/TTS_STT.md
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,9 @@ GLM-4-Voice
GPT-SoviTTS
https://github.com/cpumaxx/sovits-ff-plugin
https://github.com/JarodMica/GPT-SoVITS-Package
Kokoro
https://github.com/thewh1teagle/kokoro-onnx
https://huggingface.co/hexgrad/Kokoro-82M
lina TTS
https://github.com/theodorblackbird/lina-speech/blob/main/InferenceLina.ipynb
https://github.com/theodorblackbird/lina-speech
Expand Down
2 changes: 1 addition & 1 deletion Docs/Design/Text2SQL.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,5 +19,5 @@ https://github.com/TAG-Research/TAG-Bench
https://arxiv.org/pdf/2407.14482
https://spider2-sql.github.io/
https://departmentofproduct.substack.com/p/how-to-write-sql-queries-using-ai?utm_medium=email&triedRedirect=true

https://generativeai.pub/ai-innovations-and-insights-15-text2sql-and-extractous-2643981b197f

3 changes: 3 additions & 0 deletions Docs/Design/UX.md
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,9 @@ https://markwhen.com/
https://kando.menu/
https://deepseek-artifacts.vercel.app/
https://darkpatternsgame.productartistry.com/
https://towardsdatascience.com/building-trust-in-llm-answers-highlighting-source-texts-in-pdfs-5d1342ecb811
https://levelup.gitconnected.com/textual-how-this-python-framework-is-revolutionizing-ui-development-in-2025-7bfb0fd41a59
https://cin-model-kotaemon.hf.space/app/


Not waifus, but clippy:
Expand Down
13 changes: 10 additions & 3 deletions Docs/RAG_Notes.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,9 +49,16 @@ https://arxiv.org/pdf/2409.02098v1
https://github.com/OpenSPG/KAG
https://generativeai.pub/graph-rag-has-awesome-potential-but-currently-has-serious-flaws-c052a8a3107e
https://pub.towardsai.net/kag-graph-multimodal-rag-llm-agents-powerful-ai-reasoning-b3da38d31358

https://medium.com/@florian_algo/ai-innovations-and-insights-14-funnelrag-and-craft-8436f97286bb
https://arxiv.org/abs/2412.19442
https://arxiv.org/abs/2412.15605
https://arxiv.org/html/2412.18069v1
https://github.com/smallporridge/AssistRAG
https://medium.com/@samarrana407/why-knowledge-augmented-generation-kag-is-the-best-approach-to-rag-2e7820228087





GraphRAG
https://www.microsoft.com/en-us/research/blog/introducing-drift-search-combining-global-and-local-search-methods-to-improve-quality-and-efficiency/
Expand Down Expand Up @@ -88,8 +95,8 @@ GraphRAG
https://volodymyrpavlyshyn.medium.com/unified-knowledge-graph-model-rdf-rdf-vs-lpg-the-end-of-war-a7c14d6ac76f
https://github.com/zjunlp/OneKE
https://blog.gopenai.com/llm-ontology-prompting-for-knowledge-graph-extraction-efdcdd0db3a1?gi=1d8915f0da5e


https://towardsdatascience.com/how-to-build-a-graph-rag-app-b323fc33ba06
https://medium.com/@dickson.lukose/ontology-modelling-and-engineering-4df8b6b9f3a5


### Links
Expand Down
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
- This project started as a tool by `the-crypt-keeper` to perform summarization of YouTube videos.
- I forked it, to add a couple features as I wanted to use it to help me consume conference videos at a faster pace. I kept adding/improving things and now it's a fully different tool/focus.
- You can find the original scripts by `the-crypt-keeper` in the `tldw-original-scripts` directory, a snapshot of the files before I made my changes.
- The GUI is currently a placeholder. Please excuse its crappiness for now. It will be replaced with a FastAPI backend and a new JS frontend. (Gradio is a placeholder UI)
</details>

### Updating from a version installed prior to Nov 1st:
Expand Down

0 comments on commit c88c0df

Please sign in to comment.