Ling / tasks /sentiment_analysis.py
Nam Fam
update files
ea99abb
from llms import LLM
from utils.remote_client import execute_remote_task
def sentiment_analysis(text: str, model: str, custom_instructions: str = "", use_llm: bool = True) -> str:
"""
Analyze sentiment of text using either LLM or traditional (Modal API) method.
Args:
text: The text to analyze
model: The model to use
custom_instructions: Optional instructions for LLM
use_llm: Whether to use LLM or traditional method
"""
if not text.strip():
return ""
if use_llm:
return _sentiment_with_llm(text, model, custom_instructions)
else:
return _sentiment_with_traditional(text, model)
def _sentiment_with_llm(text: str, model: str, custom_instructions: str = "") -> str:
try:
llm = LLM(model=model)
prompt = (
f"Analyze the sentiment of the following text. Return ONLY one value: 'positive', 'negative', or 'neutral'.\n" +
(f"{custom_instructions}\n" if custom_instructions else "") +
f"Text: {text}\nSentiment:"
)
result = llm.generate(prompt)
return result.strip()
except Exception as e:
print(f"Error in LLM sentiment analysis: {str(e)}")
return "Oops! Something went wrong. Please try again later."
def _sentiment_with_traditional(text: str, model: str) -> str:
try:
payload = {
"text": text,
"model": model,
"task": "sentiment"
}
resp = execute_remote_task("classification", payload)
if "error" in resp:
return "Oops! Something went wrong. Please try again later."
return resp.get("labels", "")
except Exception as e:
print(f"Error in traditional sentiment analysis: {str(e)}")
return "Oops! Something went wrong. Please try again later."