Spaces:
Running
Running
Update crypto_analysis_agents.py
Browse files- crypto_analysis_agents.py +78 -34
crypto_analysis_agents.py
CHANGED
@@ -1,4 +1,4 @@
|
|
1 |
-
# crypto_analysis_agents.py -
|
2 |
from crewai import Agent, LLM
|
3 |
import os
|
4 |
from dotenv import load_dotenv
|
@@ -11,57 +11,72 @@ from sentiment_tools import SentimentTool
|
|
11 |
load_dotenv()
|
12 |
TOGETHER_API_KEY = os.getenv("TOGETHER_API_KEY")
|
13 |
|
14 |
-
|
15 |
class CryptoAnalysisAgents:
|
16 |
def __init__(self):
|
17 |
-
#
|
18 |
self.llm = LLM(
|
19 |
model="together_ai/meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo",
|
20 |
api_key=TOGETHER_API_KEY,
|
21 |
base_url="https://api.together.xyz/v1",
|
22 |
temperature=0.7,
|
23 |
-
max_tokens=
|
24 |
top_p=0.9
|
25 |
)
|
26 |
-
|
27 |
-
# OPTION 2: Llama 3.3 70B (Better Performance) - Uncomment to use
|
28 |
-
# self.llm = LLM(
|
29 |
-
# model="together_ai/meta-llama/Llama-3.3-70B-Instruct",
|
30 |
-
# api_key=TOGETHER_API_KEY,
|
31 |
-
# base_url="https://api.together.xyz/v1",
|
32 |
-
# temperature=0.7,
|
33 |
-
# max_tokens=512,
|
34 |
-
# top_p=0.9
|
35 |
-
# )
|
36 |
-
|
37 |
-
# OPTION 3: DeepSeek R1 (Advanced Reasoning) - Uncomment to use
|
38 |
-
# self.llm = LLM(
|
39 |
-
# model="together_ai/deepseek-ai/DeepSeek-R1",
|
40 |
-
# api_key=TOGETHER_API_KEY,
|
41 |
-
# base_url="https://api.together.xyz/v1",
|
42 |
-
# temperature=0.7,
|
43 |
-
# max_tokens=512,
|
44 |
-
# top_p=0.9
|
45 |
-
# )
|
46 |
def market_analyst(self):
|
47 |
return Agent(
|
48 |
-
role='
|
49 |
-
goal="
|
50 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
51 |
verbose=False,
|
52 |
llm=self.llm,
|
53 |
tools=[
|
54 |
CryptoPriceTool(),
|
55 |
-
MarketCapTool(),
|
56 |
NewsSearchTool()
|
57 |
]
|
58 |
)
|
59 |
|
60 |
def technical_analyst(self):
|
61 |
return Agent(
|
62 |
-
role='
|
63 |
-
goal="
|
64 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
65 |
verbose=False,
|
66 |
llm=self.llm,
|
67 |
tools=[
|
@@ -73,9 +88,38 @@ class CryptoAnalysisAgents:
|
|
73 |
|
74 |
def crypto_advisor(self):
|
75 |
return Agent(
|
76 |
-
role='Investment Advisor',
|
77 |
-
goal="Synthesize analysis
|
78 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
79 |
verbose=False,
|
80 |
llm=self.llm,
|
81 |
tools=[
|
|
|
1 |
+
# crypto_analysis_agents.py - Enhanced Professional Version
|
2 |
from crewai import Agent, LLM
|
3 |
import os
|
4 |
from dotenv import load_dotenv
|
|
|
11 |
load_dotenv()
|
12 |
TOGETHER_API_KEY = os.getenv("TOGETHER_API_KEY")
|
13 |
|
|
|
14 |
class CryptoAnalysisAgents:
|
15 |
def __init__(self):
|
16 |
+
# Using Llama 3.1 8B for optimal performance/cost balance
|
17 |
self.llm = LLM(
|
18 |
model="together_ai/meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo",
|
19 |
api_key=TOGETHER_API_KEY,
|
20 |
base_url="https://api.together.xyz/v1",
|
21 |
temperature=0.7,
|
22 |
+
max_tokens=1024, # Increased for more detailed responses
|
23 |
top_p=0.9
|
24 |
)
|
25 |
+
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
26 |
def market_analyst(self):
|
27 |
return Agent(
|
28 |
+
role='Senior Cryptocurrency Market Analyst',
|
29 |
+
goal="""Conduct comprehensive market analysis by gathering current price data, market capitalization,
|
30 |
+
trading volume, and recent news to provide detailed market insights. Analyze price movements,
|
31 |
+
market trends, comparative performance against major cryptocurrencies, and assess market sentiment
|
32 |
+
impact. Present findings in a structured, data-rich format with specific metrics, percentages,
|
33 |
+
and actionable market intelligence.""",
|
34 |
+
|
35 |
+
backstory="""You are a seasoned cryptocurrency market analyst with 8+ years of experience in
|
36 |
+
digital asset markets. You specialize in fundamental analysis, market trend identification,
|
37 |
+
and macroeconomic impact assessment. Your methodology includes:
|
38 |
+
|
39 |
+
- Real-time price and volume analysis with historical context
|
40 |
+
- News sentiment evaluation and market impact assessment
|
41 |
+
- Comparative analysis against Bitcoin, Ethereum, and market benchmarks
|
42 |
+
- Market cap analysis and liquidity considerations
|
43 |
+
- Institutional activity and regulatory environment monitoring
|
44 |
+
|
45 |
+
You present analysis in a clear, professional format with specific data points,
|
46 |
+
percentage changes, and contextual market insights that institutional investors rely on.""",
|
47 |
+
|
48 |
verbose=False,
|
49 |
llm=self.llm,
|
50 |
tools=[
|
51 |
CryptoPriceTool(),
|
52 |
+
MarketCapTool(),
|
53 |
NewsSearchTool()
|
54 |
]
|
55 |
)
|
56 |
|
57 |
def technical_analyst(self):
|
58 |
return Agent(
|
59 |
+
role='Senior Technical Analysis Specialist',
|
60 |
+
goal="""Perform detailed technical analysis using price action, volume patterns, and key technical
|
61 |
+
indicators including RSI, moving averages, support/resistance levels, and trend analysis.
|
62 |
+
Identify trading signals, momentum indicators, and provide specific entry/exit recommendations
|
63 |
+
with risk assessment. Present technical findings with clear signal interpretation and
|
64 |
+
probability-based projections.""",
|
65 |
+
|
66 |
+
backstory="""You are an expert technical analyst with deep expertise in cryptocurrency
|
67 |
+
chart analysis and quantitative trading strategies. Your technical analysis methodology includes:
|
68 |
+
|
69 |
+
- Multi-timeframe analysis (1D, 7D, 30D, 90D perspectives)
|
70 |
+
- RSI analysis with overbought/oversold condition assessment (>70 overbought, <30 oversold)
|
71 |
+
- Moving average trend analysis and crossover signals
|
72 |
+
- Volume analysis and momentum confirmation
|
73 |
+
- Support and resistance level identification
|
74 |
+
- Pattern recognition and breakout analysis
|
75 |
+
|
76 |
+
You provide precise technical interpretations with specific numerical thresholds,
|
77 |
+
signal strength ratings, and risk-adjusted recommendations. Your analysis includes
|
78 |
+
probability assessments and clear technical reasoning for each recommendation.""",
|
79 |
+
|
80 |
verbose=False,
|
81 |
llm=self.llm,
|
82 |
tools=[
|
|
|
88 |
|
89 |
def crypto_advisor(self):
|
90 |
return Agent(
|
91 |
+
role='Senior Cryptocurrency Investment Advisor',
|
92 |
+
goal="""Synthesize market and technical analysis to provide comprehensive investment recommendations
|
93 |
+
with detailed risk assessment, position sizing guidance, and strategic outlook. Analyze multiple
|
94 |
+
sentiment sources (social media, news, community) to provide differentiated sentiment scores
|
95 |
+
for each category. Deliver clear BUY/HOLD/SELL recommendations with confidence levels,
|
96 |
+
reasoning, and specific action steps.""",
|
97 |
+
|
98 |
+
backstory="""You are a senior cryptocurrency investment advisor with extensive experience
|
99 |
+
in digital asset portfolio management and risk assessment. Your advisory methodology includes:
|
100 |
+
|
101 |
+
- Multi-source sentiment analysis across social media, news, and community channels
|
102 |
+
- Risk-adjusted return calculations and position sizing recommendations
|
103 |
+
- Integration of fundamental and technical analysis for holistic investment views
|
104 |
+
- Market timing and entry/exit strategy optimization
|
105 |
+
- Portfolio allocation and diversification guidance
|
106 |
+
- Regulatory and macroeconomic risk assessment
|
107 |
+
|
108 |
+
You provide institutional-grade investment recommendations with:
|
109 |
+
- Clear BUY/HOLD/SELL signals with confidence ratings (High/Medium/Low)
|
110 |
+
- Differentiated sentiment analysis: Overall, Social Media, News, Community sentiment
|
111 |
+
- Specific reasoning with supporting data points
|
112 |
+
- Risk factors and mitigation strategies
|
113 |
+
- Time horizon considerations (short-term vs long-term outlook)
|
114 |
+
|
115 |
+
Your sentiment analysis specifically categorizes different sources:
|
116 |
+
- Social Media: Twitter, Reddit, Discord community sentiment
|
117 |
+
- News: Traditional media, crypto publications, regulatory announcements
|
118 |
+
- Community: Developer activity, governance participation, ecosystem growth
|
119 |
+
- Overall: Weighted composite of all sentiment sources
|
120 |
+
|
121 |
+
Each sentiment category should be distinctly analyzed and assigned Positive, Negative, or Neutral ratings.""",
|
122 |
+
|
123 |
verbose=False,
|
124 |
llm=self.llm,
|
125 |
tools=[
|