{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e25a6874-54d9-4167-82ed-ab2f4fdc0a6f",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext pdl.pdl_notebook_ext"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f3c62df1-0347-4711-acd7-3892cfd5df30",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Hello,\u001b[32m World\u001b[0m\u001b[32m!\u001b[0m"
     ]
    },
    {
     "data": {
      "text/html": [
       "\n",
       "<!DOCTYPE html>\n",
       "<html>\n",
       "\n",
       "<head>\n",
       "  <meta charset=\"utf-8\" />\n",
       "\n",
       "  <!-- Styling -->\n",
       "  <!-- <link rel=\"stylesheet\" href=\"css/index.css\"> -->\n",
       "  <style>\n",
       "    .pdl_block {\n",
       "      border-radius: 3px;\n",
       "      margin: 3px;\n",
       "      padding: 5px;\n",
       "      margin: 2px;\n",
       "      vertical-align: middle;\n",
       "      display: inline-block;\n",
       "    }\n",
       "\n",
       "    .pdl_show_result_false {\n",
       "      color: rgba(0, 0, 0, 0.5);\n",
       "    }\n",
       "\n",
       "    .pdl_string {\n",
       "      background-color: antiquewhite;\n",
       "    }\n",
       "\n",
       "    .pdl_empty {\n",
       "      background-color: rgb(238, 184, 112);\n",
       "    }\n",
       "\n",
       "    .pdl_text {\n",
       "      background-color: rgb(219, 215, 250);\n",
       "    }\n",
       "\n",
       "    .pdl_model {\n",
       "      background-color: rgb(215, 250, 224);\n",
       "    }\n",
       "\n",
       "    .pdl_code {\n",
       "      background-color: rgb(250, 215, 225);\n",
       "    }\n",
       "\n",
       "    .pdl_api {\n",
       "      background-color: rgb(122, 246, 113);\n",
       "    }\n",
       "\n",
       "    .pdl_get {\n",
       "      background-color: rgb(125, 229, 243);\n",
       "    }\n",
       "\n",
       "    .pdl_data {\n",
       "      background-color: rgb(146, 181, 245);\n",
       "    }\n",
       "\n",
       "    .pdl_if {\n",
       "      background-color: rgb(248, 99, 141);\n",
       "    }\n",
       "\n",
       "    .pdl_repeat {\n",
       "      background-color: rgb(251, 201, 86);\n",
       "    }\n",
       "\n",
       "    .pdl_repeat_until {\n",
       "      background-color: rgb(243, 209, 77);\n",
       "    }\n",
       "\n",
       "    .pdl_for {\n",
       "      background-color: rgb(245, 241, 133);\n",
       "    }\n",
       "\n",
       "    .pdl_read {\n",
       "      background-color: rgb(243, 77, 113);\n",
       "    }\n",
       "\n",
       "    .pdl_include {\n",
       "      background-color: rgb(245, 18, 67);\n",
       "    }\n",
       "\n",
       "    .pdl_function {\n",
       "      background-color: rgb(77, 243, 132);\n",
       "    }\n",
       "    .pdl_call {\n",
       "      background-color: rgb(80, 243, 77);\n",
       "    }\n",
       "\n",
       "  </style>\n",
       "\n",
       "  <!-- Main script -->\n",
       "  <script src=\"https://ibm.github.io/prompt-declaration-language/dist/bundle.js\"></script>\n",
       "\n",
       "  <!-- Multi column layout -->\n",
       "  <link rel=\"stylesheet\" type=\"text/css\" href=\"https://rawgit.com/vitmalina/w2ui/master/dist/w2ui.min.css\">\n",
       "\n",
       "\n",
       "</head>\n",
       "\n",
       "<body>\n",
       "\n",
       "\n",
       "  <!-- Main window -->\n",
       "  <div id=\"mainview\">\n",
       "\n",
       "    <!-- Main window layout -->\n",
       "    <div id=\"layout\" style=\"width: 95%; height: 400px;\"></div>\n",
       "    <script type=\"module\">\n",
       "      import { w2layout } from 'https://rawgit.com/vitmalina/w2ui/master/dist/w2ui.es6.min.js'\n",
       "\n",
       "      let pstyle = 'border: 1px solid #efefef; padding: 5px'\n",
       "      new w2layout({\n",
       "        box: '#layout',\n",
       "        name: 'layout',\n",
       "        panels: [\n",
       "          { type: 'left', size: 600, resizable: true, style: pstyle, html: '<div id=\"doc\"></div>' },\n",
       "          { type: 'main', style: pstyle, html: '<div id=\"code\"></div>' }\n",
       "        ]\n",
       "      })\n",
       "      const data = {\"kind\": \"text\", \"description\": \"Model call\", \"defs\": {}, \"text\": [\"Hello,\", {\"kind\": \"model\", \"defs\": {}, \"platform\": \"litellm\", \"model\": \"watsonx/ibm/granite-34b-code-instruct\", \"parameters\": {\"stop\": [\"!\"], \"include_stop_sequence\": true}, \"result\": \" World!\", \"location\": {\"path\": [\"text\", \"[1]\"], \"file\": \"\", \"table\": {\"['description']\": 1, \"['text']\": 2, \"['text', '[0]']\": 3, \"['text', '[1]']\": 4, \"['text', '[1]', 'model']\": 4, \"['text', '[1]', 'parameters']\": 5, \"['text', '[1]', 'parameters', 'stop']\": 6, \"['text', '[1]', 'parameters', 'include_stop_sequence']\": 7}}}], \"result\": \"Hello, World!\", \"location\": {\"path\": [], \"file\": \"\", \"table\": {\"['description']\": 1, \"['text']\": 2, \"['text', '[0]']\": 3, \"['text', '[1]']\": 4, \"['text', '[1]', 'model']\": 4, \"['text', '[1]', 'parameters']\": 5, \"['text', '[1]', 'parameters', 'stop']\": 6, \"['text', '[1]', 'parameters', 'include_stop_sequence']\": 7}}}\n",
       "      pdl_viewer.replace_div('doc', pdl_viewer.show_output(data))\n",
       "\n",
       "    </script>\n",
       "\n",
       "  </div>\n",
       "\n",
       "</body>\n",
       "\n",
       "</html>\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "%%pdl --viewer\n",
    "description: Model call\n",
    "text: \n",
    "- Hello,\n",
    "- model: \"replicate/ibm-granite/granite-3.0-8b-instruct\"\n",
    "  parameters:\n",
    "    stop_sequences: \"!\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b72c204-b8de-45b2-9beb-9c6565d28de2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pdl-3.12",
   "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
