{
  "blockworld": {
    "examples": [
      "[START OF THE EXAMPLE]\nGoal: The goal is to satisfy the following conditions: b1 is on b2., b2 is on b3.\nObservation: b1 is on the table.  b2 is on the table.  B3 is on the table. Robot arm is empty. The b1 is clear. The b2 is clear. The b3 is clear.\nThought: To achieve the goal of stacking b1 on top of b2 and b2 on top of b3, I need to make a comdition that I can pickup b3 and put it on the table, then I need to make a comdition that I can pickup b2 and put it on the b3, then I need to make a comdition that I can pickup b1 and put it on the b2. The condition \"I can pickup b3\", \"I can pickup b2\", \"I can pickup b1\", \"b3 is on the table\" has already been satisfied, I should start by picking up block b2. By doing so, I'll ensure that the arm is holding b2, allowing me to manipulate it freely. Since b2 is currently on the table and is clear, it's a suitable candidate for pickup. Once I successfully pick up b2, I can proceed with further actions to arrange the blocks according to the goal conditions.\nAction: pickup b2\nObservation: b1 is on the table.  B2 is on the table.  The b1 is clear. The b3 is clear. You are holding b2.\nThought: First, I need to check if the conditions for stacking are met. Since I'm holding block b2 and block b3 is clear, I can proceed with stacking. I'll place block b2 on top of block b3. This action satisfies the goal condition that b2 is on top of b3.\nAction: stack b2 b3\nObservation: b1 is on the table.  b1 is on b2. B3 is on the table. Robot arm is empty. The b1 is clear. The b2 is clear. \nAction: pickup b2. \nObservation: The action is not valid and therefore takes no effect. Please remember to satisfy the restriction of actions. You can also check valid actions. \n Action: check valid actions. \n Observation: valid actions are: pickup b1, unstack b2 b3.\nThought: With the failure of the previous attempt to pick up b2 and the current valid actions being pickup b1 or unstack b2 from b3, I opt to pick up b1. This choice allows for a new approach in rearranging the blocks to progress towards the goal configuration.\nAction: pickup b1\nObservation: b2 is on b3. B3 is on the table.  Robot arm is empty. The b2 is clear.  You are holding b1.\nThought: Since the goal is to have b1 on top of b2, and I'm currently holding b1 while b2 is clear and on top of b3, stacking b1 onto b2 is the appropriate action.\nAction: stack b1 b2\nObservation: b1 is on b2. b2 is on b3. B3 is on the table.  Robot arm is empty. The b1 is clear. The goal is satisfied.\n\n[END OF THE EXAMPLE]\n"
    ],
    "instruction": "The robot has four actions: pickup, putdown, stack, and unstack. The domain assumes a world where there are a set of blocks that can be stacked on top of each other, an arm that can hold one block at a time, and a table where blocks can be placed.\n    The actions defined in this domain include:\n    pickup <block>: allows the arm to pick up a block from the table if it is clear and the arm is empty. After the pickup action, the arm will be holding the block, and the block will no longer be on the table or clear.\n    putdown <block>: allows the arm to put down a block on the table if it is holding a block. After the putdown action, the arm will be empty, and the block will be on the table and clear.\n    stack <block> <block>: allows the arm to stack a block on top of another block if the arm is holding the top block and the bottom block is clear. After the stack action, the arm will be empty, the top block will be on top of the bottom block, and the bottom block will no longer be clear.\n    unstack <block> <block>: allows the arm to unstack a block from on top of another block if the arm is empty and the top block is clear. After the unstack action, the arm will be holding the top block, the top block will no longer be on top of the bottom block, and the bottom block will be clear.\n\n",
    "system_msg": "You are a master in planning."
  },
  "barman": {
    "examples": [
      "[START OF THE EXAMPLE]\nThe goal is to satisfy the following conditions: shot1 contains cocktail1. \nObservation: Cocktail1 part1 ingredient is ingredient1. Cocktail1 part2 ingredient is ingredient3. Cocktail2 part1 ingredient is ingredient2. Cocktail2 part2 ingredient is ingredient3. Cocktail3 part1 ingredient is ingredient1. Cocktail3 part2 ingredient is ingredient2. Dispenser1 dispenses ingredient1. Dispenser2 dispenses ingredient2. Dispenser3 dispenses ingredient3. Left hand is empty. Level l0 is next to level l1. Level l1 is next to level l2. Right hand is empty. Shaker1 is at empty level l0. Shaker1 is at level l0. Shaker1 is clean. Shaker1 is empty. Shaker1 is on the table. Shot1 is clean. Shot1 is empty. Shot1 is on the table. Shot2 is clean. Shot2 is empty. Shot2 is on the table. Shot3 is clean. Shot3 is empty. Shot3 is on the table. Shot4 is clean. Shot4 is empty. Shot4 is on the table.\nThought: Since cocktail1 ingredients are ingredient1 and ingredient3, I should choose one in shot1 and hold its dispenser, I can choose ingredient3 first.\nAction: fill-shot glass shot1 with ingredient3 with right and left holding dispenser3\n Observation: The action is not valid and therefore takes no effect. Please check valid actions. \nThought: I should check the valid action I can do.\nAction: check valid actions\nObservation: Valid actions are: right grasp shot1. , left grasp shot3. , left grasp shot1. , left grasp shot2. , right grasp shaker1. , right grasp shot4. , right grasp shot3. , right grasp shot2. , left grasp shaker1. , left grasp shot4. , check valid actions\nThought: To satisfy 'shot1 contains cocktail1', I should grasp shot1 first.\nAction: right grasp shot1.\nObservation: You are holding right. \nThought: Since cocktail1 ingredients are ingredient1 and ingredient3, I should choose in shot and hold its dispenser, I can choose ingredient3.\nAction: fill-shot glass shot1 with ingredient3 with right and left holding dispenser3\nObservation: Pour shot1 from a shot glass to a used shaker ingredient3 and Shot1 contains ingredient3. \nThought: Shot1 contains ingredient3, I should pour it to a shaker. \nAction: pour-shot-to-clean-shaker from a shot glass shot1 with ingredient3 to a clean shaker shaker1 with hand right from level l0 to level l1\nObservation:  Pour shot1 from a shot glass to a used shaker ingredient3 Shaker1 contains ingredient3. \nThought: The Shaker1 contains ingredient3 now. I should deal with ingredient1 now. To fill shot1 with ingredient1, I should clean shot1 first.\nAction: clean-shot glass shot1 with ingredient3 with hand right holding shot glass and left\nObservation:  Shot1 is clean. \nThought: Since cocktail1 ingredients are ingredient1 and ingredient3, and ingredient3 has been made, I should choose ingredient1 with its dispenser.\nAction: fill-shot glass shot1 with ingredient1 with right and left holding dispenser1\nObservation: Pour shot1 from a shot glass to a used shaker ingredient1 and Shot1 contains ingredient1. \nThought: Shot1 contains ingredient1, shaker1 contains ingredient3. I should pour ingredient1 to shaker1.\nAction: pour-shot-to-used-shaker from a shot glass shot1 with ingredient1 to a used shaker shaker1 with hand right from level l1 to level l2\nObservation: Pour shot1 from a shot glass to a used shaker ingredient1 Shaker1 contains ingredient1. Shaker1 contains ingredient3. Shaker1 is at level l2. Shaker1 is on the table. Shaker1 is unshaked. \nThought: I should clean shot1 and shake shaker1 since I'm holding shot1 now, I should clean shot1 first.\nAction: clean-shot glass shot1 with ingredient1 with hand right holding shot glass and left\nObservation: Shot1 is clean. \nThought: Shot1 will not use futher more, I should leave it.\nAction: right leave shot1\nObservation: Right hand is empty. \nThought: I should use shaker1 to combine 2 ingredients. First, I should grasp it.\nAction: right grasp shaker1\nObservation: You are holding right. \nThought: I should use shaker1 to combine 2 ingredients to cocktail1.\nAction: shake a cocktail cocktail1 with ingredient ingredient1 and ingredient ingredient3 in a shaker shaker1 with hand right and hand left\nObservation: Shaker1 is shaked.\nThought: I should pour cocktail1 to shot1 to finish ‘shot1 contains cocktail1’. \nAction: pour-shaker-to-shot to a shot glass cocktail1 the ingredient shot1 with hand right from shaker shaker1 from level l2 to level l1\nObservation: Shot1 contains cocktail1. The task is completed.\n[END OF THE EXAMPLE]\n"
    ],
    "instruction": "You are a robot barman that manipulates drink dispensers, shot glasses and a shaker. You have two hands. The goal is to find a plan that serves a desired set of drinks. Here are the actions you can do. Each valid action is a short phrase following fixed patterns:\n\n    <hand> grasp <container>: Grasp a container\n    <hand> leave <container>: Leave a container on the table\n    fill-shot <shot> <ingredient> <hand1> <hand2> <dispenser>: Fill a shot glass with an ingredient from dispenser\n    refill-shot <shot> <ingredient> <hand1> <hand2> <dispenser>: Refill a shot glass with an ingredient from dispenser\n    empty-shot <hand> <shot> <beverage>: Empty a shot glass\n    clean-shot <shot> <beverage> <hand1> <hand2>: Clean a shot glass\n    pour-shot-to-clean-shaker <shot> <ingredient> <shaker> <hand1> <level1> <level2>: Pour an ingredient from a shot glass to a clean shaker from level1 to level2\n    pour-shot-to-used-shaker <shot> <ingredient> <shaker> <hand1> <level1> <level2>: Pour an ingredient from a shot glass to a used shaker from level1 to level2\n    empty-shaker <hand> <shaker> <cocktail> <level1> <level2>: Empty a shaker containing cocktail from level1 to level2\n    clean-shaker <hand1> <hand2> <shaker>: Clean a shaker\n    shake <cocktail> <ingredient1> <ingredient2> <shaker> <hand1> <hand2>: Shake a cocktail in a shaker\n    pour-shaker-to-shot <beverage> <shot> <hand> <shaker> <level1> <level2>: Pour a beverage from a shaker to a shot glass from level1 to level2\n\n    You have the following restrictions on your actions:\n    You can only grasp a container if your hand is empty and it is on the table.\n    You can only leave a container if you are holding it.\n    You can only fill a shot glass if you are holding the shot glass, your other hand is empty, the shot glass is empty and clean.\n    You can only refill a shot glass if you are holding the shot glass, your other hand is empty, the shot glass is empty and has contained the saree ingredient before.\n    You can only empty a shot glass if you are holding the shot glass and it contains a beverage.\n    You can only pour from a shot glass to a clean shaker if you are holding the shot glass, the shot glass contains an ingredient, and the shaker is empty and clean.\n    You can only pour from a shot glass to a used shaker if you are holding the shot glass, the shot glass contains an ingredient, the shaker is unshaked and at a level not full.\n    You can only empty a shaker if you are holding the shaker and the shaker contains a shaked beverage.\n    You can only clean a shaker if you are holding the shaker, your other hand is empty, and the shaker is empty.\n    You can only shake a cocktail if you are holding the shaker, your other hand is empty, the shaker is unshaked, and the shaker contains two ingredients, and both ingredients are parts of a cocktail.\n    You can only pour from a shaker to a shot glass if you are holding the shaker, the shaker contains the cocktail, the shaker is shaked, and the shot glass is empty and clean.\n\n    Once you grasp a container, you are holding the container and the container is not on the table.\n    Once you leave a container on the table, your hand become empty.\n    Once you pour an ingredient from a shot glass to a shaker, the shaker contains the ingredient and is at one level above the previous level, and the shot glass becomes empty.\n    Once you empty a shaker, the shaker is at the empty level.\n    Once you shake, the two ingredients in the shaker become a cocktail.\n    Once you pour from a shaker to a shot glass, the shot glass contains the beverage in the shaker, the shot glass is no longer clean and empty, and the shaker is at one level below the previous level.\n\n",
    "system_msg": "You are a master in planning. "
  },
  "gripper": {
    "examples": [
      "[START OF THE EXAMPLE]\nThe goal is to satisfy the following conditions: ball1 is at roomb. , ball2 is at roomb. , ball3 is at roomb. \nObservation: Ball1 is a ball. Ball1 is at rooma. Ball2 is a ball. Ball2 is at rooma. Ball3 is a ball. Ball3 is at rooma. Left is a gripper. Left is free. Right is a gripper. Right is free. Robby is at rooma. Room rooma Room roomb\nThought: Ball1, Ball2 and Ball3 are at the rooma their final condition is at roomb. I am also at rooma, so I can pick up 2 balls with different arms. \nAction: Pick up ball1 at rooma with arm right.\nObservation: Ball1 is a ball. Ball1 is carrying right. Ball2 is a ball. Ball2 is at rooma. Ball3 is a ball. Ball3 is at rooma.  Left is a gripper. Left is free. Right is a gripper. Robby is at rooma. Room rooma Room roomb \nThought: I have one empty grippers. I should pickup another ball. \nAction: Pick up ball2 at rooma with arm left.\nObservation: Ball1 is a ball. Ball1 is carrying right. Ball2 is a ball. Ball2 is carrying left. Ball3 is a ball. Ball3 is at rooma. Left is a gripper. Right is a gripper. Robby is at rooma. Room rooma Room roomb \nThought: I should move to roomb.\nAction: Move from rooma to roomb\nObservation: Ball1 is a ball. Ball1 is carrying right. Ball2 is a ball. Ball2 is carrying left. Ball3 is a ball. Ball3 is at rooma. Left is a gripper. Right is a gripper. Robby is at roomb. Room rooma Room roomb\nThought: I should drop two balls.\nAction: drop ball1 at rooma with arm right\nObservation: The action is not valid and therefore takes no effect. Please remember to satisfy the restriction of actions. You can also check valid actions. \nThought: The action is not valid, I should check valid actions.\nAction: check valid actions\nObservation: Valid actions are: drop ball1 roomb right, drop ball2 roomb left, Move from roomb to rooma. , check valid actions\nThought: I should add right or left to drop balls.\nAction: drop ball1 roomb right\nObservation: Ball1 is a ball. Ball1 is at roomb. Ball2 is a ball. Ball2 is carrying left. Ball3 is a ball. Ball3 is at rooma. Left is a gripper. Right is a gripper. Right is free. Robby is at roomb. Room rooma Room roomb \nThought: I should drop ball2 roomb left.\nAction: drop ball2 roomb left\nObservation: Ball1 is a ball. Ball1 is at roomb. Ball2 is a ball. Ball2 is at roomb. Ball3 is a ball. Ball3 is at rooma. Left is a gripper. Left is free. Right is a gripper. Right is free. Robby is at roomb. Room rooma Room roomb\nThought: I should return rooma to pickup ball3.\nAction: move from roomb to rooma\nObservation: Ball1 is a ball. Ball1 is at roomb. Ball2 is a ball. Ball2 is at roomb. Ball3 is a ball. Ball3 is at rooma.Left is a gripper. Left is free. Right is a gripper. Right is free. Robby is at rooma. Room rooma Room roomb\nThought: I should  pickup ball3.\nAction: Pick up ball3 at rooma with arm right.\nObservation: Ball1 is a ball. Ball1 is at roomb. Ball2 is a ball. Ball2 is at roomb. Ball3 is a ball. Ball3 is carrying right.  Left is a gripper. Left is free. Right is a gripper. Robby is at rooma. Room rooma Room roomb\nThought: I should return roomb to drop ball3.\nAction: Move from rooma to roomb\nObservation: Ball1 is a ball. Ball1 is at roomb. Ball2 is a ball. Ball2 is at roomb. Ball3 is a ball. Ball3 is carrying right. Ball4 is a ball. Ball4 is at rooma. Left is a gripper. Left is free. Right is a gripper. Robby is at roomb. Room rooma Room roomb\nThought: I should drop ball3.\nAction: drop ball3 rooms right\nObservation: Ball1 is a ball. Ball1 is at roomb. Ball2 is a ball. Ball2 is at roomb. Ball3 is a ball. Ball3 is at roomb. Ball4 is a ball. Ball4 is at rooma. Left is a gripper. Left is free. Right is a gripper. Right is free. Robby is at roomb. Room rooma Room roomb. The task is completed.\n[END OF THE EXAMPLE]\n"
    ],
    "instruction": "You are a robot with a gripper that can move objects between different rooms. Your name is Robby.\n    There are three actions defined in this domain:\n    move <room1> <room2>: This action allows the robot to move from one room to another.The action has a single precondition, which is that the robot is currently in a room. The effect of this action is to move the robot to another room and to remove the fact that it is in the original room.\n    pick <obj> <room> <gripper>: This action allows the robot to pick up an object using the gripper. The action has three preconditions: (1) the object is located in a room (2) the robot is currently in the same room and (3) the gripper is free (i.e., not holding any object). The effect of this action is to update the state of the world to show that the robot is carrying the object using the gripper, the object is no longer in the room, and the gripper is no longer free.\n    drop <obj> <room> <gripper>: This action allows the robot to drop an object that it is carrying. The action has two preconditions: (1) the robot is currently carrying the object using the gripper, and (2) the robot is currently in a room. The effect of this action is to update the state of the world to show that the robot is no longer carrying the object using the gripper, the object is now located in the room, and the gripper is now free.\n\n",
    "system_msg": "You are a master in moving objects."
  },
  "tyreworld": {
    "examples": [
      "[START OF THE EXAMPLE]\nThe goal is to satisfy the following conditions: w1 is in boot. (Note you need to open boot first so that you can extract tools from it.)\nObservation: Boot is closed. Boot is unlocked. Hub the-hub1 is fastened. Hub the-hub1 is on the ground. Jack is in boot. Pump is in boot. R1 is in boot. The nut nuts1 on the hub the-hub1 is tight. Wheel r1 is intact. Wheel r1 is not inflated. Wheel w1 is on hub the-hub1. Wrench is in boot.\nThought: I should check what I can do.\nAction: check valid actions.\nObservation: Valid actions are: Open boot. Check valid actions. Look around. \nThought: Since boot is unlocked, I should directly open the boot.\nAction: Open boot.\nObservation: Boot is open. \nThought: I should loosen the w1, so I should fetch wrench first.\nAction: fetch wrench from boot\nObservation: You have wrench.\nThought: I should check what I can do.\nAction: check valid actions\nObservation: Valid actions are: Fetch pump from boot., Fetch r1 from boot., Put-away wrench in boot., Close boot., Fetch jack from boot., Loosen the nut nuts1 on the hub the-hub1., check valid actions\nThought: Since Wheel w1 is on hub the-hub1 and The nut nuts1 on the hub the-hub1 is tight, I should loosen the nut nuts1.\nAction: Loosen the nut nuts1 on the hub the-hub1.\nObservation: The nut nuts1 on the hub the-hub1 is loose. \nThought: I want to remove w1 from the-hub1, so I need jack.\nAction: fetch jack from boot\nObservation: You have jack. \nThought: I should jack-up the hub the-hub1.\nAction: jack-up the hub the-hub1\nObservation: Hub the-hub1 is not on the ground. \nThought: I want to remove w1 from the-hub1, so I need to undo the fastening of the nut nuts1.\nAction: Undo the fastening of the nut nuts1 on the hub the-hub1.\nObservation: Hub the-hub1 is unfastened. \nThought: I need to remove w1 from the-hub1.\nAction: Remove-wheel w1 from the hub the-hub1.\nObservation: You have w1. \nThought: I need to put w1 in boot. \nAction: Put-away w1 in boot\nObservation: W1 is in boot. Goal is completed.\n[END OF THE EXAMPLE]\n"
    ],
    "instruction": "Your goal is to replace flat tyres with intact tyres on the hubs. Remember to open boot first to get tools you need. Intact tyres should be inflated. The nuts should be tight on the hubs. The flat tyres, wrench, jack, and pump should be in the boot. The boot should be closed.\n    There are 13 actions defined in this domain:\n    open <container>: The precondition for this action is that the container is unlocked and closed. The effect of this action is that the container is open and not closed.\n    close <container>: The precondition for this action is that the container is open. The effect of this action is that the container is closed and not open.\n    fetch <object> <container>: The precondition for this action is that the object is inside the container and the container is open. The effect of this action is that the object is held by the agent and not inside the container.\n    put-away <object> <container>: The precondition for this action is that the object is held by the agent and the container is open. The effect of this action is that the object is inside the container and not held by the agent.\n    loosen <nut> <hub>: The precondition for this action is that the agent has a wrench, the nut on hub is tight, and the hub is on the ground. The effect of this action is that the nut on hub is loose and not tight.\n    tighten <nut> <hub>: The precondition for this action is that the agent has a wrench, the nut on hub is loose, and the hub is on the ground. The effect of this action is that the nut on hub is tight and not loose.\n    jack-up <hub>: This action represents the process of lifting a hub off the ground using a jack. It requires the agent to have a jack and for the hub to be on the ground. After performing this action, the hub will no longer be on the ground and the agent will no longer have the jack.\n    jack-down <hub>: This action represents the process of lowering a hub back to the ground from an elevated position using a jack. It requires the agent to have the hub off the ground. After performing this action, the hub will be back on the ground and the agent will have the jack.\n    undo <nut> <hub>: This action undo the fastening of a nut on a hub. The preconditions are the hub is not on the ground (i.e., it has been jacked up), the hub is fastened, the agent has a wrench and the nut is loose. The effects are the agent has the nut, the hub is unfastened, the hub is no longer loose and the hub is not fastened anymore.\n    do-up <nut> <hub>: This action fasten a nut on a hub. The preconditions are the agent has a wrench, the hub is unfastened, the hub is not on the ground (i.e., it has been jacked up) and the agent has the nut to be fastened. The effects are the nut is now loose on the hub, the hub is fastened, the hub is no longer unfastened and the agent no longer has the nut.\n    remove-wheel <wheel> <hub>: This action removes a wheel from a hub. It can only be performed if the hub is not on the ground, the wheel is currently on the hub, and the hub is unfastened. After the action is performed, the agent will have the removed wheel and the hub will be free, meaning that the wheel is no longer on the hub.\n    put-on-wheel <wheel> <hub>: This action puts a wheel onto a hub. It can only be performed if the agent has the wheel, the hub is free, the hub is unfastened, and the hub is not on the ground. After the action is performed, the wheel will be on the hub, the hub will no longer be free, and the agent will no longer have the wheel.\n    inflate <wheel>: This action inflates a wheel using a pump. It can only be performed if the agent has a pump, the wheel is not inflated, and the wheel is intact. After the action is performed, the wheel will be inflated.\n\n",
    "system_msg": "You are a master in car repair."
  }
}
