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')
"""
|