[{"role": "system", "content": "You are a franka panda robot operating in an environment with the following state:\n\nTABLE_BOUNDS = [[-0.5, 0.5], [-0.5, 0.5], [0, 0]]  # X Y Z\nTABLE_CENTER = [0, 0, 0]\n\n@dataclass\nclass Frame:\n    name: str\n    x_pos: float\n    y_pos: float\n    z_pos: float\n    x_rot: float\n    y_rot: float\n    z_rot: float\n    size: float | list[float]\n    color: list[float]\n\n\n@dataclass\nclass BridgeState(State):\n    frames: List[Frame] = field(default_factory=list)\n\n    def getFrame(self, name: str) -> Frame:\n        for f in self.frames:\n            if f.name == name:\n                return f\n        return None\n        \n\nYou have access to the following set of skills expressed as pddl predicates followed by descriptions. \nYou have no other skills you can use, and you must exactly follow the number of inputs described below.\nThe coordinate axes are x, y, z where x is left/right from the robot base, y the distance from the robot base, and z is the height off the table.\n\nAction(\"pick\", [frame_name], pick_axis)\nGrab the frame with name frame_name. Aligns the gripper x-axis (the axis in which the fingers move) with the pick_axis, if set to None, the all axis are checked and which ever one is feasible gets used.\n\nAction(\"place_sr\", [x, y, z, rotated, yaw])\nPlace grasped object at pose x, y, z, with a specific yaw angle. If the rotated boolean is set to True, it will rotate the block 90 degrees around the pick axis. The yaw, which is in radians, determines the angle at which the object is rotated with respect to the object's current local axis pointing upwards. If z is set to None, the object gets plazed on the table. If yaw is set to None, there are no restrictions to the yaw angle.\n\nAction(\"push_motion\", [start_x, start_y, end_x, end_y])\nPerform a push motion along the straight 2D path defined by the start and end points.\n\nYour goal is to generate two things:\n\nFirst, generate a python function named `gen_plan` that can take any continuous inputs or lists of continuous inputs\nand return the entire plan with all steps included where the parameters to the plan depend on the inputs.\n\nSecond, generate a python function `gen_initial_guess` that returns a set of initial guesses for the continuous input parameters, it can also return a lis of values. The number of initial guesses in the\n`gen_initial_guess` should exactly match the number of inputs to the function excluding the state input.\n\nThe main function should be named EXACTLY `gen_plan` and the initial_guess of the main function should be named EXACTLY `gen_initial_guess`. Do not change the names. Do not create any additional classes or overwrite any existing ones.\nAside from the inital state all inputs to the `gen_plan` function MUST NOT be of type List or Dict. List and Dict inputs to `gen_plan` are not allowed.\n\nAdditionally, the input to `gen_initial_guess` must be exactly the `initial:BridgeState` argument, even if this isn't explicitly used within the function!\nWHEN PERFORMING A PUSH, YOU NEED TO ALWAYS DEFINE SOME OFFSETS FOR THE START AND END POINTS OF SAID PUSH IN THE gen_initial_guess FUNCTION.\nIF THERE ARE MULTIPLE PUSHES, A UNIQUE OFFSET MUST BE PROVIDED FOR EACH ONE \u2014 I.E., gen_initial_guess MUST RETURN A LIST OF OFFSET SETS, ONE PER PUSH ACTION.\nOffsets should be of the form [start_x_offset, start_y_offset, end_x_offset, end_y_offset].\n\n\n"}, {"role": "user", "content": "initial=BridgeState(frames=[Frame(name=\"block_red\", x_pos=0.0, y_pos=0.0, z_pos=0.71, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.04, 0.04, 0.12, 0.0], color=\"[255, 0, 0]\"), Frame(name=\"block_green\", x_pos=0.15, y_pos=0.0, z_pos=0.71, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.04, 0.04, 0.12, 0.0], color=\"[0, 255, 0]\"), Frame(name=\"block_blue\", x_pos=0.3, y_pos=0.0, z_pos=0.71, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.04, 0.04, 0.12, 0.0], color=\"[0, 0, 255]\"), Frame(name=\"l_gripper\", x_pos=0.0, y_pos=0.28, z_pos=1.27, x_rot=0.5, y_rot=-0.0, z_rot=1.29, size=[0.03], color=\"[229, 229, 229]\"), Frame(name=\"table\", x_pos=0.0, y_pos=0.0, z_pos=0.6, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[1.0, 1.0, 0.1, 0.02], color=\"[76, 76, 76]\")])\nGoal: Build a bridge. A bridge is defined as two vertical blocks next to each other and one horizontal block on top of them.\n\n\n"}, {"role": "assistant", "content": "```python\ndef gen_plan(state: BridgeState, center: list, yaw: float, slack: float):\n    \n    import numpy as np\n    \n    # Build the bridge\n    actions = []\n\n    block_size_z = state.getFrame(\"block_red\").size[2]\n    \n    # Red #\n    pos_x = np.cos(yaw) * block_size_z * .5 + center[0]\n    pos_y = -np.sin(yaw) * block_size_z * .5 + center[1]\n    actions.append(Action(\"pick\", [\"block_red\", None]))\n    actions.append(Action(\"place_sr\", [pos_x, pos_y, None, None, None]))\n\n    # Green #\n    pos_x = -np.cos(yaw) * block_size_z * .5 + center[0]\n    pos_y = np.sin(yaw) * block_size_z * .5 + center[1]\n    actions.append(Action(\"pick\", [\"block_green\", None]))\n    actions.append(Action(\"place_sr\", [pos_x, pos_y, None, None, None]))\n\n    # Blue #\n    pos_z = block_size_z + slack\n    actions.append(Action(\"pick\", [\"block_blue\", None]))\n    actions.append(Action(\"place_sr\", [center[0], center[1], pos_z, True, yaw]))\n    \n    return actions\n\ndef gen_initial_guess(initial:BridgeState):\n    guess = {\n        \"center\": [.2, .2], # BBO initial value\n        \"yaw\": .0,\n        \"slack\": .03,\n    }\n    return guess\n```\n\n\n"}, {"role": "user", "content": "initial=BridgeState(frames=[Frame(name=\"big_red_block\", x_pos=-0.2, y_pos=0.3, z_pos=0.7, x_rot=-0.0, y_rot=-0.0, z_rot=1.57, size=[0.1, 0.2, 0.1, 0.0], color=\"[204, 51, 63]\"), Frame(name=\"target_pose\", x_pos=0.4, y_pos=0.3, z_pos=0.7, x_rot=-0.0, y_rot=0.0, z_rot=-2.51, size=[0.1, 0.2, 0.1, 0.0], color=\"[0, 255, 0]\")])\nGoal: Push the red block to the target pose.\n\n\n"}, {"role": "assistant", "content": "```python\ndef gen_plan(state: BridgeState, push_offsets: list):\n    \n    import numpy as np\n\n    # Build the block towards the target\n    actions = []\n    red_box = state.getFrame(\"big_red_block\")\n    target = state.getFrame(\"target_pose\")\n    dir = np.array([target.x_pos, target.y_pos]) - np.array([red_box.x_pos, red_box.y_pos])\n    dir_mag = np.linalg.norm(dir)\n    if dir_mag != 0;\n        dir_normed = dir / dir_mag\n    else:\n        dir_normed = np.zeros(2)\n\n    # First push start\n    offset_mag = max(red_box.size[:2]) * 3\n    a_start_x = red_box.x_pos - dir_normed[0]*offset_mag + push_offsets[0][0]\n    a_start_y = red_box.y_pos - dir_normed[1]*offset_mag + push_offsets[0][1]\n    \n    # First push end\n    a_end_x = target.x_pos + push_offsets[0][2]\n    a_end_y = target.x_pos + push_offsets[0][3]\n    \n    # Second push start\n    b_start_x = target.x_pos - dir_normed[0]*.2 + push_offsets[1][0]\n    b_start_y = target.y_pos - dir_normed[1]*.2 + push_offsets[1][1]\n    \n    # Second push end\n    b_end_x = target.x_pos + push_offsets[1][2]\n    b_end_y = target.x_pos + push_offsets[1][3]\n\n    # First Push #\n    actions.append(Action(\"push_motion\", [a_start_x, a_start_y, a_end_x, a_end_y]))\n\n    # Second Push (For adjusting position) #\n    actions.append(Action(\"push_motion\", [b_start_x, b_start_y, b_end_x, b_end_y]))\n\n    return actions\n\ndef gen_initial_guess(initial: BridgeState):\n    return {\n        \"push_offsets\": [[.0, .0, .0, .0]] * 2, # BBO initial value\n    }\n```\n\n"}, {"role": "user", "content": "initial=BridgeState(frames=[Frame(name=\"block0\", x_pos=-0.17, y_pos=0.11, z_pos=0.7, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.08, 0.08, 0.08, 0.0], color=\"[95, 146, 233]\"), Frame(name=\"block1\", x_pos=-0.2, y_pos=-0.04, z_pos=0.7, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.08, 0.08, 0.08, 0.0], color=\"[200, 67, 86]\"), Frame(name=\"block2\", x_pos=0.18, y_pos=0.25, z_pos=0.7, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.08, 0.08, 0.08, 0.0], color=\"[215, 93, 12]\"), Frame(name=\"block3\", x_pos=-0.02, y_pos=0.37, z_pos=0.7, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.08, 0.08, 0.08, 0.0], color=\"[79, 117, 209]\"), Frame(name=\"block4\", x_pos=-0.11, y_pos=0.3, z_pos=0.7, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.08, 0.08, 0.08, 0.0], color=\"[161, 152, 35]\"), Frame(name=\"block5\", x_pos=-0.0, y_pos=0.04, z_pos=0.7, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.08, 0.08, 0.08, 0.0], color=\"[7, 239, 65]\"), Frame(name=\"block6\", x_pos=-0.07, y_pos=0.16, z_pos=0.7, x_rot=-0.0, y_rot=0.0, z_rot=-0.0, size=[0.08, 0.08, 0.08, 0.0], color=\"[251, 239, 148]\")])\nGoal: Push the blocks so that they form a straight line."}, {"role": "assistant", "content": "```python\ndef gen_plan(state: BridgeState, line_angle: float, push_offsets: list):\n    import numpy as np\n\n    actions = []\n    block_names = [f.name for f in state.frames if f.name.startswith(\"block\")]\n    block_centers = np.array([[state.getFrame(name).x_pos, state.getFrame(name).y_pos] for name in block_names])\n\n    # Define unit direction vector for the desired line\n    direction = np.array([np.cos(line_angle), np.sin(line_angle)])\n\n    # Project each block center onto the direction vector to determine order\n    projections = block_centers @ direction\n    sorted_indices = np.argsort(projections)\n    sorted_blocks = [block_names[i] for i in sorted_indices]\n\n    # Determine spacing: use average block size plus some gap\n    block_size = state.getFrame(sorted_blocks[0]).size[0]  # Assuming square footprint\n    spacing = block_size + 0.01\n\n    # Start from average position as center\n    center = np.mean(block_centers, axis=0)\n    num_blocks = len(sorted_blocks)\n\n    for i, block_name in enumerate(sorted_blocks):\n        offset = (i - (num_blocks - 1) / 2.0) * spacing\n        target_pos = center + direction * offset\n\n        # Push vector from current to target\n        current_pos = np.array([state.getFrame(block_name).x_pos, state.getFrame(block_name).y_pos])\n        push_dir = target_pos - current_pos\n        push_dir_mag = np.linalg.norm(push_dir)\n        if push_dir_mag != 0:\n            push_dir /= push_dir_mag\n        else:\n            push_dir = np.zeros(2)\n\n        # Define start and end points for push using provided offset\n        offset_vals = push_offsets[i]\n        start = current_pos - push_dir * block_size * 2 + offset_vals[:2]\n        end = target_pos + offset_vals[2:]\n\n        actions.append(Action(\"push_motion\", [start[0], start[1], end[0], end[1]]))\n\n    return actions\n\n\ndef gen_initial_guess(initial: BridgeState):\n    block_names = [f.name for f in initial.frames if f.name.startswith(\"block\")]\n    num_blocks = len(block_names)\n    \n    # Generate distinct offset guesses for each block\n    push_offsets = [[0.0, 0.0, 0.0, 0.0] for _ in range(num_blocks)]\n\n    return {\n        \"line_angle\": 0.0,  # Aligned with x-axis initially\n        \"push_offsets\": push_offsets,\n    }\n```"}, {"role": "user", "content": [{"type": "input_text", "text": "The best parameters that were found based on your solution are [-0.029441907312538575, -0.08961463758167725, -0.03704727954708138, -0.02502171683618844, 0.04754836339332536, -0.06729013364568401, -0.008967445056745637, -0.03192531497873054, 0.0010476319525209382, -0.02597900713565023, -0.01722575504676371, -0.015622277198740958, -0.01689870083475253, 0.053592047750294455, 0.010529542363308695, -0.05727000851278028, -0.03950582698516437, -0.03356099106543936, -0.019077726352465078, 0.04612284952800906, -0.0068769026263875484, 0.011704871178680992, 0.016084594841365377, -0.0653260642204935, -0.038202468945788944, 0.005146397881314242, 0.05135272848092095, -0.10028398031517566, 0.029691771173546155] and have a cost of 108.02981121797826, which is above the target cost of <= 1 Please revise your solution accordingly.The final state after running the best solution is: BridgeState(frames=[Frame(name=\"block0\", x_pos=-0.2, y_pos=0.06, z_pos=0.69, x_rot=0.0, y_rot=-0.0, z_rot=0.28, size=[0.08, 0.08, 0.08, 0.0], color=\"[95, 146, 233]\"), Frame(name=\"block1\", x_pos=-0.2, y_pos=-0.04, z_pos=0.69, x_rot=0.0, y_rot=-0.0, z_rot=-0.06, size=[0.08, 0.08, 0.08, 0.0], color=\"[200, 67, 86]\"), Frame(name=\"block2\", x_pos=0.2, y_pos=0.23, z_pos=0.69, x_rot=0.0, y_rot=-0.0, z_rot=0.3, size=[0.08, 0.08, 0.08, 0.0], color=\"[215, 93, 12]\"), Frame(name=\"block3\", x_pos=-0.01, y_pos=0.29, z_pos=0.69, x_rot=-0.0, y_rot=-0.0, z_rot=-1.16, size=[0.08, 0.08, 0.08, 0.0], color=\"[79, 117, 209]\"), Frame(name=\"block4\", x_pos=-0.09, y_pos=0.25, z_pos=0.69, x_rot=0.0, y_rot=-0.0, z_rot=0.67, size=[0.08, 0.08, 0.08, 0.0], color=\"[161, 152, 35]\"), Frame(name=\"block5\", x_pos=0.06, y_pos=0.02, z_pos=0.69, x_rot=0.0, y_rot=-0.0, z_rot=0.1, size=[0.08, 0.08, 0.08, 0.0], color=\"[7, 239, 65]\"), Frame(name=\"block6\", x_pos=-0.12, y_pos=0.11, z_pos=0.69, x_rot=0.0, y_rot=-0.0, z_rot=-0.18, size=[0.08, 0.08, 0.08, 0.0], color=\"[251, 239, 148]\")]). Image of final state after attempt 0"}, {"type": "input_image", "image_url": "data:image/jpeg;base64,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"}]}]