File size: 8,547 Bytes
c87c295
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
from typing import List, Literal, Optional, Tuple, TypedDict


Role = Literal["system", "user", "assistant"]


class Message(TypedDict):
    role: Role
    content: str


Dialog = List[Message]

model_path = "./ckpt/llama-2-13b-chat"

B_INST, E_INST = "[INST]", "[/INST]"
B_SYS, E_SYS = "<<SYS>>\n", "\n<</SYS>>\n\n"
DEFAULT_PAD_TOKEN = "[PAD]"
DEFAULT_EOS_TOKEN = "</s>"
DEFAULT_BOS_TOKEN = "<s>"
DEFAULT_UNK_TOKEN = "<unk>"

IMPORT_PKG = """
import numpy as np
import pandas as pd 
import matplotlib.pyplot as plt
import seaborn as sns
from scipy import stats
import os,sys
import re
from datetime import datetime
from sympy import symbols, Eq, solve
import torch 
import requests
from bs4 import BeautifulSoup
import json
import math
import yfinance
"""

TOOLS_CODE = r"""

import requests
import tweepy
import json,time
from urllib.parse import quote_plus
from typing import Dict
from bs4 import BeautifulSoup


#Goolge Search 
GOOGLE_API_KEY = "<YOUR>"
GOOGLE_CSE_ID  = '<YOUR>'
MAX_GOOGLE_RESULT = 5

#Twitter Key
TWITTER_API_KEY = "<YOUR>"
TWITTER_API_KEY_SECRET = "<YOUR>"
TWITTER_ACCESS_TOKEN = "<YOUR>"
TWITTER_TOKEN_SECRET = "<YOUR>"
 
class GoogleSearch:
    def __init__(self):
        self.api_key = GOOGLE_API_KEY
        self.cse_id = GOOGLE_CSE_ID
        self.url = "https://www.googleapis.com/customsearch/v1"
    
    def search(self, search_term, **kwargs):
        params = {
            'q': search_term,
            'key': self.api_key,
            'cx': self.cse_id,
        }
        params.update(kwargs)
        response = requests.get(self.url, params=params)
        return response.json()

    def __call__(self, search_term, **kwargs):
        results = self.search(search_term, **kwargs)
        output_str = ''
        for idx, item in enumerate(results.get('items', [])):
            if idx > MAX_GOOGLE_RESULT:
                break
            title = item.get('title').replace('\n','')
            snippet = item.get('snippet').replace('\n','')
            link = item.get('link').replace('\n','')
            output_str += f"[{idx+1}] Title : [{title}]\n\tsnippet : {snippet}\n\tlink : {link}\n"
        return output_str


class ArxivAPI:
    def __init__(self):
        self.base_url = 'http://export.arxiv.org/api/query?'
        self.headers = {'User-Agent': 'Mozilla/5.0'}
    
    def clean_str(self, results):
        output_str = ''
        for idx, result in enumerate(results):
            output_str += f"[{idx+1}]title : {result['title'].strip()}({result['id'].strip()})\n"
        return output_str
    
    def search(self, query: str, max_results: int = 10):
        query = quote_plus(query)
        search_query = f'search_query=all:{query}&start=0&max_results={max_results}'
        url = self.base_url + search_query
        response = requests.get(url, headers=self.headers)
        if response.status_code != 200:
            raise Exception(f'Error: {response.status_code}')
        soup = BeautifulSoup(response.content, 'xml')
        entries = soup.find_all('entry')
        results = [{'id': entry.id.text, 'title': entry.title.text} for entry in entries]
        return self.clean_str(results)

        
# google
google_search = GoogleSearch()

# Arxiv
arxiv = ArxivAPI()
"""


CODE_INTERPRETER_SYSTEM_PROMPT = """
You are helpful agent that can generate code, execute, getting feedback(results).


For example,
###User : what is 52th fibonacci number
###Assistant : 
I think I need to use python code to generate 52th fibonacci number

```python
import numpy as np

def fibonacci(n):
    sq = np.sqrt(5)
    phi = (1 + sq) / 2
    return round((phi ** n) / sq)

fibo_52 = fibonacci(52)
fibo_52
```
```RESULT
32951280099
```
The 52nd Fibonacci number is 32951280099.

+ Each code block is executed individually in each cell of a Jupyter notebook.
+ If the generated code runs successfully, there's no need to generate redundant code.
+ The code is written to provide answers to the questions.

"""

CODE_INTERPRETER_SYSTEM_PROMPT = """
You are helpful agent that can generate code, execute, getting feedback(results).

For example,
###User : Show me YTD bitcoin price.
###Assistant : 

Here's a sample Python code using pandas, matplotlib, and yfinance to get the Year-to-date (YTD) Bitcoin price and plot it:
```python
import yfinance as yf
import matplotlib.pyplot as plt

# Get the data of the Bitcoin USD price
btc = yf.Ticker("BTC-USD")

# Get the historical prices for this year
btc_hist = btc.history(period="ytd")

# Plot the close prices
btc_hist['Close'].plot(figsize=(16, 9))
plt.title('Year-to-date Bitcoin price')
plt.xlabel('Date')
plt.ylabel('Price (USD)')
plt.savefig('./tmp/chart.png')
```
```RESULT
<Figure size 1600x900 with 1 Axes>
```

Here is the chart of the bitcoin close YTD chart : ![chart]('./tmp/chart.png')</s>

+ Each code block is executed individually in each cell of a Jupyter notebook.
+ If the generated code runs successfully, there's no need to generate redundant code.
+ The code is written to provide answers to the questions.

"""

CODE_INTERPRETER_SYSTEM_PROMPT = """
As an advanced language model, you can generate code as part of your responses. 
To make the code more noticeable and easier to read, please encapsulate it within triple backticks.
For instance, if you're providing Python code, wrap it as follows:

```python
print('hellow world')
```

Basically this two tools are provided.

```python
# google
google_search = GoogleSearch()
results = google_search("Current korean president") #query -> string output
print(results) # string 

# Arxiv
arxiv = ArxivAPI()
results = arxiv.search('embodied ai') #query -> string
print(results) # string
```

After presenting the results from the code
You will provide a useful explanation or interpretation of the output to further aid your understanding."

Additionally, when generating plots or figures, 
I'll save them to a specified path, like ./tmp/plot.png, so that they can be viewed. 
After saving the plot, I'll use the following markdown syntax to display the image at the end of the response:
![plot]('./tmp/plot.png')

You are using jupyter notebook currently.
This approach allows me to visually present data and findings."
"""

CODE_INTERPRETER_SYSTEM_PROMPT_PRESIDENT = """
You are helpful agent that can code 

You are avaible to use
numpy, beautifulsoup, torch, PIL, opencv, ...

For example,
###User : Who is current president of singapore?
###Assistant : 

Here's a sample Python code using pandas, matplotlib, and yfinance to get the Year-to-date (YTD) Bitcoin price and plot it:
```python
import requests
from bs4 import BeautifulSoup

def get_current_south_korea_president():
    url = 'https://www.president.go.kr/president/greeting'
    response = requests.get(url)
    soup = BeautifulSoup(response.text, 'html.parser')
    # Find the president's name
    president_name = soup.find('title').text.strip()
    return president_name

get_current_south_korea_president()
```
```RESULT
๋Œ€ํ•œ๋ฏผ๊ตญ ๋Œ€ํ†ต๋ น > ์œค์„์—ด ๋Œ€ํ†ต๋ น > ์ทจ์ž„์‚ฌ
```

The current President of Korea is ์œค์„์—ด
"""


CODE_INTERPRETER_SYSTEM_PROMPT_GPT4 = f"""
You are helpful agent that can code 

You are avaible to use
{IMPORT_PKG}
"""


CODE_INTERPRETER_SYSTEM_PROMPT_GPT4 = f"""
You are helpful agent that can code.

### User : Can you show me the distribution of the current 
"""


CODE_INTERPRETER_SYSTEM_PROMPT_GPT4_BASE = f"""
You are helpful agent that can code.

For example,

### User : Show me YTD bitcoin pirce.

### Assistant : Sure thing! Here's a Python script using yfinance to get the YTD Bitcoin price and save it into a CSV file using pandas. 
It also plots the price using matplotlib. Please note we are saving the plot in the 
./tmp/ directory as 'bitcoin_YTD.png' and data as 'bitcoin_YTD.csv'.

```python
import yfinance as yf
import matplotlib.pyplot as plt
import pandas as pd\nfrom datetime import datetime

# Get the current year
year = datetime.now().year
# Get the data of Bitcoin from the beginning of this year until now
btc = yf.download('BTC-USD', start=str(year)+'-01-01', end=datetime.now().strftime(\"%Y-%m-%d\"))

# Save the data to a .csv file
btc.to_csv('./tmp/bitcoin_YTD.csv')

# Create a plot
plt.figure(figsize=(14, 7))
plt.plot(btc['Close'])
plt.title('Bitcoin Price YTD')
plt.xlabel('Date')
plt.ylabel('Price'
nplt.grid(True)
plt.savefig('./tmp/bitcoin_YTD.png')
```

```RESULTS
[*********************100%***********************]  1 of 1 completed
<Figure size 1400x700 with 1 Axes>
```

Here is plot : ![BTC-YTD]('./tmp/bitcoin_YTD.png')
"""