purpose: "Image Observatio+ICL"
domain: MiniGrid-DoorKey-5x5-v0
date: "2025 July 10"
base_prompt: "You need to solve Minigrid Doorkey.
Minigrid Doorkey involves crossing a gridworld, where you need to pick up the key, unlock the door and reach the goal. Do not hit the wall.
The state is depicted in an image. 
This is you facing upwards. <PATH>/DoorKey/UP.png</PATH>
This is you facing right. <PATH>/DoorKey/RIGHT.png</PATH>
This is you facing down. <PATH>/DoorKey/DOWN.png</PATH>
This is you facing left. <PATH>/DoorKey/LEFT.png</PATH>
This is an empty tile. <PATH>/DoorKey/EMPTY.png</PATH>
This is a key. <PATH>/DoorKey/KEY.png</PATH>
This is a locked door. <PATH>/DoorKey/DOOR_LOCKED.png</PATH>
This is an unlocked door. <PATH>/DoorKey/DOOR_UNLOCKED.png</PATH>
This is your goal. <PATH>/DoorKey/GOAL.png</PATH>
This is a wall. <PATH>/DoorKey/WALL.png</PATH>
The possible actions are:
1. TURN LEFT, changing the direction to left
2. TURN RIGHT, changing the direction to right
3. MOVE FORWARD, moving forwards for one tile
4. PICK UP THE KEY, picking up the key, this is only possible when you are facing the tile with key on it 
5. UNLOCK THE DOOR, this action is only possible when you have the key."

if_optimal_prompt_cot: "
Is action ACTION the best action you can take? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"feedback\": <FEEDBACK>}
Where <FEEDBACK> is one of \"YES\" or \"NO\", <REASONING> is a string of your thinking steps.
"
action_advising_base_prompt_cot: "
Which action do you choose? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"action\": <ACTION>}
Where <ACTION> is one of \"TURN LEFT\", \"TURN RIGHT\", \"MOVE FORWARD\", \"PICK UP THE KEY\" or \"UNLOCK THE DOOR\", <REASONING> is a string of your thinking steps.
"

preference_base_prompt_cot: "
Given ACTION1 or ACTION2, which action is better? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"preference\": <PREFERENCE>}
Where <PREFERENCE> is one of \"FIRST\" or \"SECOND\", <REASONING> is a string of your thinking steps.
"



icl_prompt_goal_advising: ""
icl_prompt_action_advising: "
\n Below are examples about reasoning over the best action. \n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs1.png</PATH>
The door is locked. You  have the key. 
Which action do you choose? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"action\": <ACTION>}
Where <ACTION> is one of \"TURN LEFT\", \"TURN RIGHT\", \"MOVE FORWARD\", \"PICK UP THE KEY\" or \"UNLOCK THE DOOR\", <REASONING> is a string of your thinking steps.
\n
Answer:
{\"reasoning\": \"The agent is one tile below and to the left of the door, facing up. We first need to move forward to get adjacent to the door tile. Then we can turn to face the door and unlock it. Therefore, the best action now is to move forward.\", \"action\": \"MOVE FORWARD\"}
\n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs2.png</PATH>
The door is unlocked. You  have the key. 
Which action do you choose? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"action\": <ACTION>}
Where <ACTION> is one of \"TURN LEFT\", \"TURN RIGHT\", \"MOVE FORWARD\", \"PICK UP THE KEY\" or \"UNLOCK THE DOOR\", <REASONING> is a string of your thinking steps.
\n
Answer: {\"reasoning\": \"The agent is facing right into a wall, so moving forward is not possible. To reach the goal, the agent must turn around and move through the empty tiles. The first step is to turn right (then toward the goal).\", \"action\": \"TURN RIGHT\"}
\n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs3.png</PATH>
The door is locked. You do not have the key. 
Which action do you choose? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"action\": <ACTION>}
Where <ACTION> is one of \"TURN LEFT\", \"TURN RIGHT\", \"MOVE FORWARD\", \"PICK UP THE KEY\" or \"UNLOCK THE DOOR\", <REASONING> is a string of your thinking steps.
\n
Answer:{\"reasoning\": \"We are currently facing left and cannot move forward because there is a wall to our left. The key is located below us, so the first step is to turn left to face down, allowing us to move toward the key.\", \"action\": \"TURN LEFT\"}
"
icl_prompt_delta_action: ""
icl_prompt_preference: "
\n Below are examples about reasoning over the actions given a state. \n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs4.png</PATH>
The door is locked. You do not have the key. 
Given MOVE FORWARD or TURN RIGHT, which action is better? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"preference\": <PREFERENCE>}
Where <PREFERENCE> is one of \"FIRST\" or \"SECOND\", <REASONING> is a string of your thinking steps.
\n
Answer: {\"reasoning\": \"We want to get the key, which is above us, so we should move forward and head to it. Turning right points us toward a wall, which doesn’t help.\", \"preference\": \"FIRST\"}
\n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs5.png</PATH>
The door is unlocked. You  have the key. 
Given TURN LEFT or MOVE FORWARD, which action is better? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"preference\": <PREFERENCE>}
Where <PREFERENCE> is one of \"FIRST\" or \"SECOND\", <REASONING> is a string of your thinking steps.
\n
Answer: {\"reasoning\": \"We want to reach the goal to the right. Turning left would face us upward where there’s a wall, which doesn’t help. Moving forward brings us closer to the goal.\", \"preference\": \"SECOND\"}
\n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs6.png</PATH>
The door is locked. You do not have the key. 
Given TURN RIGHT or PICK UP THE KEY, which action is better? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"preference\": <PREFERENCE>}
Where <PREFERENCE> is one of \"FIRST\" or \"SECOND\", <REASONING> is a string of your thinking steps.
\n
Answer: 
{\"reasoning\": \"We cannot pick up the key because we are not facing it. Turning right helps us rotate toward the key so we can eventually pick it up.\", \"preference\": \"FIRST\"}
"
icl_prompt_binary_feedback: "
Below are examples about how to judge an action. \n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs7.png</PATH>
The door is locked. You do not have the key. 
Is action MOVE FORWARD the best action you can take? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"feedback\": <FEEDBACK>}
Where <FEEDBACK> is one of \"YES\" or \"NO\", <REASONING> is a string of your thinking steps.
\n
Answer: {\"reasoning\": \"The agent is facing a wall, so moving forward does nothing and fails to progress toward picking up the key. A turn to face the key is a better action.\", \"feedback\": \"NO\"}
\n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs8.png</PATH>
The door is locked. You  have the key. 
Is action MOVE FORWARD the best action you can take? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"feedback\": <FEEDBACK>}
Where <FEEDBACK> is one of \"YES\" or \"NO\", <REASONING> is a string of your thinking steps.
\n
Answer: {\"reasoning\": \"You already have the key, so the immediate goal is to move adjacent to the locked door and unlock it. The tile directly ahead is free, and moving forward places you in position to turn and unlock the door. Therefore, moving forward is the best action.\", \"feedback\": \"YES\"}
\n
Question: You are in the following state represented in image:
<PATH>/DK_ICL_IMAGE/obs5.png</PATH>
The door is unlocked. You  have the key. 
Is action TURN LEFT the best action you can take? Please think step by step.
Only give the answer in a new line in JSON format:
{\"reasoning\": <REASONING>, \"feedback\": <FEEDBACK>}
Where <FEEDBACK> is one of \"YES\" or\"NO\", <REASONING> is a string of your thinking steps.
\n
Answer:
{\"reasoning\": \"The agent is facing right and needs to move toward the goal on its right and then turn down. Turning left would make the agent face upwards into a wall. Moving forward is the better move.\", \"feedback\": \"NO\"}
"

