Files changed (2) hide show
  1. 123 +91 -0
  2. app.py +0 -69
123 ADDED
@@ -0,0 +1,91 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from smolagents import CodeAgent, DuckDuckGoSearchTool, HfApiModel, load_tool, tool
2
+ import datetime
3
+ import requests
4
+ import pytz
5
+ import yaml
6
+ from tools.final_answer import FinalAnswerTool
7
+ from Gradio_UI import GradioUI
8
+
9
+ @tool
10
+ def analyze_ichimoku_signal(prices_close: list, high_prices: list, low_prices: list) -> str:
11
+ """Инструмент для технического анализа по системе Ichimoku Cloud.
12
+ Анализирует TK Zone, положение цены и будущее облако для выдачи торгового вердикта.
13
+ Args:
14
+ prices_close: Список цен закрытия (нужно минимум 52 периода).
15
+ high_prices: Список максимальных цен за те же периоды.
16
+ low_prices: Список минимальных цен за те же периоды.
17
+ """
18
+ if len(prices_close) < 52:
19
+ return "Ошибка: Недостаточно данных. Требуется минимум 52 свечи для корректного расчета."
20
+
21
+ # Функция расчета средней цены за период
22
+ def get_mid(h, l, p):
23
+ return (max(h[-p:]) + min(l[-p:])) / 2
24
+
25
+ # Текущие показатели
26
+ tenkan = get_mid(high_prices, low_prices, 9)
27
+ kijun = get_mid(high_prices, low_prices, 26)
28
+ current_price = prices_close[-1]
29
+
30
+ # Будущее облако (проекция на текущий момент)
31
+ span_a = (tenkan + kijun) / 2
32
+ span_b = get_mid(high_prices, low_prices, 52)
33
+ kumo_bullish = span_a > span_b
34
+
35
+ # Анализ зон
36
+ in_tk_zone = min(tenkan, kijun) <= current_price <= max(tenkan, kijun)
37
+
38
+ # Формирование вердикта
39
+ if current_price > max(tenkan, kijun) and kumo_bullish:
40
+ verdict = "🚀 LONG: Цена выше TK Zone, Облако бычье. Импульс подтвержден."
41
+ elif current_price < min(tenkan, kijun) and not kumo_bullish:
42
+ verdict = "📉 SHORT: Цена ниже TK Zone, Облако медвежье. Давление продавцов."
43
+ elif in_tk_zone:
44
+ verdict = "⏳ NEUTRAL: Цена в зоне равновесия (TK Zone). Ожидаем выхода."
45
+ else:
46
+ verdict = "🤔 MIXED: Сигналы противоречат друг другу. Рекомендуется наблюдение."
47
+
48
+ return f"Анализ Ichimoku: Цена={current_price}, Tenkan={tenkan:.2f}, Kijun={kijun:.2f}. Вердикт: {verdict}"
49
+
50
+ @tool
51
+ def get_current_time_in_timezone(timezone: str) -> str:
52
+ """A tool that fetches the current local time in a specified timezone.
53
+ Args:
54
+ timezone: A string representing a valid timezone (e.g., 'America/New_York').
55
+ """
56
+ try:
57
+ tz = pytz.timezone(timezone)
58
+ local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
59
+ return f"The current local time in {timezone} is: {local_time}"
60
+ except Exception as e:
61
+ return f"Error fetching time for timezone '{timezone}': {str(e)}"
62
+
63
+ final_answer = FinalAnswerTool()
64
+
65
+ # Модель Qwen2.5-Coder отлично подходит для исполнения логики инструментов
66
+ model = HfApiModel(
67
+ max_tokens=2096,
68
+ temperature=0.5,
69
+ model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
70
+ custom_role_conversions=None,
71
+ )
72
+
73
+ # Загрузка шаблонов промптов
74
+ try:
75
+ with open("prompts.yaml", 'r') as stream:
76
+ prompt_templates = yaml.safe_load(stream)
77
+ except FileNotFoundError:
78
+ prompt_templates = None # Если файла нет, агент использует стандартные
79
+
80
+ # Создание агента с регистрацией всех инструментов
81
+ agent = CodeAgent(
82
+ model=model,
83
+ tools=[final_answer, analyze_ichimoku_signal, get_current_time_in_timezone],
84
+ max_steps=6,
85
+ verbosity_level=1,
86
+ prompt_templates=prompt_templates
87
+ )
88
+
89
+ # Запуск интерфейса
90
+ if __name__ == "__main__":
91
+ GradioUI(agent).launch()
app.py DELETED
@@ -1,69 +0,0 @@
1
- from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
2
- import datetime
3
- import requests
4
- import pytz
5
- import yaml
6
- from tools.final_answer import FinalAnswerTool
7
-
8
- from Gradio_UI import GradioUI
9
-
10
- # Below is an example of a tool that does nothing. Amaze us with your creativity !
11
- @tool
12
- def my_custom_tool(arg1:str, arg2:int)-> str: #it's import to specify the return type
13
- #Keep this format for the description / args / args description but feel free to modify the tool
14
- """A tool that does nothing yet
15
- Args:
16
- arg1: the first argument
17
- arg2: the second argument
18
- """
19
- return "What magic will you build ?"
20
-
21
- @tool
22
- def get_current_time_in_timezone(timezone: str) -> str:
23
- """A tool that fetches the current local time in a specified timezone.
24
- Args:
25
- timezone: A string representing a valid timezone (e.g., 'America/New_York').
26
- """
27
- try:
28
- # Create timezone object
29
- tz = pytz.timezone(timezone)
30
- # Get current time in that timezone
31
- local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
32
- return f"The current local time in {timezone} is: {local_time}"
33
- except Exception as e:
34
- return f"Error fetching time for timezone '{timezone}': {str(e)}"
35
-
36
-
37
- final_answer = FinalAnswerTool()
38
-
39
- # If the agent does not answer, the model is overloaded, please use another model or the following Hugging Face Endpoint that also contains qwen2.5 coder:
40
- # model_id='https://pflgm2locj2t89co.us-east-1.aws.endpoints.huggingface.cloud'
41
-
42
- model = HfApiModel(
43
- max_tokens=2096,
44
- temperature=0.5,
45
- model_id='Qwen/Qwen2.5-Coder-32B-Instruct',# it is possible that this model may be overloaded
46
- custom_role_conversions=None,
47
- )
48
-
49
-
50
- # Import tool from Hub
51
- image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
52
-
53
- with open("prompts.yaml", 'r') as stream:
54
- prompt_templates = yaml.safe_load(stream)
55
-
56
- agent = CodeAgent(
57
- model=model,
58
- tools=[final_answer], ## add your tools here (don't remove final answer)
59
- max_steps=6,
60
- verbosity_level=1,
61
- grammar=None,
62
- planning_interval=None,
63
- name=None,
64
- description=None,
65
- prompt_templates=prompt_templates
66
- )
67
-
68
-
69
- GradioUI(agent).launch()