{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import re\n",
    "\n",
    "from dotenv import load_dotenv\n",
    "from langchain import hub\n",
    "from langchain.agents import AgentType, load_tools\n",
    "from langchain_experimental.tools import PythonREPLTool\n",
    "from langchain.agents import create_react_agent, AgentExecutor\n",
    "from langchain.chains.conversation.memory import ConversationBufferWindowMemory\n",
    "\n",
    "from langchain_openai import ChatOpenAI\n",
    "from langchain.tools import ArxivQueryRun, WikipediaQueryRun\n",
    "from langchain.utilities import ArxivAPIWrapper, WikipediaAPIWrapper\n",
    "\n",
    "\n",
    "from langchain.callbacks.streaming_stdout import StreamingStdOutCallbackHandler\n",
    "\n",
    "from llamp.mp.agents import (\n",
    "    MPSummaryExpert,\n",
    "    MPThermoExpert,\n",
    "    MPElasticityExpert,\n",
    "    MPDielectricExpert,\n",
    "    MPPiezoelectricExpert,\n",
    "    MPMagnetismExpert,\n",
    "    MPElectronicExpert,\n",
    "    MPSynthesisExpert,\n",
    "    MPStructureRetriever,\n",
    ")\n",
    "\n",
    "\n",
    "load_dotenv()\n",
    "\n",
    "OPENAI_API_KEY = os.getenv(\"OPENAI_API_KEY\", None)\n",
    "OPENAI_ORGANIZATION = os.getenv(\"OPENAI_ORGANIZATION\", None)\n",
    "\n",
    "OPENAI_GPT_MODEL = \"gpt-4-turbo\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/elvis/anaconda3/envs/llamp_test/lib/python3.11/site-packages/langchain/hub.py:86: DeprecationWarning: The `langchainhub sdk` is deprecated.\n",
      "Please use the `langsmith sdk` instead:\n",
      "  pip install langsmith\n",
      "Use the `pull_prompt` method.\n",
      "  res_dict = client.pull_repo(owner_repo_commit)\n"
     ]
    }
   ],
   "source": [
    "top_llm = ChatOpenAI(\n",
    "    temperature=0.1,\n",
    "    model=OPENAI_GPT_MODEL,\n",
    "    openai_api_key=OPENAI_API_KEY,\n",
    "    openai_organization=OPENAI_ORGANIZATION,\n",
    "    streaming=False,\n",
    "    callbacks=[StreamingStdOutCallbackHandler()],\n",
    ")\n",
    "\n",
    "bottom_callback_handler = StreamingStdOutCallbackHandler()\n",
    "\n",
    "bottom_llm = ChatOpenAI(\n",
    "    temperature=0,\n",
    "    model=OPENAI_GPT_MODEL,\n",
    "    openai_api_key=OPENAI_API_KEY,\n",
    "    openai_organization=OPENAI_ORGANIZATION,\n",
    "    max_retries=5,\n",
    "    streaming=True,\n",
    "    callbacks=[bottom_callback_handler],\n",
    ")\n",
    "\n",
    "\n",
    "wikipedia = WikipediaQueryRun(api_wrapper=WikipediaAPIWrapper())\n",
    "arxiv = ArxivQueryRun(api_wrapper=ArxivAPIWrapper())\n",
    "\n",
    "tools = load_tools([\"llm-math\"], llm=bottom_llm)\n",
    "tools += [PythonREPLTool()]\n",
    "tools += [\n",
    "    MPThermoExpert(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPElasticityExpert(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPDielectricExpert(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPMagnetismExpert(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPElectronicExpert(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPPiezoelectricExpert(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPSummaryExpert(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPSynthesisExpert(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPStructureRetriever(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    # ArxivAgent(llm=bottom_llm).as_tool(agent_kwargs=dict(return_intermediate_steps=False)),\n",
    "    arxiv,\n",
    "    wikipedia,\n",
    "]\n",
    "\n",
    "instructions = re.sub(\n",
    "        r\"\\s+\",\n",
    "        \" \",\n",
    "        \"\"\"You are a data-aware agent that can consult materials-related\n",
    "    data through Materials Project (MP) database, arXiv, Wikipedia, and a python \n",
    "    REPL, which you can use to execute python code. If you get an error, debug \n",
    "    your code and try again. Only use the output of your code to answer the \n",
    "    question. Ask user to clarify their queries if needed. Please note that you \n",
    "    don't have direct control over MP but through multiple assistant agents to \n",
    "    help you. You need to provide complete context in the input for assistants to \n",
    "    do their job.\n",
    "    \"\"\",\n",
    "    ).replace(\"\\n\", \" \")\n",
    "base_prompt = hub.pull(\"langchain-ai/react-agent-template\")\n",
    "prompt = base_prompt.partial(instructions=instructions)\n",
    "\n",
    "conversational_memory = ConversationBufferWindowMemory(\n",
    "    memory_key=\"chat_history\", k=5, return_messages=True\n",
    ")\n",
    "\n",
    "agent = create_react_agent(top_llm, tools, prompt)\n",
    "agent_executor = AgentExecutor(\n",
    "    agent=agent, tools=tools, verbose=True,\n",
    "    handle_parsing_errors=True,\n",
    "    memory=conversational_memory,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\u001b[1m> Entering new AgentExecutor chain...\u001b[0m\n",
      "Thought: Do I need to use a tool? Yes\n",
      "Action: MPStructureRetriever\n",
      "Action Input: Retrieve structure for NaZnP with ID mp-4824\u001b[32;1m\u001b[1;3mThought: Do I need to use a tool? Yes\n",
      "Action: MPStructureRetriever\n",
      "Action Input: Retrieve structure for NaZnP with ID mp-4824\u001b[0m\n",
      "\n",
      "\u001b[1m> Entering new AgentExecutor chain...\u001b[0m\n",
      "Action:\n",
      "```json\n",
      "{\n",
      "  \"action\": \"search_materials_structure__get\",\n",
      "  \"action_input\": {\n",
      "    \"material_ids\": \"mp-4824\",\n",
      "    \"fields\": \"material_id,structure\"\n",
      "  }\n",
      "}\n",
      "```\u001b[32;1m\u001b[1;3mAction:\n",
      "```json\n",
      "{\n",
      "  \"action\": \"search_materials_structure__get\",\n",
      "  \"action_input\": {\n",
      "    \"material_ids\": \"mp-4824\",\n",
      "    \"fields\": \"material_id,structure\"\n",
      "  }\n",
      "}\n",
      "```\u001b[0m"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Retrieving SummaryDoc documents: 100%|██████████| 1/1 [00:00<00:00, 5096.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[36;1m\u001b[1;3mAll retrieved structures are saved as Pymatgen Structure json files to the following paths: mp-4824-NaZnP-sg129.json\u001b[0m\n",
      "\u001b[32;1m\u001b[1;3m\u001b[0m\n",
      "\n",
      "\u001b[1m> Finished chain.\u001b[0m\n",
      "\u001b[33;1m\u001b[1;3m{'input': 'Retrieve structure for NaZnP with ID mp-4824', 'output': 'All retrieved structures are saved as Pymatgen Structure json files to the following paths: mp-4824-NaZnP-sg129.json'}\u001b[0mDo I need to use a tool? Yes\n",
      "Action: Python_REPL\n",
      "Action Input: \n",
      "```python\n",
      "from pymatgen.core import Structure\n",
      "from pymatgen.core.surface import SlabGenerator\n",
      "from ase import Atoms\n",
      "import json\n",
      "\n",
      "# Load the structure from the saved json file\n",
      "with open(\"mp-4824-NaZnP-sg129.json\", \"r\") as file:\n",
      "    structure_data = json.load(file)\n",
      "structure = Structure.from_dict(structure_data)\n",
      "\n",
      "# Generate the (100) surface slab\n",
      "slabgen = SlabGenerator(structure, miller_index=(1, 0, 0), min_slab_size=10.0, min_vacuum_size=10.0)\n",
      "slab = slabgen.get_slabs()[0]\n",
      "\n",
      "# Convert pymatgen slab to ASE atoms\n",
      "ase_slab = slab.to_ase()\n",
      "\n",
      "# Add CO2 molecule 2 Angstroms above the highest atom in the slab\n",
      "max_z = max(ase_slab.positions[:, 2])\n",
      "co2 = Atoms('CO2', positions=[(0, 0, max_z + 2), (0, 0, max_z + 2.1), (0, 0, max_z + 3.2)])\n",
      "ase_slab.extend(co2)\n",
      "\n",
      "# Convert back to pymatgen structure and generate POSCAR\n",
      "final_structure = Structure.from_sites(ase_slab)\n",
      "poscar_string = final_structure.to(fmt=\"poscar\")\n",
      "print(poscar_string)\n",
      "```\u001b[32;1m\u001b[1;3mDo I need to use a tool? Yes\n",
      "Action: Python_REPL\n",
      "Action Input: \n",
      "```python\n",
      "from pymatgen.core import Structure\n",
      "from pymatgen.core.surface import SlabGenerator\n",
      "from ase import Atoms\n",
      "import json\n",
      "\n",
      "# Load the structure from the saved json file\n",
      "with open(\"mp-4824-NaZnP-sg129.json\", \"r\") as file:\n",
      "    structure_data = json.load(file)\n",
      "structure = Structure.from_dict(structure_data)\n",
      "\n",
      "# Generate the (100) surface slab\n",
      "slabgen = SlabGenerator(structure, miller_index=(1, 0, 0), min_slab_size=10.0, min_vacuum_size=10.0)\n",
      "slab = slabgen.get_slabs()[0]\n",
      "\n",
      "# Convert pymatgen slab to ASE atoms\n",
      "ase_slab = slab.to_ase()\n",
      "\n",
      "# Add CO2 molecule 2 Angstroms above the highest atom in the slab\n",
      "max_z = max(ase_slab.positions[:, 2])\n",
      "co2 = Atoms('CO2', positions=[(0, 0, max_z + 2), (0, 0, max_z + 2.1), (0, 0, max_z + 3.2)])\n",
      "ase_slab.extend(co2)\n",
      "\n",
      "# Convert back to pymatgen structure and generate POSCAR\n",
      "final_structure = Structure.from_sites(ase_slab)\n",
      "poscar_string = final_structure.to(fmt=\"poscar\")\n",
      "print(poscar_string)\n",
      "```\u001b[0m\u001b[33;1m\u001b[1;3mAttributeError(\"'Slab' object has no attribute 'to_ase'\")\u001b[0mDo I need to use a tool? Yes\n",
      "Action: Python_REPL\n",
      "Action Input: \n",
      "```python\n",
      "from pymatgen.core import Structure\n",
      "from pymatgen.core.surface import SlabGenerator\n",
      "from ase import Atoms\n",
      "from pymatgen.io.ase import AseAtomsAdaptor\n",
      "import json\n",
      "\n",
      "# Load the structure from the saved json file\n",
      "with open(\"mp-4824-NaZnP-sg129.json\", \"r\") as file:\n",
      "    structure_data = json.load(file)\n",
      "structure = Structure.from_dict(structure_data)\n",
      "\n",
      "# Generate the (100) surface slab\n",
      "slabgen = SlabGenerator(structure, miller_index=(1, 0, 0), min_slab_size=10.0, min_vacuum_size=10.0)\n",
      "slab = slabgen.get_slabs()[0]\n",
      "\n",
      "# Convert pymatgen slab to ASE atoms using AseAtomsAdaptor\n",
      "ase_adaptor = AseAtomsAdaptor()\n",
      "ase_slab = ase_adaptor.get_atoms(slab)\n",
      "\n",
      "# Add CO2 molecule 2 Angstroms above the highest atom in the slab\n",
      "max_z = max(ase_slab.positions[:, 2])\n",
      "co2 = Atoms('CO2', positions=[(0, 0, max_z + 2), (0, 0, max_z + 2.1), (0, 0, max_z + 3.2)])\n",
      "ase_slab.extend(co2)\n",
      "\n",
      "# Convert back to pymatgen structure and generate POSCAR\n",
      "final_structure = ase_adaptor.get_structure(ase_slab)\n",
      "poscar_string = final_structure.to(fmt=\"poscar\")\n",
      "print(poscar_string)\n",
      "```\u001b[32;1m\u001b[1;3mDo I need to use a tool? Yes\n",
      "Action: Python_REPL\n",
      "Action Input: \n",
      "```python\n",
      "from pymatgen.core import Structure\n",
      "from pymatgen.core.surface import SlabGenerator\n",
      "from ase import Atoms\n",
      "from pymatgen.io.ase import AseAtomsAdaptor\n",
      "import json\n",
      "\n",
      "# Load the structure from the saved json file\n",
      "with open(\"mp-4824-NaZnP-sg129.json\", \"r\") as file:\n",
      "    structure_data = json.load(file)\n",
      "structure = Structure.from_dict(structure_data)\n",
      "\n",
      "# Generate the (100) surface slab\n",
      "slabgen = SlabGenerator(structure, miller_index=(1, 0, 0), min_slab_size=10.0, min_vacuum_size=10.0)\n",
      "slab = slabgen.get_slabs()[0]\n",
      "\n",
      "# Convert pymatgen slab to ASE atoms using AseAtomsAdaptor\n",
      "ase_adaptor = AseAtomsAdaptor()\n",
      "ase_slab = ase_adaptor.get_atoms(slab)\n",
      "\n",
      "# Add CO2 molecule 2 Angstroms above the highest atom in the slab\n",
      "max_z = max(ase_slab.positions[:, 2])\n",
      "co2 = Atoms('CO2', positions=[(0, 0, max_z + 2), (0, 0, max_z + 2.1), (0, 0, max_z + 3.2)])\n",
      "ase_slab.extend(co2)\n",
      "\n",
      "# Convert back to pymatgen structure and generate POSCAR\n",
      "final_structure = ase_adaptor.get_structure(ase_slab)\n",
      "poscar_string = final_structure.to(fmt=\"poscar\")\n",
      "print(poscar_string)\n",
      "```\u001b[0m\u001b[33;1m\u001b[1;3mNa6 Zn6 P6 C1 O2\n",
      "1.0\n",
      "   4.0287840499999996    0.0000000000000000    0.0000000000000002\n",
      "  -0.0000000000000004    6.8370037799999999    0.0000000000000004\n",
      "   0.0000000000000000    0.0000000000000000   24.1727042999999995\n",
      "Na Zn P Na Zn P Na Zn P C O\n",
      "2 2 2 2 2 2 2 2 2 1 2\n",
      "direct\n",
      "   0.7500000000000000    0.6442037800000002    0.1250000000000000 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.0416666666666667 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.1250000000000000 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.0416666666666667 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.0416666666666667 P\n",
      "   0.7500000000000000    0.2122956100000000    0.1250000000000000 P\n",
      "   0.7500000000000000    0.6442037800000002    0.2916666666666666 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.2083333333333333 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.2916666666666666 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.2083333333333333 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.2083333333333333 P\n",
      "   0.7500000000000000    0.2122956100000000    0.2916666666666666 P\n",
      "   0.7500000000000000    0.6442037800000002    0.4583333333333333 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.3750000000000001 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.4583333333333334 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.3750000000000001 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.3750000000000000 P\n",
      "   0.7500000000000000    0.2122956100000000    0.4583333333333333 P\n",
      "   0.0000000000000000    0.0000000000000000    0.5410712833441643 C\n",
      "   0.0000000000000000    0.0000000000000000    0.5452081808447059 O\n",
      "   0.0000000000000000    0.0000000000000000    0.5907140533506630 O\n",
      "\n",
      "\u001b[0mDo I need to use a tool? No\n",
      "Final Answer: Na6 Zn6 P6 C1 O2\n",
      "1.0\n",
      "   4.0287840499999996    0.0000000000000000    0.0000000000000002\n",
      "  -0.0000000000000004    6.8370037799999999    0.0000000000000004\n",
      "   0.0000000000000000    0.0000000000000000   24.1727042999999995\n",
      "Na Zn P Na Zn P Na Zn P C O\n",
      "2 2 2 2 2 2 2 2 2 1 2\n",
      "direct\n",
      "   0.7500000000000000    0.6442037800000002    0.1250000000000000 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.0416666666666667 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.1250000000000000 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.0416666666666667 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.0416666666666667 P\n",
      "   0.7500000000000000    0.2122956100000000    0.1250000000000000 P\n",
      "   0.7500000000000000    0.6442037800000002    0.2916666666666666 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.2083333333333333 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.2916666666666666 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.2083333333333333 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.2083333333333333 P\n",
      "   0.7500000000000000    0.2122956100000000    0.2916666666666666 P\n",
      "   0.7500000000000000    0.6442037800000002    0.4583333333333333 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.3750000000000001 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.4583333333333334 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.3750000000000001 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.3750000000000000 P\n",
      "   0.7500000000000000    0.2122956100000000    0.4583333333333333 P\n",
      "   0.0000000000000000    0.0000000000000000    0.5410712833441643 C\n",
      "   0.0000000000000000    0.0000000000000000    0.5452081808447059 O\n",
      "   0.0000000000000000    0.0000000000000000    0.5907140533506630 O\u001b[32;1m\u001b[1;3mDo I need to use a tool? No\n",
      "Final Answer: Na6 Zn6 P6 C1 O2\n",
      "1.0\n",
      "   4.0287840499999996    0.0000000000000000    0.0000000000000002\n",
      "  -0.0000000000000004    6.8370037799999999    0.0000000000000004\n",
      "   0.0000000000000000    0.0000000000000000   24.1727042999999995\n",
      "Na Zn P Na Zn P Na Zn P C O\n",
      "2 2 2 2 2 2 2 2 2 1 2\n",
      "direct\n",
      "   0.7500000000000000    0.6442037800000002    0.1250000000000000 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.0416666666666667 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.1250000000000000 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.0416666666666667 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.0416666666666667 P\n",
      "   0.7500000000000000    0.2122956100000000    0.1250000000000000 P\n",
      "   0.7500000000000000    0.6442037800000002    0.2916666666666666 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.2083333333333333 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.2916666666666666 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.2083333333333333 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.2083333333333333 P\n",
      "   0.7500000000000000    0.2122956100000000    0.2916666666666666 P\n",
      "   0.7500000000000000    0.6442037800000002    0.4583333333333333 Na\n",
      "   0.2500000000000000    0.3557962200000000    0.3750000000000001 Na\n",
      "   0.2500000000000000    0.0000000000000000    0.4583333333333334 Zn\n",
      "   0.7500000000000000    0.0000000000000000    0.3750000000000001 Zn\n",
      "   0.2500000000000000    0.7877043900000001    0.3750000000000000 P\n",
      "   0.7500000000000000    0.2122956100000000    0.4583333333333333 P\n",
      "   0.0000000000000000    0.0000000000000000    0.5410712833441643 C\n",
      "   0.0000000000000000    0.0000000000000000    0.5452081808447059 O\n",
      "   0.0000000000000000    0.0000000000000000    0.5907140533506630 O\u001b[0m\n",
      "\n",
      "\u001b[1m> Finished chain.\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "response = agent_executor.invoke(\n",
    "    {\n",
    "        \"input\": \"\"\"Could you retreive NaZnP (mp-4824) and use pymatgen to create the (100) surface and put a CO2 molecule 2 A on top of it? \n",
    "        Run the code you generate slab, convert the slab into ASE atoms, add CO2, and return structure \n",
    "        as readable POSCAR string without any other response.\"\"\",\n",
    "    }\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Na6 Zn6 P6 C1 O2\\n1.0\\n   4.0287840499999996    0.0000000000000000    0.0000000000000002\\n  -0.0000000000000004    6.8370037799999999    0.0000000000000004\\n   0.0000000000000000    0.0000000000000000   24.1727042999999995\\nNa Zn P Na Zn P Na Zn P C O\\n2 2 2 2 2 2 2 2 2 1 2\\ndirect\\n   0.7500000000000000    0.6442037800000002    0.1250000000000000 Na\\n   0.2500000000000000    0.3557962200000000    0.0416666666666667 Na\\n   0.2500000000000000    0.0000000000000000    0.1250000000000000 Zn\\n   0.7500000000000000    0.0000000000000000    0.0416666666666667 Zn\\n   0.2500000000000000    0.7877043900000001    0.0416666666666667 P\\n   0.7500000000000000    0.2122956100000000    0.1250000000000000 P\\n   0.7500000000000000    0.6442037800000002    0.2916666666666666 Na\\n   0.2500000000000000    0.3557962200000000    0.2083333333333333 Na\\n   0.2500000000000000    0.0000000000000000    0.2916666666666666 Zn\\n   0.7500000000000000    0.0000000000000000    0.2083333333333333 Zn\\n   0.2500000000000000    0.7877043900000001    0.2083333333333333 P\\n   0.7500000000000000    0.2122956100000000    0.2916666666666666 P\\n   0.7500000000000000    0.6442037800000002    0.4583333333333333 Na\\n   0.2500000000000000    0.3557962200000000    0.3750000000000001 Na\\n   0.2500000000000000    0.0000000000000000    0.4583333333333334 Zn\\n   0.7500000000000000    0.0000000000000000    0.3750000000000001 Zn\\n   0.2500000000000000    0.7877043900000001    0.3750000000000000 P\\n   0.7500000000000000    0.2122956100000000    0.4583333333333333 P\\n   0.0000000000000000    0.0000000000000000    0.5410712833441643 C\\n   0.0000000000000000    0.0000000000000000    0.5452081808447059 O\\n   0.0000000000000000    0.0000000000000000    0.5907140533506630 O'"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "agent_executor.memory.chat_memory.messages[1].content"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: >"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pymatgen.core import Structure\n",
    "from ase.visualize import view\n",
    "from ase.io.extxyz import read_extxyz\n",
    "from ase.io import read\n",
    "from ase.visualize.plot import plot_atoms\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fpath = \"POSCAR\"\n",
    "with open(fpath, \"w\") as f:\n",
    "    f.write(agent_executor.memory.chat_memory.messages[1].content)\n",
    "\n",
    "atoms = read(fpath)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(3, 3))\n",
    "\n",
    "plot_atoms(atoms * (3, 3, 1), ax, radii=0.5, \n",
    "           rotation=('-80x, -50y, 0z')\n",
    "           )\n",
    "\n",
    "# view(atoms*(3, 3, 1), viewer=\"x3d\")\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llamp",
   "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
}
