-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathcli.py
64 lines (58 loc) · 5.19 KB
/
cli.py
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
import argparse
from perplexity import Chat, Search
def main():
class CustomFormatter(argparse.ArgumentDefaultsHelpFormatter,
argparse.RawDescriptionHelpFormatter):
pass
parser = argparse.ArgumentParser(
description="""
------------------------------------------------------------------
Perplexity AI Toolkit
API Wrapper & Command-line Interface
[v1.2.2] by @rmncldyo
------------------------------------------------------------------
Perplexity AI toolit is an API wrapper and command-line interface for the suite of large-language models offered by Perplexity Labs.
| Option(s) | Description | Example Usage |
|--------------------------|------------------------------------------|-------------------------------------------------------------------------------|
| -c, --chat | Enable chat mode | --chat |
| -s, --search | Enable online search mode | --search |
| -p, --prompt | User prompt | --prompt "How many stars are there in our galaxy?" |
| -q, --query | Online search query | --query "What is today's date?" |
| -a, --api_key | API key for authentication | --api_key "api_key_goes_here" |
| -m, --model | Model name | --model "llama-3-sonar-large-32k-chat" |
| -sp, --system_prompt | System prompt (instructions) | --system_prompt "Be precise and concise." |
| -st, --stream | Enable streaming mode | --stream |
| -mt, --max_tokens | Maximum tokens to generate | --max_tokens 1024 |
| -tm, --temperature | Sampling temperature | --temperature 0.7 |
| -tp, --top_p | Nucleus sampling threshold | --top_p 0.9 |
| -tk, --top_k | Top-k sampling threshold | --top_k 40 |
| -pp, --presence_penalty | Penalize tokens based on their presence | --presence_penalty 0.5 |
| -fp, --frequency_penalty | Penalize tokens based on their frequency | --frequency_penalty 0.5 |
""",
formatter_class=CustomFormatter,
epilog="For detailed usage information, visit our ReadMe here: github.com/RMNCLDYO/perplexity-ai-toolkit"
)
parser.add_argument('-c', '--chat', action='store_true', help='Enable chat mode')
parser.add_argument('-s', '--search', action='store_true', help='Enable search mode')
parser.add_argument('-p', '--prompt', type=str, help='User prompt')
parser.add_argument('-q', '--query', type=str, help='Online search query')
parser.add_argument('-a', '--api_key', type=str, help='API key for authentication')
parser.add_argument('-m', '--model', type=str, help='Model name')
parser.add_argument('-sp', '--system_prompt', type=str, help='System prompt (instructions)')
parser.add_argument('-st', '--stream', action='store_true', help='Enable streaming mode')
parser.add_argument('-mt', '--max_tokens', type=int, help='Maximum tokens to generate')
parser.add_argument('-tm', '--temperature', type=float, help='Sampling temperature')
parser.add_argument('-tp', '--top_p', type=float, help='Nucleus sampling threshold')
parser.add_argument('-tk', '--top_k', type=int, help='Top-k sampling threshold')
parser.add_argument('-pp', '--presence_penalty', type=float, help='Penalize tokens based on their presence')
parser.add_argument('-fp', '--frequency_penalty', type=float, help='Penalize tokens based on their frequency')
args = parser.parse_args()
if args.chat:
Chat().run(args.api_key, args.model, args.prompt, args.system_prompt, args.stream, args.max_tokens, args.temperature, args.top_p, args.top_k, args.presence_penalty, args.frequency_penalty)
elif args.search:
Search().run(args.api_key, args.model, args.query, args.system_prompt, args.stream, args.max_tokens, args.temperature, args.top_p, args.top_k, args.presence_penalty, args.frequency_penalty)
else:
print("Error: Please specify a mode to use. Use --help for more information.")
exit()
if __name__ == "__main__":
main()