|
from colorama import Fore |
|
|
|
from autogpt.config import Config |
|
from autogpt.config.ai_config import AIConfig |
|
from autogpt.config.config import Config |
|
from autogpt.logs import logger |
|
from autogpt.promptgenerator import PromptGenerator |
|
from autogpt.setup import prompt_user |
|
from autogpt.utils import clean_input |
|
|
|
CFG = Config() |
|
|
|
|
|
def get_prompt() -> str: |
|
""" |
|
This function generates a prompt string that includes various constraints, |
|
commands, resources, and performance evaluations. |
|
|
|
Returns: |
|
str: The generated prompt string. |
|
""" |
|
|
|
|
|
cfg = Config() |
|
|
|
|
|
prompt_generator = PromptGenerator() |
|
|
|
|
|
prompt_generator.add_constraint( |
|
"~4000 word limit for short term memory. Your short term memory is short, so" |
|
" immediately save important information to files." |
|
) |
|
prompt_generator.add_constraint( |
|
"If you are unsure how you previously did something or want to recall past" |
|
" events, thinking about similar events will help you remember." |
|
) |
|
prompt_generator.add_constraint("No user assistance") |
|
prompt_generator.add_constraint( |
|
'Exclusively use the commands listed in double quotes e.g. "command name"' |
|
) |
|
prompt_generator.add_constraint( |
|
"Use subprocesses for commands that will not terminate within a few minutes" |
|
) |
|
|
|
|
|
commands = [ |
|
("Google Search", "google", {"input": "<search>"}), |
|
( |
|
"Browse Website", |
|
"browse_website", |
|
{"url": "<url>", "question": "<what_you_want_to_find_on_website>"}, |
|
), |
|
( |
|
"Start GPT Agent", |
|
"start_agent", |
|
{"name": "<name>", "task": "<short_task_desc>", "prompt": "<prompt>"}, |
|
), |
|
( |
|
"Message GPT Agent", |
|
"message_agent", |
|
{"key": "<key>", "message": "<message>"}, |
|
), |
|
("List GPT Agents", "list_agents", {}), |
|
("Delete GPT Agent", "delete_agent", {"key": "<key>"}), |
|
( |
|
"Clone Repository", |
|
"clone_repository", |
|
{"repository_url": "<url>", "clone_path": "<directory>"}, |
|
), |
|
("Write to file", "write_to_file", {"file": "<file>", "text": "<text>"}), |
|
("Read file", "read_file", {"file": "<file>"}), |
|
("Append to file", "append_to_file", {"file": "<file>", "text": "<text>"}), |
|
("Delete file", "delete_file", {"file": "<file>"}), |
|
("Search Files", "search_files", {"directory": "<directory>"}), |
|
("Analyze Code", "analyze_code", {"code": "<full_code_string>"}), |
|
( |
|
"Get Improved Code", |
|
"improve_code", |
|
{"suggestions": "<list_of_suggestions>", "code": "<full_code_string>"}, |
|
), |
|
( |
|
"Write Tests", |
|
"write_tests", |
|
{"code": "<full_code_string>", "focus": "<list_of_focus_areas>"}, |
|
), |
|
("Execute Python File", "execute_python_file", {"file": "<file>"}), |
|
("Task Complete (Shutdown)", "task_complete", {"reason": "<reason>"}), |
|
("Generate Image", "generate_image", {"prompt": "<prompt>"}), |
|
("Send Tweet", "send_tweet", {"text": "<text>"}), |
|
] |
|
|
|
|
|
if cfg.huggingface_audio_to_text_model: |
|
commands.append( |
|
("Convert Audio to text", "read_audio_from_file", {"file": "<file>"}), |
|
) |
|
|
|
|
|
if cfg.execute_local_commands: |
|
commands.append( |
|
( |
|
"Execute Shell Command, non-interactive commands only", |
|
"execute_shell", |
|
{"command_line": "<command_line>"}, |
|
), |
|
) |
|
commands.append( |
|
( |
|
"Execute Shell Command Popen, non-interactive commands only", |
|
"execute_shell_popen", |
|
{"command_line": "<command_line>"}, |
|
), |
|
) |
|
|
|
|
|
if cfg.allow_downloads: |
|
commands.append( |
|
( |
|
"Downloads a file from the internet, and stores it locally", |
|
"download_file", |
|
{"url": "<file_url>", "file": "<saved_filename>"}, |
|
), |
|
) |
|
|
|
|
|
commands.append( |
|
("Do Nothing", "do_nothing", {}), |
|
) |
|
commands.append( |
|
("Task Complete (Shutdown)", "task_complete", {"reason": "<reason>"}), |
|
) |
|
|
|
|
|
for command_label, command_name, args in commands: |
|
prompt_generator.add_command(command_label, command_name, args) |
|
|
|
|
|
prompt_generator.add_resource( |
|
"Internet access for searches and information gathering." |
|
) |
|
prompt_generator.add_resource("Long Term memory management.") |
|
prompt_generator.add_resource( |
|
"GPT-3.5 powered Agents for delegation of simple tasks." |
|
) |
|
prompt_generator.add_resource("File output.") |
|
|
|
|
|
prompt_generator.add_performance_evaluation( |
|
"Continuously review and analyze your actions to ensure you are performing to" |
|
" the best of your abilities." |
|
) |
|
prompt_generator.add_performance_evaluation( |
|
"Constructively self-criticize your big-picture behavior constantly." |
|
) |
|
prompt_generator.add_performance_evaluation( |
|
"Reflect on past decisions and strategies to refine your approach." |
|
) |
|
prompt_generator.add_performance_evaluation( |
|
"Every command has a cost, so be smart and efficient. Aim to complete tasks in" |
|
" the least number of steps." |
|
) |
|
|
|
|
|
return prompt_generator.generate_prompt_string() |
|
|
|
|
|
def construct_prompt() -> str: |
|
"""Construct the prompt for the AI to respond to |
|
|
|
Returns: |
|
str: The prompt string |
|
""" |
|
config = AIConfig.load(CFG.ai_settings_file) |
|
if CFG.skip_reprompt and config.ai_name: |
|
logger.typewriter_log("Name :", Fore.GREEN, config.ai_name) |
|
logger.typewriter_log("Role :", Fore.GREEN, config.ai_role) |
|
logger.typewriter_log("Goals:", Fore.GREEN, f"{config.ai_goals}") |
|
elif config.ai_name: |
|
logger.typewriter_log( |
|
"Welcome back! ", |
|
Fore.GREEN, |
|
f"Would you like me to return to being {config.ai_name}?", |
|
speak_text=True, |
|
) |
|
should_continue = clean_input( |
|
f"""Continue with the last settings? |
|
Name: {config.ai_name} |
|
Role: {config.ai_role} |
|
Goals: {config.ai_goals} |
|
Continue (y/n): """ |
|
) |
|
if should_continue.lower() == "n": |
|
config = AIConfig() |
|
|
|
if not config.ai_name: |
|
config = prompt_user() |
|
config.save(CFG.ai_settings_file) |
|
|
|
|
|
global ai_name |
|
ai_name = config.ai_name |
|
|
|
return config.construct_full_prompt() |
|
|