File size: 4,100 Bytes
b7455e1
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
from smolagents import CodeAgent, DuckDuckGoSearchTool, HfApiModel, load_tool, tool
import datetime
import requests
import pytz
import yaml
from tools.final_answer import FinalAnswerTool
from Gradio_UI import GradioUI

@tool
def analyze_ichimoku_signal(prices_close: list, high_prices: list, low_prices: list) -> str:
    """Инструмент для технического анализа по системе Ichimoku Cloud.
    Анализирует TK Zone, положение цены и будущее облако для выдачи торгового вердикта.
    Args:
        prices_close: Список цен закрытия (нужно минимум 52 периода).
        high_prices: Список максимальных цен за те же периоды.
        low_prices: Список минимальных цен за те же периоды.
    """
    if len(prices_close) < 52:
        return "Ошибка: Недостаточно данных. Требуется минимум 52 свечи для корректного расчета."

    # Функция расчета средней цены за период
    def get_mid(h, l, p):
        return (max(h[-p:]) + min(l[-p:])) / 2

    # Текущие показатели
    tenkan = get_mid(high_prices, low_prices, 9)
    kijun = get_mid(high_prices, low_prices, 26)
    current_price = prices_close[-1]

    # Будущее облако (проекция на текущий момент)
    span_a = (tenkan + kijun) / 2
    span_b = get_mid(high_prices, low_prices, 52)
    kumo_bullish = span_a > span_b

    # Анализ зон
    in_tk_zone = min(tenkan, kijun) <= current_price <= max(tenkan, kijun)
    
    # Формирование вердикта
    if current_price > max(tenkan, kijun) and kumo_bullish:
        verdict = "🚀 LONG: Цена выше TK Zone, Облако бычье. Импульс подтвержден."
    elif current_price < min(tenkan, kijun) and not kumo_bullish:
        verdict = "📉 SHORT: Цена ниже TK Zone, Облако медвежье. Давление продавцов."
    elif in_tk_zone:
        verdict = "⏳ NEUTRAL: Цена в зоне равновесия (TK Zone). Ожидаем выхода."
    else:
        verdict = "🤔 MIXED: Сигналы противоречат друг другу. Рекомендуется наблюдение."

    return f"Анализ Ichimoku: Цена={current_price}, Tenkan={tenkan:.2f}, Kijun={kijun:.2f}. Вердикт: {verdict}"

@tool
def get_current_time_in_timezone(timezone: str) -> str:
    """A tool that fetches the current local time in a specified timezone.
    Args:
        timezone: A string representing a valid timezone (e.g., 'America/New_York').
    """
    try:
        tz = pytz.timezone(timezone)
        local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
        return f"The current local time in {timezone} is: {local_time}"
    except Exception as e:
        return f"Error fetching time for timezone '{timezone}': {str(e)}"

final_answer = FinalAnswerTool()

# Модель Qwen2.5-Coder отлично подходит для исполнения логики инструментов
model = HfApiModel(
    max_tokens=2096,
    temperature=0.5,
    model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
    custom_role_conversions=None,
)

# Загрузка шаблонов промптов
try:
    with open("prompts.yaml", 'r') as stream:
        prompt_templates = yaml.safe_load(stream)
except FileNotFoundError:
    prompt_templates = None # Если файла нет, агент использует стандартные

# Создание агента с регистрацией всех инструментов
agent = CodeAgent(
    model=model,
    tools=[final_answer, analyze_ichimoku_signal, get_current_time_in_timezone], 
    max_steps=6,
    verbosity_level=1,
    prompt_templates=prompt_templates
)

# Запуск интерфейса
if __name__ == "__main__":
    GradioUI(agent).launch()