agsamantha/node_modules/langchain/dist/agents/structured_chat/prompt.cjs

63 lines
2.6 KiB
JavaScript
Raw Permalink Normal View History

2024-10-02 20:15:21 +00:00
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.SUFFIX = exports.FORMAT_INSTRUCTIONS = exports.AGENT_ACTION_FORMAT_INSTRUCTIONS = exports.PREFIX = void 0;
exports.PREFIX = `Answer the following questions truthfully and as best you can.`;
exports.AGENT_ACTION_FORMAT_INSTRUCTIONS = `Output a JSON markdown code snippet containing a valid JSON blob (denoted below by $JSON_BLOB).
This $JSON_BLOB must have a "action" key (with the name of the tool to use) and an "action_input" key (tool input).
Valid "action" values: "Final Answer" (which you must use when giving your final response to the user), or one of [{tool_names}].
The $JSON_BLOB must be valid, parseable JSON and only contain a SINGLE action. Here is an example of an acceptable output:
\`\`\`json
{{
"action": $TOOL_NAME,
"action_input": $INPUT
}}
\`\`\`
Remember to include the surrounding markdown code snippet delimiters (begin with "\`\`\`" json and close with "\`\`\`")!
`;
exports.FORMAT_INSTRUCTIONS = `You have access to the following tools.
You must format your inputs to these tools to match their "JSON schema" definitions below.
"JSON Schema" is a declarative language that allows you to annotate and validate JSON documents.
For example, the example "JSON Schema" instance {{"properties": {{"foo": {{"description": "a list of test words", "type": "array", "items": {{"type": "string"}}}}}}, "required": ["foo"]}}}}
would match an object with one required property, "foo". The "type" property specifies "foo" must be an "array", and the "description" property semantically describes it as "a list of test words". The items within "foo" must be strings.
Thus, the object {{"foo": ["bar", "baz"]}} is a well-formatted instance of this example "JSON Schema". The object {{"properties": {{"foo": ["bar", "baz"]}}}} is not well-formatted.
Here are the JSON Schema instances for the tools you have access to:
{tool_schemas}
The way you use the tools is as follows:
------------------------
${exports.AGENT_ACTION_FORMAT_INSTRUCTIONS}
If you are using a tool, "action_input" must adhere to the tool's input schema, given above.
------------------------
ALWAYS use the following format:
Question: the input question you must answer
Thought: you should always think about what to do
Action:
\`\`\`json
$JSON_BLOB
\`\`\`
Observation: the result of the action
... (this Thought/Action/Observation can repeat N times)
Thought: I now know the final answer
Action:
\`\`\`json
{{
"action": "Final Answer",
"action_input": "Final response to human"
}}
\`\`\``;
exports.SUFFIX = `Begin! Reminder to ALWAYS use the above format, and to use tools if appropriate.`;