diff --git a/week09/inClass_week09.ipynb b/week09/inClass_week09.ipynb index 9b9744c..c1d4ccc 100644 --- a/week09/inClass_week09.ipynb +++ b/week09/inClass_week09.ipynb @@ -2124,9 +2124,633 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 33, "id": "3eff0459", "metadata": {}, + "outputs": [ + { + "data": { + "text/html": [ + "\n", + "\n", + "
\n", + "" + ], + "text/plain": [ + "alt.HConcatChart(...)" + ] + }, + "execution_count": 33, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "chart = alt.HConcatChart(hconcat=[chart1,chart2])\n", + "chart" + ] + }, + { + "cell_type": "code", + "execution_count": 35, + "id": "cc280a3a", + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "\u001b[0;31mSignature:\u001b[0m\n", + "\u001b[0malt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mselection_interval\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'str | None'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mvalue\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[Any]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mbind\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[Binding | str]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mempty\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[bool]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mexpr\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[str | Expr | Expression]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mencodings\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[list[SingleDefUnitChannel_T]]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mon\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[str]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mclear\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[str | bool]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mresolve\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[SelectionResolution_T]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mmark\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[Mark]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mtranslate\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[str | bool]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0mzoom\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Optional[str | bool]'\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mUndefined\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwds\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m'Any'\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\n", + "\u001b[0;34m\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m->\u001b[0m \u001b[0;34m'Parameter'\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n", + "\u001b[0;31mDocstring:\u001b[0m\n", + "Create an interval selection parameter. Selection parameters define data queries that are driven by direct manipulation from user input (e.g., mouse clicks or drags). Interval selection parameters are used to select a continuous range of data values on drag, whereas point selection parameters (`selection_point`) are used to select multiple discrete data values.).\n", + "\n", + "Parameters\n", + "----------\n", + "name : string (optional)\n", + " The name of the parameter. If not specified, a unique name will be\n", + " created.\n", + "value : any (optional)\n", + " The default value of the parameter. If not specified, the parameter\n", + " will be created without a default value.\n", + "bind : :class:`Binding`, str (optional)\n", + " Binds the parameter to an external input element such as a slider,\n", + " selection list or radio button group.\n", + "empty : boolean (optional)\n", + " For selection parameters, the predicate of empty selections returns\n", + " True by default. Override this behavior, by setting this property\n", + " 'empty=False'.\n", + "expr : :class:`Expr` (optional)\n", + " An expression for the value of the parameter. This expression may\n", + " include other parameters, in which case the parameter will\n", + " automatically update in response to upstream parameter changes.\n", + "encodings : List[str] (optional)\n", + " A list of encoding channels. The corresponding data field values\n", + " must match for a data tuple to fall within the selection.\n", + "on : string (optional)\n", + " A Vega event stream (object or selector) that triggers the selection.\n", + " For interval selections, the event stream must specify a start and end.\n", + "clear : string or boolean (optional)\n", + " Clears the selection, emptying it of all values. This property can\n", + " be an Event Stream or False to disable clear. Default is 'dblclick'.\n", + "resolve : enum('global', 'union', 'intersect') (optional)\n", + " With layered and multi-view displays, a strategy that determines\n", + " how selections' data queries are resolved when applied in a filter\n", + " transform, conditional encoding rule, or scale domain.\n", + " One of:\n", + "\n", + " * 'global': only one brush exists for the entire SPLOM. When the\n", + " user begins to drag, any previous brushes are cleared, and a\n", + " new one is constructed.\n", + " * 'union': each cell contains its own brush, and points are\n", + " highlighted if they lie within any of these individual brushes.\n", + " * 'intersect': each cell contains its own brush, and points are\n", + " highlighted only if they fall within all of these individual\n", + " brushes.\n", + "\n", + " The default is 'global'.\n", + "mark : :class:`Mark` (optional)\n", + " An interval selection also adds a rectangle mark to depict the\n", + " extents of the interval. The mark property can be used to\n", + " customize the appearance of the mark.\n", + "translate : string or boolean (optional)\n", + " When truthy, allows a user to interactively move an interval\n", + " selection back-and-forth. Can be True, False (to disable panning),\n", + " or a Vega event stream definition which must include a start and\n", + " end event to trigger continuous panning. Discrete panning (e.g.,\n", + " pressing the left/right arrow keys) will be supported in future\n", + " versions.\n", + " The default value is True, which corresponds to\n", + " [pointerdown, window:pointerup] > window:pointermove!\n", + " This default allows users to click and drag within an interval\n", + " selection to reposition it.\n", + "zoom : string or boolean (optional)\n", + " When truthy, allows a user to interactively resize an interval\n", + " selection. Can be True, False (to disable zooming), or a Vega\n", + " event stream definition. Currently, only wheel events are supported,\n", + " but custom event streams can still be used to specify filters,\n", + " debouncing, and throttling. Future versions will expand the set of\n", + " events that can trigger this transformation.\n", + " The default value is True, which corresponds to wheel!. This\n", + " default allows users to use the mouse wheel to resize an interval\n", + " selection.\n", + "**kwds :\n", + " Additional keywords to control the selection.\n", + "\n", + "Returns\n", + "-------\n", + "parameter: Parameter\n", + " The parameter object that can be used in chart creation.\n", + "\u001b[0;31mFile:\u001b[0m /opt/anaconda3/envs/DataViz2/lib/python3.10/site-packages/altair/vegalite/v5/api.py\n", + "\u001b[0;31mType:\u001b[0m function" + ] + } + ], + "source": [ + "alt.selection_interval?" + ] + }, + { + "cell_type": "code", + "execution_count": 36, + "id": "057bc8fe", + "metadata": {}, + "outputs": [], + "source": [ + "brush = alt.selection_interval()" + ] + }, + { + "cell_type": "code", + "execution_count": 37, + "id": "a06e84da", + "metadata": {}, + "outputs": [ + { + "data": { + "text/html": [ + "\n", + "\n", + "\n", + "" + ], + "text/plain": [ + "alt.Chart(...)" + ] + }, + "execution_count": 37, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "chart1.add_params(\n", + " brush\n", + ")" + ] + }, + { + "cell_type": "code", + "execution_count": 38, + "id": "361a3179", + "metadata": {}, + "outputs": [], + "source": [ + "brush = alt.selection_interval(encodings=['x','y'])" + ] + }, + { + "cell_type": "code", + "execution_count": 39, + "id": "14d5c6c1", + "metadata": {}, + "outputs": [ + { + "data": { + "text/html": [ + "\n", + "\n", + "\n", + "" + ], + "text/plain": [ + "alt.Chart(...)" + ] + }, + "execution_count": 39, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "chart1 = alt.Chart.from_dict({\n", + " # Data\n", + " \"data\": {\"url\":\"https://raw.githubusercontent.com/UIUC-iSchool-DataViz/is445_data/main/mobility.csv\"},\n", + " #// Marks\n", + " \"mark\":\"rect\",\n", + " \"height\":400,\n", + " # Encoding (note:error for encoding vs encodings)\n", + " \"encoding\":{\n", + " \"x\":{\"bin\":{\"maxbins\":10}, \"field\":\"Student_teacher_ratio\", \"type\":\"quantitative\"},\n", + " \"y\":{\"field\":\"State\",\"type\":\"ordinal\"},\n", + " \"color\":{\"aggregate\":\"count\", \"type\":\"quantitative\"} \n", + " # will show the number of records with a specific student/teacher ratio in a particular state\n", + " }\n", + " \n", + "}).add_params(\n", + " brush\n", + ")\n", + "chart1" + ] + }, + { + "cell_type": "code", + "execution_count": 40, + "id": "e9b770f1", + "metadata": {}, + "outputs": [ + { + "data": { + "text/html": [ + "\n", + "\n", + "\n", + "" + ], + "text/plain": [ + "alt.Chart(...)" + ] + }, + "execution_count": 40, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "chart2 = alt.Chart.from_dict({\n", + " # Data\n", + " \"data\":{\"url\":\"https://raw.githubusercontent.com/UIUC-iSchool-DataViz/is445_data/main/mobility.csv\"},\n", + " # mark\n", + " \"mark\":\"bar\",\n", + " # encoding\n", + " \"encoding\":{\n", + " \"x\":{\"field\":\"Mobility\", \"bin\":True, \"type\":\"quantitative\", \"axis\":{\"title\":\"Mobility Score\"}}, \n", + " \"y\":{\"aggregate\":\"count\", \"type\":\"quantitative\", \"axis\":{\"title\":\"Mobility Score Distribution\"}}\n", + " }\n", + "}\n", + ").transform_filter(\n", + " brush\n", + ")\n", + "\n", + "chart2" + ] + }, + { + "cell_type": "code", + "execution_count": 41, + "id": "64f256dc", + "metadata": {}, + "outputs": [], + "source": [ + "chart = chart1 | chart2" + ] + }, + { + "cell_type": "code", + "execution_count": 42, + "id": "8ffdade4", + "metadata": {}, + "outputs": [ + { + "data": { + "text/html": [ + "\n", + "\n", + "\n", + "" + ], + "text/plain": [ + "alt.HConcatChart(...)" + ] + }, + "execution_count": 42, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "chart" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "2ceefacd", + "metadata": {}, "outputs": [], "source": [] }