{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\kvriz\\miniconda3\\envs\\autogen\\Lib\\site-packages\\opentelemetry\\proto\\collector\\trace\\v1\\trace_service_pb2_grpc.py:26: RuntimeWarning: The grpc package installed is at version 1.62.3, but the generated code in opentelemetry/proto/collector/trace/v1/trace_service_pb2_grpc.py depends on grpcio>=1.63.2. Please upgrade your grpc module to grpcio>=1.63.2 or downgrade your generated code using grpcio-tools<=1.62.3. This warning will become an error in 1.65.0, scheduled for release on June 25, 2024.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "import sdl_agents\n",
    "from sdl_agents import AutoGenSystem"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[33madmin\u001b[0m (to chat_manager):\n",
      "\n",
      "Write the execution code to pick up a substrate and move it to the coating station.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: code_writer_agent\n",
      "\u001b[0m\n",
      "\u001b[33mcode_writer_agent\u001b[0m (to chat_manager):\n",
      "\n",
      "To pick up a substrate and move it to the coating station using the N9 robotic system, you can use the following code:\n",
      "\n",
      "```python\n",
      "# filename: move_substrate_to_coating_station.py\n",
      "\n",
      "import loca\n",
      "import robotics as ro\n",
      "\n",
      "# Initialize the controller\n",
      "c9 = ro.system.init('controller')\n",
      "\n",
      "# Pick up the Bernoulli substrate gripper tool\n",
      "c9.tool = 'substrate_tool'\n",
      "\n",
      "# Activate the vacuum on the Bernoulli gripper to pick up substrates\n",
      "c9.set_output('substrate_tool', True)\n",
      "\n",
      "# Move to the substrate rack and pick up a substrate\n",
      "c9.position = loca.substrate_rack_seq[0, 0]  # Move to the top-left position of the substrate rack\n",
      "\n",
      "# Move the substrate to the coating station\n",
      "c9.position = loca.s_coater\n",
      "\n",
      "# Deactivate the vacuum to release the substrate at the coating station\n",
      "c9.set_output('substrate_tool', False)\n",
      "\n",
      "# Drop off the Bernoulli substrate gripper tool\n",
      "c9.tool = None\n",
      "```\n",
      "\n",
      "This script initializes the robot controller, picks up a substrate from the substrate rack, moves it to the coating station, and then releases it. Save this code in a file named `move_substrate_to_coating_station.py` and execute it. TERMINATE\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: code_reviewer_agent\n",
      "\u001b[0m\n",
      "\u001b[33mcode_reviewer_agent\u001b[0m (to chat_manager):\n",
      "\n",
      "The code provided by the code writer agent contains several issues that need to be addressed:\n",
      "\n",
      "1. **Library Imports**: The code imports `loca` and `robotics as ro`, but it is unclear if these are the correct libraries or if they are part of the allowed libraries. Ensure that the libraries used are part of the approved list.\n",
      "\n",
      "2. **Tool Activation and Deactivation**: The code uses `c9.set_output('substrate_tool', True)` and `c9.set_output('substrate_tool', False)` to activate and deactivate the tool. Verify if these are the correct methods for controlling the tool.\n",
      "\n",
      "3. **Positioning**: The code uses `c9.position = loca.substrate_rack_seq[0, 0]` and `c9.position = loca.s_coater` to move the robot. Ensure that these are the correct methods and that the positions are defined correctly.\n",
      "\n",
      "4. **Tool Handling**: The code sets `c9.tool = 'substrate_tool'` and `c9.tool = None` to pick up and drop off the tool. Verify if these are the correct methods for tool handling.\n",
      "\n",
      "5. **Error Handling**: The code does not include any error handling. Consider adding error handling to manage potential issues during execution.\n",
      "\n",
      "6. **Documentation**: Add comments or documentation to explain the purpose of each step in the code.\n",
      "\n",
      "Please review the code and make the necessary corrections based on the approved libraries and functions.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: code_writer_agent\n",
      "\u001b[0m\n",
      "\u001b[33mcode_writer_agent\u001b[0m (to chat_manager):\n",
      "\n",
      "Thank you for the feedback. Let's address the issues and ensure the code is correct and follows the expected procedures for the N9 robotic system.\n",
      "\n",
      "Here's the revised code with corrections and additional comments:\n",
      "\n",
      "```python\n",
      "# filename: move_substrate_to_coating_station.py\n",
      "\n",
      "import loca\n",
      "import robotics as ro\n",
      "\n",
      "# Initialize the controller\n",
      "c9 = ro.system.init('controller')\n",
      "\n",
      "# Pick up the Bernoulli substrate gripper tool\n",
      "c9.tool = 'substrate_tool'\n",
      "\n",
      "# Activate the vacuum on the Bernoulli gripper to pick up substrates\n",
      "c9.set_output('substrate_tool', True)\n",
      "\n",
      "# Move to the substrate rack and pick up a substrate\n",
      "c9.position = loca.substrate['new'][0]  # Move to the first 'new' substrate position\n",
      "\n",
      "# Move the substrate to the coating station\n",
      "c9.position = loca.s_coater\n",
      "\n",
      "# Deactivate the vacuum to release the substrate at the coating station\n",
      "c9.set_output('substrate_tool', False)\n",
      "\n",
      "# Drop off the Bernoulli substrate gripper tool\n",
      "c9.tool = None\n",
      "\n",
      "# Error handling can be added here if needed\n",
      "```\n",
      "\n",
      "### Key Changes and Considerations:\n",
      "- **Positioning**: The code now uses `loca.substrate['new'][0]` to access the first 'new' substrate position. Ensure that this is the correct way to access the substrate positions.\n",
      "- **Tool Handling**: The tool is picked up and dropped off using `c9.tool = 'substrate_tool'` and `c9.tool = None`, which should be correct based on the provided context.\n",
      "- **Error Handling**: Consider adding error handling if there are specific errors you anticipate during execution.\n",
      "\n",
      "Please save this code in a file named `move_substrate_to_coating_station.py` and execute it. If there are any issues, please let me know. TERMINATE\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: admin\n",
      "\u001b[0m\n",
      "\u001b[31m\n",
      ">>>>>>>> NO HUMAN INPUT RECEIVED.\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "# Without memory\n",
    "autogen_system = AutoGenSystem(\n",
    "    llm_type='gpt4o',\n",
    "    polybot_file_path='n9_robot_operation_commands.py',\n",
    "    workdir='polybot_workcell'\n",
    ")\n",
    "\n",
    "# Test with a simple prompt\n",
    "prompt = \"\"\"Write the execution code to pick up a substrate and move it to the coating station.\"\"\"\n",
    "chat_result = autogen_system.initiate_chat(prompt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[92m\n",
      "LOADING MEMORY FROM DISK\u001b[0m\n",
      "\u001b[92m    Location = ./teachability_db_gpt4o\\uid_text_dict.pkl\u001b[0m\n",
      "\u001b[92m\n",
      "LOADING MEMORY FROM DISK\u001b[0m\n",
      "\u001b[92m    Location = ./teachability_db_gpt4o\\uid_text_dict.pkl\u001b[0m\n",
      "\u001b[33madmin\u001b[0m (to chat_manager):\n",
      "\n",
      "Write the execution code to pick up a substrate and move it to the coating station.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: code_writer_agent\n",
      "\u001b[0m\n",
      "\u001b[33mcode_writer_agent\u001b[0m (to chat_manager):\n",
      "\n",
      "To pick up a substrate and move it to the coating station, we need to follow these steps:\n",
      "\n",
      "1. Identify the location of a new substrate in the substrate rack.\n",
      "2. Move the robot arm to the location of the substrate.\n",
      "3. Use the Bernoulli substrate gripper tool to pick up the substrate.\n",
      "4. Move the robot arm to the coating station.\n",
      "5. Place the substrate on the coating station.\n",
      "\n",
      "Here's the code to perform these actions:\n",
      "\n",
      "```python\n",
      "# filename: move_substrate_to_coating_station.py\n",
      "\n",
      "import loca\n",
      "import robotics as ro\n",
      "\n",
      "# Initialize the robot controller\n",
      "c9 = ro.system.init('controller')\n",
      "\n",
      "# Pick up the Bernoulli substrate gripper tool\n",
      "c9.tool = 'substrate_tool'\n",
      "\n",
      "# Identify the location of a new substrate in the substrate rack\n",
      "substrate_index = (0, 0)  # Assuming the top-left position is the first new substrate\n",
      "\n",
      "# Move the robot arm to the location of the substrate\n",
      "c9.position = loca.substrate_rack[substrate_index]\n",
      "\n",
      "# Activate the vacuum to pick up the substrate\n",
      "c9.set_output('substrate_tool', True)\n",
      "\n",
      "# Move the robot arm to the coating station\n",
      "c9.position = loca.s_coater\n",
      "\n",
      "# Deactivate the vacuum to release the substrate\n",
      "c9.set_output('substrate_tool', False)\n",
      "\n",
      "# Drop off the Bernoulli substrate gripper tool\n",
      "c9.tool = None\n",
      "```\n",
      "\n",
      "Please save this code in a file named `move_substrate_to_coating_station.py` and execute it. This will move a substrate to the coating station.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: code_reviewer_agent\n",
      "\u001b[0m\n",
      "\u001b[33mcode_reviewer_agent\u001b[0m (to chat_manager):\n",
      "\n",
      "The code provided for moving a substrate to the coating station seems mostly correct, but there are a few points to address:\n",
      "\n",
      "1. **Library Imports**: Ensure that all necessary libraries are imported. The code uses `loca` and `robotics`, which should be part of the allowed libraries. Verify that these are indeed available and correct.\n",
      "\n",
      "2. **Tool Management**: The code correctly picks up and drops off the Bernoulli substrate gripper tool, which is good practice.\n",
      "\n",
      "3. **Substrate Index**: The substrate index is hardcoded as `(0, 0)`. If the substrate location is dynamic, consider implementing a method to find the next available substrate.\n",
      "\n",
      "4. **Output Control**: The use of `c9.set_output('substrate_tool', True)` and `c9.set_output('substrate_tool', False)` is appropriate for controlling the vacuum tool.\n",
      "\n",
      "5. **File Naming**: Ensure the file is saved as `move_substrate_to_coating_station.py`, as specified.\n",
      "\n",
      "6. **Comments and Documentation**: The code is well-commented, which is helpful for understanding the steps involved.\n",
      "\n",
      "7. **Error Handling**: Consider adding error handling to manage potential issues, such as the substrate not being found or the tool not being picked up correctly.\n",
      "\n",
      "Here's a slightly revised version of the code with these considerations:\n",
      "\n",
      "```python\n",
      "# filename: move_substrate_to_coating_station.py\n",
      "\n",
      "import loca\n",
      "import robotics as ro\n",
      "\n",
      "# Initialize the robot controller\n",
      "c9 = ro.system.init('controller')\n",
      "\n",
      "# Pick up the Bernoulli substrate gripper tool\n",
      "c9.tool = 'substrate_tool'\n",
      "\n",
      "# Identify the location of a new substrate in the substrate rack\n",
      "# Consider implementing a dynamic method to find the next available substrate\n",
      "substrate_index = (0, 0)  # Assuming the top-left position is the first new substrate\n",
      "\n",
      "# Move the robot arm to the location of the substrate\n",
      "c9.position = loca.substrate_rack[substrate_index]\n",
      "\n",
      "# Activate the vacuum to pick up the substrate\n",
      "c9.set_output('substrate_tool', True)\n",
      "\n",
      "# Move the robot arm to the coating station\n",
      "c9.position = loca.s_coater\n",
      "\n",
      "# Deactivate the vacuum to release the substrate\n",
      "c9.set_output('substrate_tool', False)\n",
      "\n",
      "# Drop off the Bernoulli substrate gripper tool\n",
      "c9.tool = None\n",
      "```\n",
      "\n",
      "Ensure that the `loca` and `robotics` modules are correctly imported and available in your environment. If any additional functions or error handling is needed, consider implementing those based on the specific requirements of your system.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: admin\n",
      "\u001b[0m\n",
      "\u001b[33madmin\u001b[0m (to chat_manager):\n",
      "\n",
      "you should first activate the vacuum on the coating stage to hold the substrate and then deactivate the vacuum of the bernouli tool\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: code_writer_agent\n",
      "\u001b[0m\n",
      "\u001b[33mcode_writer_agent\u001b[0m (to chat_manager):\n",
      "\n",
      "Thank you for the clarification. Let's adjust the code to ensure that the vacuum on the coating stage is activated before deactivating the vacuum of the Bernoulli tool. Here's the updated code:\n",
      "\n",
      "```python\n",
      "# filename: move_substrate_to_coating_station.py\n",
      "\n",
      "import loca\n",
      "import robotics as ro\n",
      "\n",
      "# Initialize the robot controller\n",
      "c9 = ro.system.init('controller')\n",
      "\n",
      "# Pick up the Bernoulli substrate gripper tool\n",
      "c9.tool = 'substrate_tool'\n",
      "\n",
      "# Identify the location of a new substrate in the substrate rack\n",
      "substrate_index = (0, 0)  # Assuming the top-left position is the first new substrate\n",
      "\n",
      "# Move the robot arm to the location of the substrate\n",
      "c9.position = loca.substrate_rack[substrate_index]\n",
      "\n",
      "# Activate the vacuum to pick up the substrate\n",
      "c9.set_output('substrate_tool', True)\n",
      "\n",
      "# Move the robot arm to the coating station\n",
      "c9.position = loca.s_coater\n",
      "\n",
      "# Activate the vacuum on the coating stage to hold the substrate\n",
      "c9.set_output('coater_stage_vacuum', True)\n",
      "\n",
      "# Deactivate the vacuum of the Bernoulli tool to release the substrate\n",
      "c9.set_output('substrate_tool', False)\n",
      "\n",
      "# Drop off the Bernoulli substrate gripper tool\n",
      "c9.tool = None\n",
      "```\n",
      "\n",
      "Please save this code in a file named `move_substrate_to_coating_station.py` and execute it. This will move a substrate to the coating station, ensuring the substrate is securely held by the coating stage before releasing it from the Bernoulli tool.\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: admin\n",
      "\u001b[0m\n",
      "\u001b[31m\n",
      ">>>>>>>> NO HUMAN INPUT RECEIVED.\u001b[0m\n",
      "\u001b[31m\n",
      ">>>>>>>> USING AUTO REPLY...\u001b[0m\n",
      "\u001b[33madmin\u001b[0m (to chat_manager):\n",
      "\n",
      "This updated code ensures that the vacuum on the coating stage is activated before the Bernoulli tool releases the substrate, which should help in securely transferring the substrate to the coating station. If you have any further questions or need additional modifications, feel free to ask. \n",
      "\n",
      "TERMINATE\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "\u001b[32m\n",
      "Next speaker: admin\n",
      "\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "# With memory\n",
    "autogen_system = AutoGenSystem(\n",
    "    llm_type='gpt4o',\n",
    "    polybot_file_path='n9_robot_operation_commands.py',\n",
    "    workdir='polybot_workcell'\n",
    ")\n",
    "\n",
    "# Test with a simple prompt\n",
    "prompt = \"\"\"Write the execution code to pick up a substrate and move it to the coating station.\"\"\"\n",
    "chat_result = autogen_system.initiate_chat(prompt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "autogen",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
