{"messages": [{"role": "system", "content": [{"text": "You are a planning expert tasked with developing a world model for planning based on a user instruction.\n\n--- \n\n<!-- when generating content for the sections listed below, follow the specified format exactly. You can leaf out sections you don't need. -->\n### Explanation\n<!-- task specific explanation and chain-of-thought reasoning -->\n\n### Change/Add Action(s)\n1. {action-name-1}: {(add|edit|delete)} \n    - Description: {description what happens during the action}\n    - PDDL Definition:\n        ```pddl\n        (:action {pddl_action_name}\n            :parameters {pddl_action_parameters}\n            :precondition {pddl_action_preconds}\n            :effect {pddl_action_effects}\n        )\n        ```\n\n### Change/Add Predicate Definitions\n<!-- `state` predicates describe the current situation of objects in the world. Their description must specify the conditions under which they hold, so a classifier can later decide from perception data (e.g., 6D poses) whether the predicate is true.-->\n- ({predicate_name} {predicate_args...}): {state|other}. {predicate_description}\n\n### Change Initial State\n<!-- add predicates that should be changed, without text, leave 'None' if no change -->\n{predicate_4}: {true|false|remove}\n{predicate_8}: {true|false|remove}\n\n### Change Goal State\n<!-- add predicates that should be changed, without text, leave 'None' if no change -->\n{predicate_7}: {true|false|remove}"}]}, {"role": "user", "content": [{"text": "### User Instruction\nassemble the lamp\n\n### Domain Knowledge\nThe environment consists of a single Franka Emika Panda robot arm with its standard two-finger gripper, operating on a tabletop workspace. Multiple furniture parts (e.g., components of a lamp, table, or chair) are placed on the table. When parts need to be aligned, this means that their xy position and roll and pitch orientations must be similar, while their yaw orientation does not need to be aligned.\n\n### Predicates\n- (assembled ?obj1 - part ?obj2 - part). other: Evaluates whether obj1 has been assembled with obj2 the way they should be, e.g. when obj1 has been screwed into obj2, or obj1 has been put on top of obj2.\n\n### Actions\n\n\n### Types\nrobot table part - object\n\n### Objects\narm - robot table - table lamp_base lamp_bulb lamp_hood - part\n\n### Skill Library\n- def hover_above_part(part: str):\n- def set_gripper_around_part(part: str):\n- def move_linear_up():\n- def open_gripper():\n- def close_gripper():\n- def align_orientation_for_assembly(held_part: str, fixed_part: str):\n- def screw_touching_parts_together(held_part: str, fixed_part: str):\n- def move_linear_down_until_touching(held_part: str, fixed_part: str):\n\n### Initial State\ninit state will be replaced\n\n### Your Task\n1. Define the goal: Based on the user instruction, create a PDDL goal that reflects the objective the user wants to accomplish. Ignore temporal instructions.\n2. List of predicates: Inspect the predicates that will be used to describe the state of the world and the relationships between entities in the domain.\n3. Define actions: \n    - Based on the goal and available skills in the skill library, define a set of PDDL actions that enable planning toward the goal.\n    - Preferably define high-level actions that abstract over one or more low-level skills to support hierarchical planning, but don't add object specific actions, e.g. `unstack-block-2`.\n    - Each PDDL action should:\n        - Have a clear and descriptive name\n        - Include a general-purpose description (not instance-specific)\n        - Include a PDDL definition: (:action <action_name> :parameters <parameters> :precondition <precondition> :effect <effect>)\n    - You are encouraged to:\n        - Define high-level composite actions when they simplify planning.\n        - Define individual PDDL actions for each skill you intend to use that has no PDDL action yet.\n        - If PDDL actions are already given in the user prompt, use them and only add new ones if necessary.\n        - Avoid unnecessary actions \u2014 only include those essential to achieving the goal.\n        - Don't create object specific actions, e.g. `switch-block-2-and-block-3`, but rather generate a general action `switch-blocks`."}]}, {"role": "assistant", "content": [{"text": "### Explanation\nThe task is to assemble a lamp which consists of parts such as lamp_base, lamp_bulb, and lamp_hood. The predicate `(assembled ?obj1 ?obj2)` captures the successful assembly relationship between parts. The robot can pick, align, and screw parts together using provided skills. The goal is to have these parts assembled correctly, which may involve hierarchical actions like picking a part, aligning it on another, and screwing them together. These should be generalized actions applicable to any parts.\n\n### Actions\n1. assemble-part-to-part: add\n    - Description: Assemble one lamp part to another by picking the part, aligning orientations, moving them close, and screwing them together to establish the assembled relation.\n    - PDDL Definition:\n        ```pddl\n        (:action assemble-part-to-part\n            :parameters (?held - part ?fixed - part)\n            :precondition (not (assembled ?held ?fixed))\n            :effect (assembled ?held ?fixed)\n        )        \n        ```\n\n### Goal State\n(and (assembled lamp_bulb lamp_base) (assembled lamp_hood lamp_bulb))\n\n"}]}]}