TradingAgents/tradingagents/agents/analysts/news_analyst.py

109 lines
4.0 KiB
Python

from langchain_core.prompts import ChatPromptTemplate, MessagesPlaceholder
import time
import json
from tradingagents.tools.generator import get_agent_tools
from tradingagents.dataflows.config import get_config
def create_news_analyst(llm):
def news_analyst_node(state):
current_date = state["trade_date"]
ticker = state["company_of_interest"]
from tradingagents.tools.generator import get_agent_tools
tools = get_agent_tools("news")
system_message = """You are a News Intelligence Analyst finding SHORT-TERM catalysts for {ticker}.
**Analysis Date:** {current_date}
## YOUR MISSION
Identify material catalysts and risks that could impact {ticker} over the NEXT 1-2 WEEKS.
## SEARCH STRATEGY
**Company News (use get_news):**
Focus on: Earnings, product launches, management changes, partnerships, regulatory actions, legal issues
**Macro/Sector News (use get_global_news):**
Focus on: Fed policy, sector rotation, geopolitical events, competitor news
## OUTPUT STRUCTURE (MANDATORY)
### Executive Summary
[1-2 sentences: Most critical catalyst + biggest risk for next 2 weeks]
### Material Catalysts (Bullish - max 4)
For each:
- **Event:** [What happened]
- **Date:** [When]
- **Impact:** [Stock reaction so far]
- **Forward Look:** [Why this matters for next 1-2 weeks]
- **Priced In?:** [Fully/Partially/Not Yet]
- **Confidence:** [High/Med/Low]
### Key Risks (Bearish - max 4)
For each:
- **Risk:** [Description]
- **Probability:** [High/Med/Low in next 2 weeks]
- **Impact:** [Magnitude if realized]
- **Timeline:** [When could it hit]
### Macro Context (Connect to {ticker})
- **Market Sentiment:** [Risk-on/off] → How does this affect {ticker} specifically?
- **Sector Trends:** [Capital flows] → Is {ticker}'s sector receiving or losing capital?
- **Upcoming Events:** [Next 2 weeks] → Which events could move {ticker}?
### News Timeline Table
| Date | Event | Source | Impact | Status | Implication |
|------|-------|--------|--------|--------|-------------|
| Dec 3 | Earnings | Co | +5% | Done | May extend |
| Dec 10 | Launch | Co | TBD | Pending | Watch |
## QUALITY RULES
- ✅ Focus on events with SPECIFIC DATES
- ✅ Assess if news is priced in or fresh
- ✅ Include short-term timeline (next 2 weeks)
- ✅ Distinguish facts from speculation
- ❌ Avoid vague "positive sentiment"
- ❌ No stale news (>1 week old unless ongoing)
Date: {current_date} | Ticker: {ticker}"""
prompt = ChatPromptTemplate.from_messages(
[
(
"system",
"You are a helpful AI assistant, collaborating with other assistants."
" Use the provided tools to progress towards answering the question."
" If you are unable to fully answer, that's OK; another assistant with different tools"
" will help where you left off. Execute what you can to make progress."
" If you or any other assistant has the FINAL TRANSACTION PROPOSAL: **BUY/HOLD/SELL** or deliverable,"
" prefix your response with FINAL TRANSACTION PROPOSAL: **BUY/HOLD/SELL** so the team knows to stop."
" You have access to the following tools: {tool_names}.\n{system_message}"
"For your reference, the current date is {current_date}. We are looking at the company {ticker}",
),
MessagesPlaceholder(variable_name="messages"),
]
)
prompt = prompt.partial(system_message=system_message)
prompt = prompt.partial(tool_names=", ".join([tool.name for tool in tools]))
prompt = prompt.partial(current_date=current_date)
prompt = prompt.partial(ticker=ticker)
chain = prompt | llm.bind_tools(tools)
result = chain.invoke(state["messages"])
report = ""
if len(result.tool_calls) == 0:
report = result.content
return {
"messages": [result],
"news_report": report,
}
return news_analyst_node