{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Predict comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import vowpalwabbit\n",
    "\n",
    "\n",
    "def my_predict(vw, ex):\n",
    "    pp = 0.0\n",
    "    for f, v in ex.iter_features():\n",
    "        pp += vw.get_weight(f) * v\n",
    "    return pp\n",
    "\n",
    "\n",
    "def ensure_close(a, b, eps=1e-6):\n",
    "    if abs(a - b) > eps:\n",
    "        raise Exception(\n",
    "            \"test failed: expected \"\n",
    "            + str(a)\n",
    "            + \" and \"\n",
    "            + str(b)\n",
    "            + \" to be \"\n",
    "            + str(eps)\n",
    "            + \"-close, but they differ by \"\n",
    "            + str(abs(a - b))\n",
    "        )\n",
    "\n",
    "\n",
    "###############################################################################\n",
    "vw = vowpalwabbit.Workspace(\"--quiet\")\n",
    "\n",
    "\n",
    "###############################################################################\n",
    "vw.learn(\"1 |x a b\")\n",
    "\n",
    "\n",
    "###############################################################################\n",
    "print(\"# do some stuff with a read example:\")\n",
    "ex = vw.example(\"1 |x a b |y c\")\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "\n",
    "updated_pred = ex.get_updated_prediction()\n",
    "print(\"current partial prediction =\", updated_pred)\n",
    "\n",
    "# compute our own prediction\n",
    "print(\n",
    "    \"        my view of example =\",\n",
    "    str([(f, v, vw.get_weight(f)) for f, v in ex.iter_features()]),\n",
    ")\n",
    "my_pred = my_predict(vw, ex)\n",
    "print(\"     my partial prediction =\", my_pred)\n",
    "ensure_close(updated_pred, my_pred)\n",
    "print(\"\")\n",
    "vw.finish_example(ex)\n",
    "\n",
    "###############################################################################\n",
    "print(\"# make our own example from scratch\")\n",
    "ex = vw.example()\n",
    "ex.set_label_string(\"0\")\n",
    "ex.push_features(\"x\", [\"a\", \"b\"])\n",
    "ex.push_features(\"y\", [(\"c\", 1.0)])\n",
    "ex.setup_example()\n",
    "\n",
    "print(\n",
    "    \"        my view of example =\",\n",
    "    str([(f, v, vw.get_weight(f)) for f, v in ex.iter_features()]),\n",
    ")\n",
    "my_pred2 = my_predict(vw, ex)\n",
    "print(\"     my partial prediction =\", my_pred2)\n",
    "ensure_close(my_pred, my_pred2)\n",
    "\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "print(\"  final partial prediction =\", ex.get_updated_prediction())\n",
    "ensure_close(ex.get_updated_prediction(), my_predict(vw, ex))\n",
    "print(\"\")\n",
    "vw.finish_example(ex)\n",
    "\n",
    "\n",
    "###############################################################################\n",
    "exList = []\n",
    "for i in range(120):\n",
    "    ex = vw.example()\n",
    "    exList.append(ex)\n",
    "\n",
    "# this is the safe way to delete the examples for VW to reuse:\n",
    "for ex in exList:\n",
    "    vw.finish_example(ex)\n",
    "\n",
    "exList = []  # this should __del__ the examples, we hope :)\n",
    "for i in range(120):\n",
    "    ex = vw.example()\n",
    "    exList.append(ex)\n",
    "\n",
    "for ex in exList:\n",
    "    vw.finish_example(ex)\n",
    "\n",
    "\n",
    "###############################################################################\n",
    "\n",
    "for i in range(2):\n",
    "    ex = vw.example(\"1 foo| a b\")\n",
    "    ex.learn()\n",
    "    print(\"tag =\", ex.get_tag())\n",
    "    print(\"partial pred =\", ex.get_partial_prediction())\n",
    "    print(\"loss =\", ex.get_loss())\n",
    "\n",
    "    print(\"label =\", ex.get_label())\n",
    "    vw.finish_example(ex)\n",
    "\n",
    "\n",
    "# to be safe, finish explicity (should happen by default anyway)\n",
    "vw.finish()\n",
    "\n",
    "\n",
    "###############################################################################\n",
    "print(\"# test some save/load behavior\")\n",
    "vw = vowpalwabbit.Workspace(\"--quiet -f test.model\")\n",
    "ex = vw.example(\"1 |x a b |y c\")\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "ex.learn()\n",
    "before_save = ex.get_updated_prediction()\n",
    "print(\"before saving, prediction =\", before_save)\n",
    "vw.finish_example(ex)\n",
    "\n",
    "vw.finish()  # this should create the file\n",
    "\n",
    "# now re-start vw by loading that model\n",
    "vw = vowpalwabbit.Workspace(\"--quiet -i test.model\")\n",
    "ex = vw.example(\"1 |x a b |y c\")  # test example\n",
    "ex.learn()\n",
    "after_save = ex.get_partial_prediction()\n",
    "print(\" after saving, prediction =\", after_save)\n",
    "vw.finish_example(ex)\n",
    "\n",
    "ensure_close(before_save, after_save)\n",
    "vw.finish()  # this should create the file\n",
    "\n",
    "print(\"done!\")"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "2cc929a270071711921cb2ad25a09768257b52278ee4b98c603d8d8861a97a9a"
  },
  "kernelspec": {
   "display_name": "Python 3.9.7 64-bit ('test': conda)",
   "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.9.7"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
