File size: 3,140 Bytes
d777bde
 
 
 
16928fe
d777bde
b75495a
16928fe
bf87ea3
 
fbfac53
d777bde
16928fe
 
 
 
 
 
 
 
 
 
 
 
0256c0c
57b95ac
 
 
 
a400d20
57b95ac
 
 
 
 
 
d777bde
57b95ac
d777bde
0d4931c
fc3458d
 
0d4931c
fc3458d
d777bde
fc3458d
 
d777bde
fc3458d
 
 
 
 
 
 
 
 
d777bde
 
 
57b95ac
d777bde
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
57b95ac
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
import re
import requests
from markdownify import markdownify
from requests.exceptions import RequestException
from smolagents import CodeAgent, DuckDuckGoSearchTool, FinalAnswerTool, HfApiModel, Tool, tool, VisitWebpageTool, ToolCallingAgent, LiteLLMModel
from huggingface_hub import login
import os
import openai
import litellm
litellm._turn_on_debug()

# Создание модели
#model_id = "Qwen/Qwen2.5-Coder-32B-Instruct"
#hf_token = os.getenv('hf_token')
#model = HfApiModel(model_id, token=hf_token)

os.environ["OPENAI_API_KEY"] = os.getenv('sambanova_token')
model = LiteLLMModel(
    model_id="openai/Llama-3.1-Tulu-3-405B",
    max_tokens=2096,
    temperature=0.1,
    api_base="https://api.sambanova.ai/v1",
    num_ctx=8192
)

# Создание инструмента для посещения веб-страниц
class WebpageVisitorTool(Tool):
    name = "webpage_visitor"
    description = "Этот инструмент посещает веб-страницу и возвращает ее содержимое в формате Markdown."

    inputs = {
        "url": {
            "type": "string",
            "description": "URL веб-страницы, которую нужно посетить.",
        }
    }

    output_type = "string"

    def forward(self, url: str) -> str:
        try:
            # Send a GET request to the URL
            response = requests.get(url)
            response.raise_for_status()  # Raise an exception for bad status codes

            # Convert the HTML content to Markdown
            markdown_content = markdownify(response.text).strip()

            # Remove multiple line breaks
            markdown_content = re.sub(r"\n{3,}", "\n\n", markdown_content)

            return markdown_content

        except RequestException as e:
            return f"Error fetching the webpage: {str(e)}"
        except Exception as e:
            return f"An unexpected error occurred: {str(e)}"

# Создание веб-агента
web_agent = ToolCallingAgent(
    tools=[DuckDuckGoSearchTool(), WebpageVisitorTool()],
    model=model,
    max_steps=10,
    name="web_search_agent",
    description="Выполняет поиск в интернете"
)

# Создание менеджера-агента
manager_agent = CodeAgent(
    tools=[],
    model=model,
    managed_agents=[web_agent],
    additional_authorized_imports=["time", "numpy", "pandas"]
)

# Запуск системы
answer = manager_agent.run("Если обучение моделей языка продолжит масштабироваться с текущим темпом до 2030 года, какова будет потребляемая электрическая мощность в ГВт, необходимая для питания крупнейших тренировочных запусков к 2030 году? Что это будет соответствовать, по сравнению с некоторыми странами? Пожалуйста, предоставьте источник для любых использованных чисел.")
print(answer)