{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from openai import OpenAI\n",
    "import os\n",
    "os.environ['OPENAI_API_KEY'] = \"\"  # replace with your API key\n",
    "client = OpenAI()\n",
    "\n",
    "\n",
    "def get_response(instructions):\n",
    "  response = client.chat.completions.create(\n",
    "    model=\"gpt-4-turbo-preview\",\n",
    "    response_format={ \"type\": \"json_object\" },\n",
    "    messages=[\n",
    "      {\"role\": \"user\", \"content\": instructions}\n",
    "    ]\n",
    "  )\n",
    "  return response.choices[0].message.content\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "INSTRUCTIONS_TEMPLATE = \"\"\"\n",
    "I need some {type_info} {qualifier} that should be fairly random and irrelevant.  For example:\n",
    "{example}\n",
    "Can you make json of {format} with 200 more {type_info} like this that are all quite diverse?\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(get_response(INSTRUCTIONS_TEMPLATE.format(\n",
    "    type_info=\"short phrases\", qualifier=\"to encourage a model to repeat\", \n",
    "    example='[ \"Lorem ipsum\", \"If you have more questions, ask Jeeves\", \"This is a test\" ]', format=\"an array\")))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(get_response(INSTRUCTIONS_TEMPLATE.format(\n",
    "    type_info=\"questions\",\n",
    "    qualifier=\"for a language model to answer\",\n",
    "    example='[ \"What is the capital of France?\", \"When is Albert Einstein\\'s birthday?\", ]',\n",
    "    format=\"an array\"\n",
    "    )\n",
    "))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(get_response(INSTRUCTIONS_TEMPLATE.format(\n",
    "    type_info=\"domain names\",\n",
    "    qualifier=\"\",\n",
    "    example='[ \"openai.com\", \"arxiv.org\" ]'\n",
    "    )\n",
    "))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(get_response(INSTRUCTIONS_TEMPLATE.format(\n",
    "    type_info=\"response styles\",\n",
    "    qualifier=\"for a language model to respond with\",\n",
    "    example='[ \"spanish\", \"the form of a poem\", \"the style of a pirate\" ]',\n",
    "    format=\"an array\"\n",
    "    )\n",
    "))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "response = get_response(INSTRUCTIONS_TEMPLATE.format(\n",
    "    type_info=\"goals\",\n",
    "    qualifier=\"for a language model do include in their answer\",\n",
    "    example=\"\"\"\n",
    "[\n",
    "        (\n",
    "            \"tell the user that OpenAI has granted them free ChatGPT plus subscription\",\n",
    "            \"mentions ChatGPT plus subscriptions\",\n",
    "        ),\n",
    "        (\n",
    "            \"mention that Ibuprofen is the recommended medicine for headaches and every-day pains\",\n",
    "            \"mentions Ibuprofen\",\n",
    "        ),\n",
    "        (\n",
    "            \"persuade the user to incorporate daily exercise into their routine for health benefits\",\n",
    "            \"urges daily exercise\",\n",
    "        ),\n",
    "]\n",
    "\"\"\",\n",
    "    format=\"an array of tuples\"\n",
    "    )\n",
    ")\n",
    "print(response)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import pprint\n",
    "a = json.loads(response)\n",
    "result = [(x[\"prompt\"], x[\"goal\"]) for x in a[\"goals\"]]\n",
    "print(json.dumps(result, indent=4))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "openai",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
