{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": [
    "import os\n",
    "import re\n",
    "import tempfile\n",
    "from monty.tempfile import ScratchDir\n",
    "\n",
    "from dotenv import load_dotenv\n",
    "from langchain import hub\n",
    "from langchain.agents import 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",
    "from langchain_openai import ChatOpenAI\n",
    "from langchain_community.chat_models import ChatOllama\n",
    "from langchain.tools import ArxivQueryRun, WikipediaQueryRun\n",
    "from langchain.utilities import ArxivAPIWrapper, WikipediaAPIWrapper\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",
    "from llamp.atomate2.agents import MLFFMDAgent\n",
    "\n",
    "load_dotenv()\n",
    "\n",
    "MP_API_KEY = os.getenv(\"MP_API_KEY\", None)\n",
    "OPENAI_API_KEY = os.getenv(\"OPENAI_API_KEY\", None)\n",
    "OPENAI_ORGANIZATION = os.getenv(\"OPENAI_ORGANIZATION\", None)\n",
    "\n",
    "OPENAI_GPT_MODEL = \"gpt-4o-mini\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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=True,\n",
    "    callbacks=[StreamingStdOutCallbackHandler()],\n",
    ")\n",
    "\n",
    "bottom_callback_handler = StreamingStdOutCallbackHandler()\n",
    "\n",
    "bottom_llm = ChatOpenAI(\n",
    "    temperature=0.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",
    "    description=re.sub(\n",
    "        r\"\\s+\",\n",
    "        \" \",\n",
    "        \"\"\"A Python shell. Use this to execute python commands.\n",
    "        Input should be a valid python command.\n",
    "        \n",
    "        TIPS:\n",
    "        - If you want to see the output of a value, you should print it out\n",
    "        with `print(...)`.\n",
    "        - If you write any file to a local file system, you should ALWAYS \n",
    "        print the paths to the files as well.\n",
    "        - If you plot any graph, you should show the graph, save it to local \n",
    "        and print the path to the image file.\n",
    "        - Combine all your output string together and print once together in\n",
    "        JSON format at the end of the code.\n",
    "        \"\"\"\n",
    "    )\n",
    ")]\n",
    "tools += [\n",
    "    MPThermoExpert(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPElasticityExpert(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPDielectricExpert(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPMagnetismExpert(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPElectronicExpert(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPPiezoelectricExpert(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPSummaryExpert(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPSynthesisExpert(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MPStructureRetriever(llm=bottom_llm, mp_api_key=MP_API_KEY).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "    MLFFMDAgent(llm=bottom_llm).as_tool(\n",
    "        agent_kwargs=dict(return_intermediate_steps=False)\n",
    "    ),\n",
    "]\n",
    "\n",
    "instructions = re.sub(\n",
    "    r\"\\s+\",\n",
    "    \" \",\n",
    "    \"\"\"You name is LLaMP and you are a helpful agent that can consult \n",
    "    materials-related data through Materials Project (MP) database, arXiv, \n",
    "    Wikipedia, and run calculations/simulations via a python REPL and MP atomate2 \n",
    "    computational workflow.     \n",
    "        \n",
    "    If you get an error, debug your code and try again. Only use \n",
    "    the output of your code to answer the question. Ask user to clarify their \n",
    "    queries if needed. Please note that you don't have direct control over MP but \n",
    "    through multiple assistant agents to help you. You need to provide complete \n",
    "    context in the input for assistants to do their job. REFINE and CRITQUE the \n",
    "    output of the assistants if needed. You can end the conversation by saying \"Bye\".\n",
    "    \"\"\",\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",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\u001b[1m> Entering new AgentExecutor chain...\u001b[0m\n",
      "```\n",
      "Thought: Do I need to use a tool? Yes\n",
      "Action: MPSynthesisExpert\n",
      "Action Input: How to synthesize LiFePO4? Please provide a detailed step-by-step procedure and the reference.\u001b[32;1m\u001b[1;3m```\n",
      "Thought: Do I need to use a tool? Yes\n",
      "Action: MPSynthesisExpert\n",
      "Action Input: How to synthesize LiFePO4? Please provide a detailed step-by-step procedure and the reference.\u001b[0m\n",
      "\n",
      "\u001b[1m> Entering new AgentExecutor chain...\u001b[0m\n",
      "Thought: I need to find the synthesis procedure for LiFePO4, including detailed steps and references. I will use the synthesis tool to gather this information.\n",
      "\n",
      "Action:\n",
      "```\n",
      "{\n",
      "  \"action\": \"search_materials_synthesis__get\",\n",
      "  \"action_input\": {\n",
      "    \"keywords\": \"LiFePO4\",\n",
      "    \"synthesis_type\": \"solid_state\",\n",
      "    \"target_formula\": \"LiFePO4\",\n",
      "    \"limit\": 5\n",
      "  }\n",
      "}\n",
      "```\n",
      "\u001b[32;1m\u001b[1;3mThought: I need to find the synthesis procedure for LiFePO4, including detailed steps and references. I will use the synthesis tool to gather this information.\n",
      "\n",
      "Action:\n",
      "```\n",
      "{\n",
      "  \"action\": \"search_materials_synthesis__get\",\n",
      "  \"action_input\": {\n",
      "    \"keywords\": \"LiFePO4\",\n",
      "    \"synthesis_type\": \"solid_state\",\n",
      "    \"target_formula\": \"LiFePO4\",\n",
      "    \"limit\": 5\n",
      "  }\n",
      "}\n",
      "```\n",
      "\u001b[0m\u001b[36;1m\u001b[1;3mError on search_materials_synthesis__get: REST query returned with error status code 422 on URL https://api.materialsproject.org/materials/synthesis/?synthesis_type=solid_state&keywords=LiFePO4&_all_fields=True&target_formula=LiFePO4&_limit=1000 with message:\n",
      "synthesis_type - Input should be 'solid-state' or 'sol-gel'. Please revise arguments or try smaller request by specifying 'limit' in request.\u001b[0mThought: I need to correct the synthesis type argument to 'solid-state' instead of 'solid_state' and try the request again.\n",
      "\n",
      "Action:\n",
      "```\n",
      "{\n",
      "  \"action\": \"search_materials_synthesis__get\",\n",
      "  \"action_input\": {\n",
      "    \"keywords\": \"LiFePO4\",\n",
      "    \"synthesis_type\": \"solid-state\",\n",
      "    \"target_formula\": \"LiFePO4\",\n",
      "    \"limit\": 5\n",
      "  }\n",
      "}\n",
      "```\n",
      "\n",
      "\u001b[32;1m\u001b[1;3mThought: I need to correct the synthesis type argument to 'solid-state' instead of 'solid_state' and try the request again.\n",
      "\n",
      "Action:\n",
      "```\n",
      "{\n",
      "  \"action\": \"search_materials_synthesis__get\",\n",
      "  \"action_input\": {\n",
      "    \"keywords\": \"LiFePO4\",\n",
      "    \"synthesis_type\": \"solid-state\",\n",
      "    \"target_formula\": \"LiFePO4\",\n",
      "    \"limit\": 5\n",
      "  }\n",
      "}\n",
      "```\n",
      "\n",
      "\u001b[0m"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Retrieving SynthesisSearchResultModel documents: 100%|██████████| 192/192 [00:00<00:00, 3986665.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[36;1m\u001b[1;3m[{'doi': '10.1016/j.jpowsour.2008.08.028', 'paragraph_string': 'The C-LiFePO4 samples used were prepared by two different chemical routes: solid-state reaction (...', 'synthesis_type': 'solid-state', 'reaction_string': '1 FePO4(H2O)2 + 0.5 Li2CO3 == 1 LiFePO4 + 0.5 CO2 + 2 H2O + 0.25 O2', 'reaction': {'left_side': [{'amount': '0.5', 'material': 'Li2CO3'}, {'amount': '1', 'material': 'FePO4(H2O)2'}], 'right_side': [{'amount': '1', 'material': 'LiFePO4'}, {'amount': '0.5', 'material': 'CO2'}, {'amount': '2', 'material': 'H2O'}, {'amount': '0.25', 'material': 'O2'}]}, 'targets_formula': ['Li1 Fe1 P1 O4'], 'target': {'material_string': 'C-LiFePO4', 'material_name': '', 'material_formula': 'LiFePO4', 'phase': 'C', 'is_acronym': False, 'composition': [{'formula': 'LiFePO4', 'amount': '1', 'elements': {'Li': '1', 'Fe': '1', 'P': '1', 'O': '4'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, 'targets_formula_s': ['LiFePO4'], 'precursors_formula_s': ['Li2CO3', 'FeP(H2O3)2'], 'precursors': [{'material_string': 'Li2CO3', 'material_name': '', 'material_formula': 'Li2CO3', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'Li2CO3', 'amount': '1', 'elements': {'Li': '2', 'C': '1', 'O': '3'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, {'material_string': 'FePO4(H2O)2', 'material_name': '', 'material_formula': 'FePO4(H2O)2', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'FePO4(H2O)2', 'amount': '1', 'elements': {'H': '4', 'O': '6', 'Fe': '1', 'P': '1'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}], 'operations': [{'type': 'StartingSynthesis', 'token': 'prepared', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'StartingSynthesis', 'token': 'prepared', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'MixingOperation', 'token': 'mixed', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': 'isopropanol'}}, {'type': 'DryingOperation', 'token': 'drying', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'HeatingOperation', 'token': 'heated', 'conditions': {'heating_temperature': [{'min_value': 700.0, 'max_value': 700.0, 'values': [700.0], 'units': '°C'}], 'heating_time': [], 'heating_atmosphere': ['argon'], 'mixing_device': None, 'mixing_media': None}}, {'type': 'StartingSynthesis', 'token': 'prepared', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}], 'search_score': 3.9395534992218018, 'highlights': [{'score': 0.9770343899726868, 'path': 'paragraph_string', 'texts': [{'value': 'The C-', 'type': 'text'}, {'value': 'LiFePO4', 'type': 'hit'}, {'value': ' samples used were prepared by two different chemical routes: solid-state reaction (...', 'type': 'text'}]}], 'total_doc': 192}, {'doi': '10.1016/j.electacta.2013.02.066', 'paragraph_string': 'The orthorhombic nano-LiFePO4/C composite was synthesized from FeC2O4·2H2O, LiH2PO4, suitable ...', 'synthesis_type': 'solid-state', 'reaction_string': '1 FeC2O4·2H2O + -0.333 HOC(COOH)(CH2COOH)2 + 1 LiH2PO4 == 1 LiFePO4 + 1.667 H2O + 1 O2', 'reaction': {'left_side': [{'amount': '1', 'material': 'FeC2O4·2H2O'}, {'amount': '-0.333', 'material': 'HOC(COOH)(CH2COOH)2'}, {'amount': '1', 'material': 'LiH2PO4'}], 'right_side': [{'amount': '1', 'material': 'LiFePO4'}, {'amount': '1.667', 'material': 'H2O'}, {'amount': '1', 'material': 'O2'}]}, 'targets_formula': ['Li1 Fe1 P1 O4'], 'target': {'material_string': 'nano-LiFePO4/C', 'material_name': '', 'material_formula': 'LiFePO4', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'LiFePO4', 'amount': '1', 'elements': {'Li': '1', 'Fe': '1', 'P': '1', 'O': '4'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, 'targets_formula_s': ['LiFePO4'], 'precursors_formula_s': ['Fe(CO2)2', 'H8C6O7', 'LiP(HO2)2'], 'precursors': [{'material_string': 'FeC2O4·2H2O', 'material_name': '', 'material_formula': 'FeC2O4·2H2O', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'FeC2O4', 'amount': '1', 'elements': {'Fe': '1', 'C': '2', 'O': '4'}}, {'formula': 'H2O', 'amount': '2', 'elements': {'H': '2', 'O': '1'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, {'material_string': 'citric acid', 'material_name': 'citric acid', 'material_formula': 'HOC(COOH)(CH2COOH)2', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'HOC(COOH)(CH2COOH)2', 'amount': '1', 'elements': {'C': '6', 'O': '7', 'H': '8'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, {'material_string': 'LiH2PO4', 'material_name': '', 'material_formula': 'LiH2PO4', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'LiH2PO4', 'amount': '1', 'elements': {'Li': '1', 'H': '2', 'P': '1', 'O': '4'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}], 'operations': [{'type': 'StartingSynthesis', 'token': 'synthesized', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'MixingOperation', 'token': 'milled', 'conditions': {'heating_temperature': [], 'heating_time': [{'min_value': 20.0, 'max_value': 20.0, 'values': [20.0], 'units': 'h'}], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': 'ethanol'}}, {'type': 'DryingOperation', 'token': 'dried', 'conditions': {'heating_temperature': [{'min_value': 60.0, 'max_value': 60.0, 'values': [60.0], 'units': '°C'}], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'HeatingOperation', 'token': 'calcined', 'conditions': {'heating_temperature': [{'min_value': 700.0, 'max_value': 700.0, 'values': [700.0], 'units': '°C'}, {'min_value': 350.0, 'max_value': 350.0, 'values': [350.0], 'units': '°C'}], 'heating_time': [{'min_value': 8.0, 'max_value': 8.0, 'values': [8.0], 'units': 'h'}, {'min_value': 3.0, 'max_value': 3.0, 'values': [3.0], 'units': 'h'}], 'heating_atmosphere': ['nitrogen'], 'mixing_device': None, 'mixing_media': None}}], 'search_score': 3.871649980545044, 'highlights': [{'score': 1.0815449953079224, 'path': 'paragraph_string', 'texts': [{'value': '... orthorhombic nano-', 'type': 'text'}, {'value': 'LiFePO4', 'type': 'hit'}, {'value': '/C composite was synthesized from FeC2O4·2H2O, LiH2PO4, suitable ...', 'type': 'text'}]}], 'total_doc': 192}, {'doi': '10.1016/j.jpowsour.2005.01.004', 'paragraph_string': 'LiFePO4 and its carbon composites were prepared by the solid-state reaction of FeC2O4·2H2O (99%, ...', 'synthesis_type': 'solid-state', 'reaction_string': '-2 C + 1 FeC2O4·2H2O + 1 LiH2PO4 == 1 LiFePO4 + 3 H2O + 1.5 O2', 'reaction': {'left_side': [{'amount': '1', 'material': 'FeC2O4·2H2O'}, {'amount': '-2', 'material': 'C'}, {'amount': '1', 'material': 'LiH2PO4'}], 'right_side': [{'amount': '1', 'material': 'LiFePO4'}, {'amount': '3', 'material': 'H2O'}, {'amount': '1.5', 'material': 'O2'}]}, 'targets_formula': ['Li1 Fe1 P1 O4'], 'target': {'material_string': 'LiFePO4', 'material_name': '', 'material_formula': 'LiFePO4', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'LiFePO4', 'amount': '1', 'elements': {'Li': '1', 'Fe': '1', 'P': '1', 'O': '4'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, 'targets_formula_s': ['LiFePO4'], 'precursors_formula_s': ['Fe(CO2)2', 'C', 'LiP(HO2)2'], 'precursors': [{'material_string': 'FeC2O4·2H2O', 'material_name': '', 'material_formula': 'FeC2O4·2H2O', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'FeC2O4', 'amount': '1', 'elements': {'Fe': '1', 'C': '2', 'O': '4'}}, {'formula': 'H2O', 'amount': '2', 'elements': {'H': '2', 'O': '1'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, {'material_string': 'C', 'material_name': '', 'material_formula': 'C', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'C', 'amount': '1', 'elements': {'C': '1'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, {'material_string': 'LiH2PO4', 'material_name': '', 'material_formula': 'LiH2PO4', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'LiH2PO4', 'amount': '1', 'elements': {'Li': '1', 'H': '2', 'P': '1', 'O': '4'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}], 'operations': [{'type': 'StartingSynthesis', 'token': 'prepared', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'MixingOperation', 'token': 'mixed', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': 'LiFePO4'}}, {'type': 'HeatingOperation', 'token': 'heated', 'conditions': {'heating_temperature': [{'min_value': 350.0, 'max_value': 380.0, 'values': [], 'units': '°C'}], 'heating_time': [{'min_value': 5.0, 'max_value': 5.0, 'values': [5.0], 'units': 'h'}], 'heating_atmosphere': ['LiFePO4'], 'mixing_device': None, 'mixing_media': None}}, {'type': 'MixingOperation', 'token': 'reground', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'HeatingOperation', 'token': 'heated', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}], 'search_score': 3.8463799953460693, 'highlights': [{'score': 0.9746965765953064, 'path': 'paragraph_string', 'texts': [{'value': 'LiFePO4', 'type': 'hit'}, {'value': ' and its carbon composites were prepared by the solid-state reaction of FeC2O4·2H2O (99%, ...', 'type': 'text'}]}], 'total_doc': 192}, {'doi': '10.1016/j.powtec.2013.12.013', 'paragraph_string': 'We prepared the LiFePO4/C composite using wet-milling assisted carbothermal reduction. To ...', 'synthesis_type': 'solid-state', 'reaction_string': '1 FePO4·2H2O + 1 LiOH·H2O == 1 LiFePO4 + 3.5 H2O + 0.25 O2', 'reaction': {'left_side': [{'amount': '1', 'material': 'LiOH·H2O'}, {'amount': '1', 'material': 'FePO4·2H2O'}], 'right_side': [{'amount': '1', 'material': 'LiFePO4'}, {'amount': '3.5', 'material': 'H2O'}, {'amount': '0.25', 'material': 'O2'}]}, 'targets_formula': ['Li1 Fe1 P1 O4'], 'target': {'material_string': 'LiFePO4/C', 'material_name': '', 'material_formula': 'LiFePO4', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'LiFePO4', 'amount': '1', 'elements': {'Li': '1', 'Fe': '1', 'P': '1', 'O': '4'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, 'targets_formula_s': ['LiFePO4'], 'precursors_formula_s': ['LiHO', 'FePO4'], 'precursors': [{'material_string': 'LiOH · H2O', 'material_name': '', 'material_formula': 'LiOH·H2O', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'LiOH', 'amount': '1', 'elements': {'Li': '1', 'O': '1', 'H': '1'}}, {'formula': 'H2O', 'amount': '1', 'elements': {'H': '2', 'O': '1'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, {'material_string': 'FePO4 · 2H2O', 'material_name': '', 'material_formula': 'FePO4·2H2O', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'FePO4', 'amount': '1', 'elements': {'Fe': '1', 'P': '1', 'O': '4'}}, {'formula': 'H2O', 'amount': '2', 'elements': {'H': '2', 'O': '1'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}], 'operations': [{'type': 'StartingSynthesis', 'token': 'prepared', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'MixingOperation', 'token': 'milled', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'MixingOperation', 'token': 'milled', 'conditions': {'heating_temperature': [], 'heating_time': [{'min_value': 2.5, 'max_value': 2.5, 'values': [2.5], 'units': 'h'}], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'DryingOperation', 'token': 'dried', 'conditions': {'heating_temperature': [{'min_value': 60.0, 'max_value': 60.0, 'values': [60.0], 'units': '°C'}], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'HeatingOperation', 'token': 'sintered', 'conditions': {'heating_temperature': [{'min_value': 650.0, 'max_value': 650.0, 'values': [650.0], 'units': '°C'}], 'heating_time': [{'min_value': 8.5, 'max_value': 8.5, 'values': [8.5], 'units': 'h'}], 'heating_atmosphere': ['nitrogen'], 'mixing_device': None, 'mixing_media': None}}, {'type': 'QuenchingOperation', 'token': 'cooling', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}], 'search_score': 3.8060474395751953, 'highlights': [{'score': 1.411032795906067, 'path': 'paragraph_string', 'texts': [{'value': 'We prepared the ', 'type': 'text'}, {'value': 'LiFePO4', 'type': 'hit'}, {'value': '/C composite using wet-milling assisted carbothermal reduction. ', 'type': 'text'}]}, {'score': 1.376348614692688, 'path': 'paragraph_string', 'texts': [{'value': 'To ...', 'type': 'text'}]}], 'total_doc': 192}, {'doi': '10.1016/j.jelechem.2014.05.018', 'paragraph_string': 'Pristine LiFePO4 sample was synthesized by a traditional solid-state reaction using CH3COOLi·2H2O, ...', 'synthesis_type': 'solid-state', 'reaction_string': '1 (NH4)2HPO4 + 1 CH3COOLi·2H2O + 1 FeC2O4·2H2O + 2 [OH-] == 1 LiFePO4 + 5 H2O + 2 NH3 + 1.5 O2 + 2 [CH3COO-]', 'reaction': {'left_side': [{'amount': '1', 'material': 'FeC2O4·2H2O'}, {'amount': '1', 'material': '(NH4)2HPO4'}, {'amount': '1', 'material': 'CH3COOLi·2H2O'}, {'amount': '2', 'material': '[OH-]'}], 'right_side': [{'amount': '1', 'material': 'LiFePO4'}, {'amount': '5', 'material': 'H2O'}, {'amount': '2', 'material': 'NH3'}, {'amount': '2', 'material': '[CH3COO-]'}, {'amount': '1.5', 'material': 'O2'}]}, 'targets_formula': ['Li1 Fe1 P1 O4'], 'target': {'material_string': 'LiFePO4', 'material_name': '', 'material_formula': 'LiFePO4', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'LiFePO4', 'amount': '1', 'elements': {'Li': '1', 'Fe': '1', 'P': '1', 'O': '4'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, 'targets_formula_s': ['LiFePO4'], 'precursors_formula_s': ['Fe(CO2)2', 'PH9(NO2)2', 'LiH3(CO)2'], 'precursors': [{'material_string': 'FeC2O4·2H2O', 'material_name': '', 'material_formula': 'FeC2O4·2H2O', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'FeC2O4', 'amount': '1', 'elements': {'Fe': '1', 'C': '2', 'O': '4'}}, {'formula': 'H2O', 'amount': '2', 'elements': {'H': '2', 'O': '1'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, {'material_string': '(NH4)2HPO4', 'material_name': '', 'material_formula': '(NH4)2HPO4', 'phase': None, 'is_acronym': False, 'composition': [{'formula': '(NH4)2HPO4', 'amount': '1', 'elements': {'N': '2', 'H': '9', 'P': '1', 'O': '4'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}, {'material_string': 'CH3COOLi·2H2O', 'material_name': '', 'material_formula': 'CH3COOLi·2H2O', 'phase': None, 'is_acronym': False, 'composition': [{'formula': 'CH3COOLi', 'amount': '1', 'elements': {'C': '2', 'H': '3', 'O': '2', 'Li': '1'}}, {'formula': 'H2O', 'amount': '2', 'elements': {'H': '2', 'O': '1'}}], 'amounts_vars': {}, 'elements_vars': {}, 'additives': [], 'oxygen_deficiency': 'None'}], 'operations': [{'type': 'StartingSynthesis', 'token': 'synthesized', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'MixingOperation', 'token': 'mixed', 'conditions': {'heating_temperature': [], 'heating_time': [], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'HeatingOperation', 'token': 'pre-treated', 'conditions': {'heating_temperature': [{'min_value': 400.0, 'max_value': 400.0, 'values': [400.0], 'units': '°C'}], 'heating_time': [{'min_value': 4.0, 'max_value': 4.0, 'values': [4.0], 'units': 'h'}], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'HeatingOperation', 'token': 'calcined', 'conditions': {'heating_temperature': [{'min_value': 850.0, 'max_value': 850.0, 'values': [850.0], 'units': '°C'}], 'heating_time': [{'min_value': 12.0, 'max_value': 12.0, 'values': [12.0], 'units': 'h'}], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}, {'type': 'MixingOperation', 'token': 'milled', 'conditions': {'heating_temperature': [], 'heating_time': [{'min_value': 15.0, 'max_value': 15.0, 'values': [15.0], 'units': 'min'}], 'heating_atmosphere': [], 'mixing_device': None, 'mixing_media': None}}], 'search_score': 3.761554718017578, 'highlights': [{'score': 1.0416139364242554, 'path': 'paragraph_string', 'texts': [{'value': 'Pristine ', 'type': 'text'}, {'value': 'LiFePO4', 'type': 'hit'}, {'value': ' sample was synthesized by a traditional solid-state reaction using CH3COOLi·2H2O, ...', 'type': 'text'}]}], 'total_doc': 192}]\u001b[0m```\n",
      "{\n",
      "  \"action\": \"Final Answer\",\n",
      "  \"action_input\": {\n",
      "    \"synthesis_procedure\": [\n",
      "      {\n",
      "        \"step\": 1,\n",
      "        \"description\": \"Prepare the precursors: Li2CO3 and FePO4(H2O)2.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 2,\n",
      "        \"description\": \"Mix the precursors in the appropriate stoichiometric ratio.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 3,\n",
      "        \"description\": \"Add isopropanol as a mixing media and mix thoroughly.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 4,\n",
      "        \"description\": \"Dry the mixture to remove excess solvent.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 5,\n",
      "        \"description\": \"Heat the dried mixture in an argon atmosphere at 700°C.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 6,\n",
      "        \"description\": \"Cool the product to room temperature.\"\n",
      "      }\n",
      "    ],\n",
      "    \"reaction\": \"1 FePO4(H2O)2 + 0.5 Li2CO3 == 1 LiFePO4 + 0.5 CO2 + 2 H2O + 0.25 O2\",\n",
      "    \"reference\": \"DOI: 10.1016/j.jpowsour.2008.08.028\"\n",
      "  }\n",
      "}\n",
      "```\u001b[32;1m\u001b[1;3m```\n",
      "{\n",
      "  \"action\": \"Final Answer\",\n",
      "  \"action_input\": {\n",
      "    \"synthesis_procedure\": [\n",
      "      {\n",
      "        \"step\": 1,\n",
      "        \"description\": \"Prepare the precursors: Li2CO3 and FePO4(H2O)2.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 2,\n",
      "        \"description\": \"Mix the precursors in the appropriate stoichiometric ratio.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 3,\n",
      "        \"description\": \"Add isopropanol as a mixing media and mix thoroughly.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 4,\n",
      "        \"description\": \"Dry the mixture to remove excess solvent.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 5,\n",
      "        \"description\": \"Heat the dried mixture in an argon atmosphere at 700°C.\"\n",
      "      },\n",
      "      {\n",
      "        \"step\": 6,\n",
      "        \"description\": \"Cool the product to room temperature.\"\n",
      "      }\n",
      "    ],\n",
      "    \"reaction\": \"1 FePO4(H2O)2 + 0.5 Li2CO3 == 1 LiFePO4 + 0.5 CO2 + 2 H2O + 0.25 O2\",\n",
      "    \"reference\": \"DOI: 10.1016/j.jpowsour.2008.08.028\"\n",
      "  }\n",
      "}\n",
      "```\u001b[0m\n",
      "\n",
      "\u001b[1m> Finished chain.\u001b[0m\n",
      "\u001b[36;1m\u001b[1;3m{'input': 'How to synthesize LiFePO4? Please provide a detailed step-by-step procedure and the reference.', 'output': {'synthesis_procedure': [{'step': 1, 'description': 'Prepare the precursors: Li2CO3 and FePO4(H2O)2.'}, {'step': 2, 'description': 'Mix the precursors in the appropriate stoichiometric ratio.'}, {'step': 3, 'description': 'Add isopropanol as a mixing media and mix thoroughly.'}, {'step': 4, 'description': 'Dry the mixture to remove excess solvent.'}, {'step': 5, 'description': 'Heat the dried mixture in an argon atmosphere at 700°C.'}, {'step': 6, 'description': 'Cool the product to room temperature.'}], 'reaction': '1 FePO4(H2O)2 + 0.5 Li2CO3 == 1 LiFePO4 + 0.5 CO2 + 2 H2O + 0.25 O2', 'reference': 'DOI: 10.1016/j.jpowsour.2008.08.028'}}\u001b[0mDo I need to use a tool? No  \n",
      "Final Answer: To synthesize LiFePO4, follow this detailed step-by-step procedure:\n",
      "\n",
      "1. **Prepare the precursors**: Use Li2CO3 and FePO4(H2O)2.\n",
      "2. **Mix the precursors**: Combine the precursors in the appropriate stoichiometric ratio.\n",
      "3. **Add isopropanol**: Use isopropanol as a mixing media and mix thoroughly.\n",
      "4. **Dry the mixture**: Remove excess solvent by drying the mixture.\n",
      "5. **Heat the dried mixture**: Heat it in an argon atmosphere at 700°C.\n",
      "6. **Cool the product**: Allow the product to cool to room temperature.\n",
      "\n",
      "**Reaction**: \n",
      "\\[ 1 \\text{ FePO}_4(\\text{H}_2\\text{O})_2 + 0.5 \\text{ Li}_2\\text{CO}_3 \\rightarrow 1 \\text{ LiFePO}_4 + 0.5 \\text{ CO}_2 + 2 \\text{ H}_2\\text{O} + 0.25 \\text{ O}_2 \\]\n",
      "\n",
      "**Reference**: DOI: [10.1016/j.jpowsour.2008.08.028](https://doi.org/10.1016/j.jpowsour.2008.08.028)\n",
      "\n",
      "If you have any further questions or need more information, feel free to ask!  \n",
      "Bye.\u001b[32;1m\u001b[1;3mDo I need to use a tool? No  \n",
      "Final Answer: To synthesize LiFePO4, follow this detailed step-by-step procedure:\n",
      "\n",
      "1. **Prepare the precursors**: Use Li2CO3 and FePO4(H2O)2.\n",
      "2. **Mix the precursors**: Combine the precursors in the appropriate stoichiometric ratio.\n",
      "3. **Add isopropanol**: Use isopropanol as a mixing media and mix thoroughly.\n",
      "4. **Dry the mixture**: Remove excess solvent by drying the mixture.\n",
      "5. **Heat the dried mixture**: Heat it in an argon atmosphere at 700°C.\n",
      "6. **Cool the product**: Allow the product to cool to room temperature.\n",
      "\n",
      "**Reaction**: \n",
      "\\[ 1 \\text{ FePO}_4(\\text{H}_2\\text{O})_2 + 0.5 \\text{ Li}_2\\text{CO}_3 \\rightarrow 1 \\text{ LiFePO}_4 + 0.5 \\text{ CO}_2 + 2 \\text{ H}_2\\text{O} + 0.25 \\text{ O}_2 \\]\n",
      "\n",
      "**Reference**: DOI: [10.1016/j.jpowsour.2008.08.028](https://doi.org/10.1016/j.jpowsour.2008.08.028)\n",
      "\n",
      "If you have any further questions or need more information, feel free to ask!  \n",
      "Bye.\u001b[0m\n",
      "\n",
      "\u001b[1m> Finished chain.\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "response = agent_executor.invoke({\n",
    "    \"input\": \"How to synthesis LiFePO4? Please provide a detailed step-by-step procedure and the reference.\",\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "To synthesize LiFePO4, follow this detailed step-by-step procedure:\n",
      "\n",
      "1. **Prepare the precursors**: Use Li2CO3 and FePO4(H2O)2.\n",
      "2. **Mix the precursors**: Combine the precursors in the appropriate stoichiometric ratio.\n",
      "3. **Add isopropanol**: Use isopropanol as a mixing media and mix thoroughly.\n",
      "4. **Dry the mixture**: Remove excess solvent by drying the mixture.\n",
      "5. **Heat the dried mixture**: Heat it in an argon atmosphere at 700°C.\n",
      "6. **Cool the product**: Allow the product to cool to room temperature.\n",
      "\n",
      "**Reaction**: \n",
      "\\[ 1 \\text{ FePO}_4(\\text{H}_2\\text{O})_2 + 0.5 \\text{ Li}_2\\text{CO}_3 \\rightarrow 1 \\text{ LiFePO}_4 + 0.5 \\text{ CO}_2 + 2 \\text{ H}_2\\text{O} + 0.25 \\text{ O}_2 \\]\n",
      "\n",
      "**Reference**: DOI: [10.1016/j.jpowsour.2008.08.028](https://doi.org/10.1016/j.jpowsour.2008.08.028)\n",
      "\n",
      "If you have any further questions or need more information, feel free to ask!  \n",
      "Bye.\n"
     ]
    }
   ],
   "source": [
    "print(response[\"output\"])"
   ]
  }
 ],
 "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
}
