{ "cells": [ { "cell_type": "markdown", "id": "67444357-8996-4ca3-8746-96d5589aed15", "metadata": {}, "source": [ "# Basics\n", "\n", ":::{note}\n", "What you see in this notebook will depend on whether you've run this notebook before and written annotations to the `annotations.db` database! For reproducibility, the rest of the notebook will assume the `annotations.db` has been deleted (if it exists).\n", ":::\n", "\n", "\n", "## Setup\n", "\n", "This basic example will be of a time series where we want to annotate various time intervals to illustrate the basics of the annotation system. Note that annotators can annotate all sorts of elements (e.g., `Image`, `Scatter`, etc.) with many different region types, which will be demonstrated later." ] }, { "cell_type": "code", "execution_count": null, "id": "8cc9c2a3", "metadata": {}, "outputs": [], "source": [ "import holoviews as hv\n", "import numpy as np\n", "import pandas as pd\n", "from holonote.annotate import Annotator\n", "\n", "hv.extension(\"bokeh\")\n", "\n", "xvals = np.linspace(-4, 0, 202)\n", "yvals = np.linspace(4, 0, 202)\n", "xs, ys = np.meshgrid(xvals, yvals)\n", "\n", "alpha, beta = 1,0\n", "image = hv.Image(np.sin(((ys/alpha)**alpha+beta)*xs), kdims=['A', 'B']).opts(cmap='greens')\n", "image" ] }, { "cell_type": "markdown", "id": "f321dd2a-3578-4226-8db0-6968a83e36ac", "metadata": {}, "source": [ "In the simplest case, simply wrap the element (here in a curve) in an `Annotator`:" ] }, { "cell_type": "code", "execution_count": null, "id": "c595fd14-ebc8-4ad3-930b-c10e9bf13166", "metadata": {}, "outputs": [], "source": [ "annotator = Annotator(image, fields=['description'])" ] }, { "cell_type": "markdown", "id": "05eb35b0-cb78-4653-806d-4d721fd6aa25", "metadata": {}, "source": [ "The `fields` argument lists the fields associated with the annotations we will be defining. When working with tabular data (the typical case), you can think of fields as the columns of your table containing information about annotated regions.\n", "\n", "Here we supplied an element to annotator to the `Annotator` but note that most of the functionality of annotators can be made available by specifying the key dimensions and their types. The following is equivalent to the above declaration:\n", "\n", "```python\n", "annotator = Annotator({'A': np.float64, 'B': np.float64}, fields=['description'])\n", "```\n", "\n", "Now we can create an overlay of our element, a dynamicmap that shows the defined annotation regions and a dynamicmap used to define new regions:" ] }, { "cell_type": "code", "execution_count": null, "id": "ffdea745-31ef-4c16-9dfe-4303e78067a2", "metadata": {}, "outputs": [], "source": [ "annotator * image # If you have a database file generated by a previous run, your annotations will now be displayed" ] }, { "cell_type": "markdown", "id": "616fd061-fffd-4f1a-94ce-dc8bc6b9d5bd", "metadata": {}, "source": [ "