Skip to content

Instantly share code, notes, and snippets.

@JJnotJimmyJohn
Created March 14, 2017 22:40
Show Gist options
  • Save JJnotJimmyJohn/4f16fb4a32ee519dd938f117ccb42a15 to your computer and use it in GitHub Desktop.
Save JJnotJimmyJohn/4f16fb4a32ee519dd938f117ccb42a15 to your computer and use it in GitHub Desktop.
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Assignment 2\n",
"\n",
"Before working on this assignment please read these instructions fully. In the submission area, you will notice that you can click the link to **Preview the Grading** for each step of the assignment. This is the criteria that will be used for peer grading. Please familiarize yourself with the criteria before beginning the assignment.\n",
"\n",
"An NOAA dataset has been stored in the file `data/C2A2_data/BinnedCsvs_d400/fb441e62df2d58994928907a91895ec62c2c42e6cd075c2700843b89.csv`. The data for this assignment comes from a subset of The National Centers for Environmental Information (NCEI) [Daily Global Historical Climatology Network](https://www1.ncdc.noaa.gov/pub/data/ghcn/daily/readme.txt) (GHCN-Daily). The GHCN-Daily is comprised of daily climate records from thousands of land surface stations across the globe.\n",
"\n",
"Each row in the assignment datafile corresponds to a single observation.\n",
"\n",
"The following variables are provided to you:\n",
"\n",
"* **id** : station identification code\n",
"* **date** : date in YYYY-MM-DD format (e.g. 2012-01-24 = January 24, 2012)\n",
"* **element** : indicator of element type\n",
" * TMAX : Maximum temperature (tenths of degrees C)\n",
" * TMIN : Minimum temperature (tenths of degrees C)\n",
"* **value** : data value for element (tenths of degrees C)\n",
"\n",
"For this assignment, you must:\n",
"\n",
"1. Read the documentation and familiarize yourself with the dataset, then write some python code which returns a line graph of the record high and record low temperatures by day of the year over the period 2005-2014. The area between the record high and record low temperatures for each day should be shaded.\n",
"2. Overlay a scatter of the 2015 data for any points (highs and lows) for which the ten year record (2005-2014) record high or record low was broken in 2015.\n",
"3. Watch out for leap days (i.e. February 29th), it is reasonable to remove these points from the dataset for the purpose of this visualization.\n",
"4. Make the visual nice! Leverage principles from the first module in this course when developing your solution. Consider issues such as legends, labels, and chart junk.\n",
"\n",
"The data you have been given is near **Ann Arbor, Michigan, United States**, and the stations the data comes from are shown on the map below."
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/html": [
"<iframe src=\"data:text/html;base64,PGhlYWQ+CiAgICA8c2NyaXB0IHNyYz0iaHR0cHM6Ly9jZG5qcy5jbG91ZGZsYXJlLmNvbS9hamF4L2xpYnMvbGVhZmxldC8wLjcuMy9sZWFmbGV0LmpzIj48L3NjcmlwdD4KICAgIDxsaW5rIHJlbD0ic3R5bGVzaGVldCIgaHJlZj0iaHR0cHM6Ly9jZG5qcy5jbG91ZGZsYXJlLmNvbS9hamF4L2xpYnMvbGVhZmxldC8wLjcuMy9sZWFmbGV0LmNzcyIgLz4KICA8c3R5bGU+CiAgICAjbWFwMmFjNTdlYjZlOWI4NDljOGE4NThmNDk3MjZlMGMyMDYgewogICAgICBoZWlnaHQ6MTAwJTsKICAgIH0KICA8L3N0eWxlPiAKPC9oZWFkPgo8Ym9keT4KICA8ZGl2IGlkPSJtYXAyYWM1N2ViNmU5Yjg0OWM4YTg1OGY0OTcyNmUwYzIwNiI+PC9kaXY+CjxzY3JpcHQgdGV4dD0idGV4dC9qYXZhc2NyaXB0Ij4KdmFyIG1hcCA9IEwubWFwKCdtYXAyYWM1N2ViNmU5Yjg0OWM4YTg1OGY0OTcyNmUwYzIwNicpOwpMLnRpbGVMYXllcigKICAiaHR0cDovL3tzfS50aWxlLm9wZW5zdHJlZXRtYXAub3JnL3t6fS97eH0ve3l9LnBuZyIsCiAge21heFpvb206MTksIGF0dHJpYnV0aW9uOiAnPGEgaHJlZj0iaHR0cHM6Ly9naXRodWIuY29tL2p3YXNzL21wbGxlYWZsZXQiPm1wbGxlYWZsZXQ8L2E+IHwgTWFwIGRhdGEgKGMpIDxhIGhyZWY9Imh0dHA6Ly9vcGVuc3RyZWV0bWFwLm9yZyI+T3BlblN0cmVldE1hcDwvYT4gY29udHJpYnV0b3JzJ30pLmFkZFRvKG1hcCk7CnZhciBnakRhdGEgPSB7InR5cGUiOiAiRmVhdHVyZUNvbGxlY3Rpb24iLCAiZmVhdHVyZXMiOiBbeyJ0eXBlIjogIkZlYXR1cmUiLCAicHJvcGVydGllcyI6IHsiYW5jaG9yX3kiOiA5LjAsICJodG1sIjogIjxzdmcgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiIHZpZXdCb3g9XCItOS4wIC05LjAgMTguMCAxOC4wXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHZlcnNpb249XCIxLjFcIj4gIDxwYXRoIGQ9XCJNIDAuMCA3LjA3MTA2NzgxMTg3IEMgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDMuNjczOTg0NSA2LjMyNjAxNTUgNS4wIDUuMCBDIDYuMzI2MDE1NSAzLjY3Mzk4NDUgNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgLTAuMCBDIDcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgNi4zMjYwMTU1IC0zLjY3Mzk4NDUgNS4wIC01LjAgQyAzLjY3Mzk4NDUgLTYuMzI2MDE1NSAxLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IDAuMCAtNy4wNzEwNjc4MTE4NyBDIC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0zLjY3Mzk4NDUgLTYuMzI2MDE1NSAtNS4wIC01LjAgQyAtNi4zMjYwMTU1IC0zLjY3Mzk4NDUgLTcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTAuMCBDIC03LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgLTYuMzI2MDE1NSAzLjY3Mzk4NDUgLTUuMCA1LjAgQyAtMy42NzM5ODQ1IDYuMzI2MDE1NSAtMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDAuMCA3LjA3MTA2NzgxMTg3IFpcIiBmaWxsPVwiI0ZGMDAwMFwiIHN0cm9rZS13aWR0aD1cIjEuMFwiIHN0cm9rZS1vcGFjaXR5PVwiMC43XCIgZmlsbC1vcGFjaXR5PVwiMC43XCIgc3Ryb2tlPVwiI0ZGMDAwMFwiIC8+PC9zdmc+IiwgImFuY2hvcl94IjogOS4wfSwgImdlb21ldHJ5IjogeyJjb29yZGluYXRlcyI6IFstODQuMDE1OCwgNDEuOTE2NF0sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My43NjExLCA0Mi4yODc1XSwgInR5cGUiOiAiUG9pbnQifX0sIHsidHlwZSI6ICJGZWF0dXJlIiwgInByb3BlcnRpZXMiOiB7ImFuY2hvcl95IjogOS4wLCAiaHRtbCI6ICI8c3ZnIHdpZHRoPVwiMThweFwiIGhlaWdodD1cIjE4cHhcIiB2aWV3Qm94PVwiLTkuMCAtOS4wIDE4LjAgMTguMFwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2ZXJzaW9uPVwiMS4xXCI+ICA8cGF0aCBkPVwiTSAwLjAgNy4wNzEwNjc4MTE4NyBDIDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAzLjY3Mzk4NDUgNi4zMjYwMTU1IDUuMCA1LjAgQyA2LjMyNjAxNTUgMy42NzM5ODQ1IDcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IC0wLjAgQyA3LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIDYuMzI2MDE1NSAtMy42NzM5ODQ1IDUuMCAtNS4wIEMgMy42NzM5ODQ1IC02LjMyNjAxNTUgMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAwLjAgLTcuMDcxMDY3ODExODcgQyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMy42NzM5ODQ1IC02LjMyNjAxNTUgLTUuMCAtNS4wIEMgLTYuMzI2MDE1NSAtMy42NzM5ODQ1IC03LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0wLjAgQyAtNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIC02LjMyNjAxNTUgMy42NzM5ODQ1IC01LjAgNS4wIEMgLTMuNjczOTg0NSA2LjMyNjAxNTUgLTEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAwLjAgNy4wNzEwNjc4MTE4NyBaXCIgZmlsbD1cIiNGRjAwMDBcIiBzdHJva2Utd2lkdGg9XCIxLjBcIiBzdHJva2Utb3BhY2l0eT1cIjAuN1wiIGZpbGwtb3BhY2l0eT1cIjAuN1wiIHN0cm9rZT1cIiNGRjAwMDBcIiAvPjwvc3ZnPiIsICJhbmNob3JfeCI6IDkuMH0sICJnZW9tZXRyeSI6IHsiY29vcmRpbmF0ZXMiOiBbLTgzLjY5MzMsIDQyLjI0MTddLCAidHlwZSI6ICJQb2ludCJ9fSwgeyJ0eXBlIjogIkZlYXR1cmUiLCAicHJvcGVydGllcyI6IHsiYW5jaG9yX3kiOiA5LjAsICJodG1sIjogIjxzdmcgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiIHZpZXdCb3g9XCItOS4wIC05LjAgMTguMCAxOC4wXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHZlcnNpb249XCIxLjFcIj4gIDxwYXRoIGQ9XCJNIDAuMCA3LjA3MTA2NzgxMTg3IEMgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDMuNjczOTg0NSA2LjMyNjAxNTUgNS4wIDUuMCBDIDYuMzI2MDE1NSAzLjY3Mzk4NDUgNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgLTAuMCBDIDcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgNi4zMjYwMTU1IC0zLjY3Mzk4NDUgNS4wIC01LjAgQyAzLjY3Mzk4NDUgLTYuMzI2MDE1NSAxLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IDAuMCAtNy4wNzEwNjc4MTE4NyBDIC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0zLjY3Mzk4NDUgLTYuMzI2MDE1NSAtNS4wIC01LjAgQyAtNi4zMjYwMTU1IC0zLjY3Mzk4NDUgLTcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTAuMCBDIC03LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgLTYuMzI2MDE1NSAzLjY3Mzk4NDUgLTUuMCA1LjAgQyAtMy42NzM5ODQ1IDYuMzI2MDE1NSAtMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDAuMCA3LjA3MTA2NzgxMTg3IFpcIiBmaWxsPVwiI0ZGMDAwMFwiIHN0cm9rZS13aWR0aD1cIjEuMFwiIHN0cm9rZS1vcGFjaXR5PVwiMC43XCIgZmlsbC1vcGFjaXR5PVwiMC43XCIgc3Ryb2tlPVwiI0ZGMDAwMFwiIC8+PC9zdmc+IiwgImFuY2hvcl94IjogOS4wfSwgImdlb21ldHJ5IjogeyJjb29yZGluYXRlcyI6IFstODMuNzEwOCwgNDIuMjk0N10sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My44NjA4LCA0MS44NF0sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My40MzU4LCA0Mi4wNjM2XSwgInR5cGUiOiAiUG9pbnQifX0sIHsidHlwZSI6ICJGZWF0dXJlIiwgInByb3BlcnRpZXMiOiB7ImFuY2hvcl95IjogOS4wLCAiaHRtbCI6ICI8c3ZnIHdpZHRoPVwiMThweFwiIGhlaWdodD1cIjE4cHhcIiB2aWV3Qm94PVwiLTkuMCAtOS4wIDE4LjAgMTguMFwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2ZXJzaW9uPVwiMS4xXCI+ICA8cGF0aCBkPVwiTSAwLjAgNy4wNzEwNjc4MTE4NyBDIDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAzLjY3Mzk4NDUgNi4zMjYwMTU1IDUuMCA1LjAgQyA2LjMyNjAxNTUgMy42NzM5ODQ1IDcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IC0wLjAgQyA3LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIDYuMzI2MDE1NSAtMy42NzM5ODQ1IDUuMCAtNS4wIEMgMy42NzM5ODQ1IC02LjMyNjAxNTUgMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAwLjAgLTcuMDcxMDY3ODExODcgQyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMy42NzM5ODQ1IC02LjMyNjAxNTUgLTUuMCAtNS4wIEMgLTYuMzI2MDE1NSAtMy42NzM5ODQ1IC03LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0wLjAgQyAtNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIC02LjMyNjAxNTUgMy42NzM5ODQ1IC01LjAgNS4wIEMgLTMuNjczOTg0NSA2LjMyNjAxNTUgLTEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAwLjAgNy4wNzEwNjc4MTE4NyBaXCIgZmlsbD1cIiNGRjAwMDBcIiBzdHJva2Utd2lkdGg9XCIxLjBcIiBzdHJva2Utb3BhY2l0eT1cIjAuN1wiIGZpbGwtb3BhY2l0eT1cIjAuN1wiIHN0cm9rZT1cIiNGRjAwMDBcIiAvPjwvc3ZnPiIsICJhbmNob3JfeCI6IDkuMH0sICJnZW9tZXRyeSI6IHsiY29vcmRpbmF0ZXMiOiBbLTg0LjAxMzMsIDQyLjMyNjRdLCAidHlwZSI6ICJQb2ludCJ9fSwgeyJ0eXBlIjogIkZlYXR1cmUiLCAicHJvcGVydGllcyI6IHsiYW5jaG9yX3kiOiA5LjAsICJodG1sIjogIjxzdmcgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiIHZpZXdCb3g9XCItOS4wIC05LjAgMTguMCAxOC4wXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHZlcnNpb249XCIxLjFcIj4gIDxwYXRoIGQ9XCJNIDAuMCA3LjA3MTA2NzgxMTg3IEMgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDMuNjczOTg0NSA2LjMyNjAxNTUgNS4wIDUuMCBDIDYuMzI2MDE1NSAzLjY3Mzk4NDUgNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgLTAuMCBDIDcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgNi4zMjYwMTU1IC0zLjY3Mzk4NDUgNS4wIC01LjAgQyAzLjY3Mzk4NDUgLTYuMzI2MDE1NSAxLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IDAuMCAtNy4wNzEwNjc4MTE4NyBDIC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0zLjY3Mzk4NDUgLTYuMzI2MDE1NSAtNS4wIC01LjAgQyAtNi4zMjYwMTU1IC0zLjY3Mzk4NDUgLTcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTAuMCBDIC03LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgLTYuMzI2MDE1NSAzLjY3Mzk4NDUgLTUuMCA1LjAgQyAtMy42NzM5ODQ1IDYuMzI2MDE1NSAtMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDAuMCA3LjA3MTA2NzgxMTg3IFpcIiBmaWxsPVwiI0ZGMDAwMFwiIHN0cm9rZS13aWR0aD1cIjEuMFwiIHN0cm9rZS1vcGFjaXR5PVwiMC43XCIgZmlsbC1vcGFjaXR5PVwiMC43XCIgc3Ryb2tlPVwiI0ZGMDAwMFwiIC8+PC9zdmc+IiwgImFuY2hvcl94IjogOS4wfSwgImdlb21ldHJ5IjogeyJjb29yZGluYXRlcyI6IFstODMuNjQ4OSwgNDEuOTU1M10sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My45ODU4LCA0Mi40MzQ0XSwgInR5cGUiOiAiUG9pbnQifX0sIHsidHlwZSI6ICJGZWF0dXJlIiwgInByb3BlcnRpZXMiOiB7ImFuY2hvcl95IjogOS4wLCAiaHRtbCI6ICI8c3ZnIHdpZHRoPVwiMThweFwiIGhlaWdodD1cIjE4cHhcIiB2aWV3Qm94PVwiLTkuMCAtOS4wIDE4LjAgMTguMFwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2ZXJzaW9uPVwiMS4xXCI+ICA8cGF0aCBkPVwiTSAwLjAgNy4wNzEwNjc4MTE4NyBDIDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAzLjY3Mzk4NDUgNi4zMjYwMTU1IDUuMCA1LjAgQyA2LjMyNjAxNTUgMy42NzM5ODQ1IDcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IC0wLjAgQyA3LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIDYuMzI2MDE1NSAtMy42NzM5ODQ1IDUuMCAtNS4wIEMgMy42NzM5ODQ1IC02LjMyNjAxNTUgMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAwLjAgLTcuMDcxMDY3ODExODcgQyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMy42NzM5ODQ1IC02LjMyNjAxNTUgLTUuMCAtNS4wIEMgLTYuMzI2MDE1NSAtMy42NzM5ODQ1IC03LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0wLjAgQyAtNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIC02LjMyNjAxNTUgMy42NzM5ODQ1IC01LjAgNS4wIEMgLTMuNjczOTg0NSA2LjMyNjAxNTUgLTEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAwLjAgNy4wNzEwNjc4MTE4NyBaXCIgZmlsbD1cIiNGRjAwMDBcIiBzdHJva2Utd2lkdGg9XCIxLjBcIiBzdHJva2Utb3BhY2l0eT1cIjAuN1wiIGZpbGwtb3BhY2l0eT1cIjAuN1wiIHN0cm9rZT1cIiNGRjAwMDBcIiAvPjwvc3ZnPiIsICJhbmNob3JfeCI6IDkuMH0sICJnZW9tZXRyeSI6IHsiY29vcmRpbmF0ZXMiOiBbLTg0LjAyMzYsIDQyLjE1MDhdLCAidHlwZSI6ICJQb2ludCJ9fSwgeyJ0eXBlIjogIkZlYXR1cmUiLCAicHJvcGVydGllcyI6IHsiYW5jaG9yX3kiOiA5LjAsICJodG1sIjogIjxzdmcgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiIHZpZXdCb3g9XCItOS4wIC05LjAgMTguMCAxOC4wXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHZlcnNpb249XCIxLjFcIj4gIDxwYXRoIGQ9XCJNIDAuMCA3LjA3MTA2NzgxMTg3IEMgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDMuNjczOTg0NSA2LjMyNjAxNTUgNS4wIDUuMCBDIDYuMzI2MDE1NSAzLjY3Mzk4NDUgNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgLTAuMCBDIDcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgNi4zMjYwMTU1IC0zLjY3Mzk4NDUgNS4wIC01LjAgQyAzLjY3Mzk4NDUgLTYuMzI2MDE1NSAxLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IDAuMCAtNy4wNzEwNjc4MTE4NyBDIC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0zLjY3Mzk4NDUgLTYuMzI2MDE1NSAtNS4wIC01LjAgQyAtNi4zMjYwMTU1IC0zLjY3Mzk4NDUgLTcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTAuMCBDIC03LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgLTYuMzI2MDE1NSAzLjY3Mzk4NDUgLTUuMCA1LjAgQyAtMy42NzM5ODQ1IDYuMzI2MDE1NSAtMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDAuMCA3LjA3MTA2NzgxMTg3IFpcIiBmaWxsPVwiI0ZGMDAwMFwiIHN0cm9rZS13aWR0aD1cIjEuMFwiIHN0cm9rZS1vcGFjaXR5PVwiMC43XCIgZmlsbC1vcGFjaXR5PVwiMC43XCIgc3Ryb2tlPVwiI0ZGMDAwMFwiIC8+PC9zdmc+IiwgImFuY2hvcl94IjogOS4wfSwgImdlb21ldHJ5IjogeyJjb29yZGluYXRlcyI6IFstODMuNjE4NiwgNDIuMDY2NF0sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My42NzY5LCA0Mi4wODExXSwgInR5cGUiOiAiUG9pbnQifX0sIHsidHlwZSI6ICJGZWF0dXJlIiwgInByb3BlcnRpZXMiOiB7ImFuY2hvcl95IjogOS4wLCAiaHRtbCI6ICI8c3ZnIHdpZHRoPVwiMThweFwiIGhlaWdodD1cIjE4cHhcIiB2aWV3Qm94PVwiLTkuMCAtOS4wIDE4LjAgMTguMFwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2ZXJzaW9uPVwiMS4xXCI+ICA8cGF0aCBkPVwiTSAwLjAgNy4wNzEwNjc4MTE4NyBDIDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAzLjY3Mzk4NDUgNi4zMjYwMTU1IDUuMCA1LjAgQyA2LjMyNjAxNTUgMy42NzM5ODQ1IDcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IC0wLjAgQyA3LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIDYuMzI2MDE1NSAtMy42NzM5ODQ1IDUuMCAtNS4wIEMgMy42NzM5ODQ1IC02LjMyNjAxNTUgMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAwLjAgLTcuMDcxMDY3ODExODcgQyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMy42NzM5ODQ1IC02LjMyNjAxNTUgLTUuMCAtNS4wIEMgLTYuMzI2MDE1NSAtMy42NzM5ODQ1IC03LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0wLjAgQyAtNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIC02LjMyNjAxNTUgMy42NzM5ODQ1IC01LjAgNS4wIEMgLTMuNjczOTg0NSA2LjMyNjAxNTUgLTEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAwLjAgNy4wNzEwNjc4MTE4NyBaXCIgZmlsbD1cIiNGRjAwMDBcIiBzdHJva2Utd2lkdGg9XCIxLjBcIiBzdHJva2Utb3BhY2l0eT1cIjAuN1wiIGZpbGwtb3BhY2l0eT1cIjAuN1wiIHN0cm9rZT1cIiNGRjAwMDBcIiAvPjwvc3ZnPiIsICJhbmNob3JfeCI6IDkuMH0sICJnZW9tZXRyeSI6IHsiY29vcmRpbmF0ZXMiOiBbLTgzLjQxNTgsIDQxLjkwNjldLCAidHlwZSI6ICJQb2ludCJ9fSwgeyJ0eXBlIjogIkZlYXR1cmUiLCAicHJvcGVydGllcyI6IHsiYW5jaG9yX3kiOiA5LjAsICJodG1sIjogIjxzdmcgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiIHZpZXdCb3g9XCItOS4wIC05LjAgMTguMCAxOC4wXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHZlcnNpb249XCIxLjFcIj4gIDxwYXRoIGQ9XCJNIDAuMCA3LjA3MTA2NzgxMTg3IEMgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDMuNjczOTg0NSA2LjMyNjAxNTUgNS4wIDUuMCBDIDYuMzI2MDE1NSAzLjY3Mzk4NDUgNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgLTAuMCBDIDcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgNi4zMjYwMTU1IC0zLjY3Mzk4NDUgNS4wIC01LjAgQyAzLjY3Mzk4NDUgLTYuMzI2MDE1NSAxLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IDAuMCAtNy4wNzEwNjc4MTE4NyBDIC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0zLjY3Mzk4NDUgLTYuMzI2MDE1NSAtNS4wIC01LjAgQyAtNi4zMjYwMTU1IC0zLjY3Mzk4NDUgLTcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTAuMCBDIC03LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgLTYuMzI2MDE1NSAzLjY3Mzk4NDUgLTUuMCA1LjAgQyAtMy42NzM5ODQ1IDYuMzI2MDE1NSAtMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDAuMCA3LjA3MTA2NzgxMTg3IFpcIiBmaWxsPVwiI0ZGMDAwMFwiIHN0cm9rZS13aWR0aD1cIjEuMFwiIHN0cm9rZS1vcGFjaXR5PVwiMC43XCIgZmlsbC1vcGFjaXR5PVwiMC43XCIgc3Ryb2tlPVwiI0ZGMDAwMFwiIC8+PC9zdmc+IiwgImFuY2hvcl94IjogOS4wfSwgImdlb21ldHJ5IjogeyJjb29yZGluYXRlcyI6IFstODMuMjgsIDQxLjk0OTddLCAidHlwZSI6ICJQb2ludCJ9fSwgeyJ0eXBlIjogIkZlYXR1cmUiLCAicHJvcGVydGllcyI6IHsiYW5jaG9yX3kiOiA5LjAsICJodG1sIjogIjxzdmcgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiIHZpZXdCb3g9XCItOS4wIC05LjAgMTguMCAxOC4wXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHZlcnNpb249XCIxLjFcIj4gIDxwYXRoIGQ9XCJNIDAuMCA3LjA3MTA2NzgxMTg3IEMgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDMuNjczOTg0NSA2LjMyNjAxNTUgNS4wIDUuMCBDIDYuMzI2MDE1NSAzLjY3Mzk4NDUgNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgLTAuMCBDIDcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgNi4zMjYwMTU1IC0zLjY3Mzk4NDUgNS4wIC01LjAgQyAzLjY3Mzk4NDUgLTYuMzI2MDE1NSAxLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IDAuMCAtNy4wNzEwNjc4MTE4NyBDIC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0zLjY3Mzk4NDUgLTYuMzI2MDE1NSAtNS4wIC01LjAgQyAtNi4zMjYwMTU1IC0zLjY3Mzk4NDUgLTcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTAuMCBDIC03LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgLTYuMzI2MDE1NSAzLjY3Mzk4NDUgLTUuMCA1LjAgQyAtMy42NzM5ODQ1IDYuMzI2MDE1NSAtMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDAuMCA3LjA3MTA2NzgxMTg3IFpcIiBmaWxsPVwiI0ZGMDAwMFwiIHN0cm9rZS13aWR0aD1cIjEuMFwiIHN0cm9rZS1vcGFjaXR5PVwiMC43XCIgZmlsbC1vcGFjaXR5PVwiMC43XCIgc3Ryb2tlPVwiI0ZGMDAwMFwiIC8+PC9zdmc+IiwgImFuY2hvcl94IjogOS4wfSwgImdlb21ldHJ5IjogeyJjb29yZGluYXRlcyI6IFstODMuNzgxOSwgNDIuMTYxMV0sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My44MiwgNDIuMTIzNl0sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My41ODMxLCA0MS44MDY5XSwgInR5cGUiOiAiUG9pbnQifX0sIHsidHlwZSI6ICJGZWF0dXJlIiwgInByb3BlcnRpZXMiOiB7ImFuY2hvcl95IjogOS4wLCAiaHRtbCI6ICI8c3ZnIHdpZHRoPVwiMThweFwiIGhlaWdodD1cIjE4cHhcIiB2aWV3Qm94PVwiLTkuMCAtOS4wIDE4LjAgMTguMFwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2ZXJzaW9uPVwiMS4xXCI+ICA8cGF0aCBkPVwiTSAwLjAgNy4wNzEwNjc4MTE4NyBDIDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAzLjY3Mzk4NDUgNi4zMjYwMTU1IDUuMCA1LjAgQyA2LjMyNjAxNTUgMy42NzM5ODQ1IDcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IC0wLjAgQyA3LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIDYuMzI2MDE1NSAtMy42NzM5ODQ1IDUuMCAtNS4wIEMgMy42NzM5ODQ1IC02LjMyNjAxNTUgMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAwLjAgLTcuMDcxMDY3ODExODcgQyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMy42NzM5ODQ1IC02LjMyNjAxNTUgLTUuMCAtNS4wIEMgLTYuMzI2MDE1NSAtMy42NzM5ODQ1IC03LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0wLjAgQyAtNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIC02LjMyNjAxNTUgMy42NzM5ODQ1IC01LjAgNS4wIEMgLTMuNjczOTg0NSA2LjMyNjAxNTUgLTEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAwLjAgNy4wNzEwNjc4MTE4NyBaXCIgZmlsbD1cIiNGRjAwMDBcIiBzdHJva2Utd2lkdGg9XCIxLjBcIiBzdHJva2Utb3BhY2l0eT1cIjAuN1wiIGZpbGwtb3BhY2l0eT1cIjAuN1wiIHN0cm9rZT1cIiNGRjAwMDBcIiAvPjwvc3ZnPiIsICJhbmNob3JfeCI6IDkuMH0sICJnZW9tZXRyeSI6IHsiY29vcmRpbmF0ZXMiOiBbLTgzLjkzMzYsIDQyLjAwMjhdLCAidHlwZSI6ICJQb2ludCJ9fSwgeyJ0eXBlIjogIkZlYXR1cmUiLCAicHJvcGVydGllcyI6IHsiYW5jaG9yX3kiOiA5LjAsICJodG1sIjogIjxzdmcgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiIHZpZXdCb3g9XCItOS4wIC05LjAgMTguMCAxOC4wXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHZlcnNpb249XCIxLjFcIj4gIDxwYXRoIGQ9XCJNIDAuMCA3LjA3MTA2NzgxMTg3IEMgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDMuNjczOTg0NSA2LjMyNjAxNTUgNS4wIDUuMCBDIDYuMzI2MDE1NSAzLjY3Mzk4NDUgNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgLTAuMCBDIDcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgNi4zMjYwMTU1IC0zLjY3Mzk4NDUgNS4wIC01LjAgQyAzLjY3Mzk4NDUgLTYuMzI2MDE1NSAxLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IDAuMCAtNy4wNzEwNjc4MTE4NyBDIC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0zLjY3Mzk4NDUgLTYuMzI2MDE1NSAtNS4wIC01LjAgQyAtNi4zMjYwMTU1IC0zLjY3Mzk4NDUgLTcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTAuMCBDIC03LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgLTYuMzI2MDE1NSAzLjY3Mzk4NDUgLTUuMCA1LjAgQyAtMy42NzM5ODQ1IDYuMzI2MDE1NSAtMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDAuMCA3LjA3MTA2NzgxMTg3IFpcIiBmaWxsPVwiI0ZGMDAwMFwiIHN0cm9rZS13aWR0aD1cIjEuMFwiIHN0cm9rZS1vcGFjaXR5PVwiMC43XCIgZmlsbC1vcGFjaXR5PVwiMC43XCIgc3Ryb2tlPVwiI0ZGMDAwMFwiIC8+PC9zdmc+IiwgImFuY2hvcl94IjogOS4wfSwgImdlb21ldHJ5IjogeyJjb29yZGluYXRlcyI6IFstODQuMTEwOCwgNDIuMDI4M10sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My43ODMxLCA0Mi40MzU2XSwgInR5cGUiOiAiUG9pbnQifX0sIHsidHlwZSI6ICJGZWF0dXJlIiwgInByb3BlcnRpZXMiOiB7ImFuY2hvcl95IjogOS4wLCAiaHRtbCI6ICI8c3ZnIHdpZHRoPVwiMThweFwiIGhlaWdodD1cIjE4cHhcIiB2aWV3Qm94PVwiLTkuMCAtOS4wIDE4LjAgMTguMFwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2ZXJzaW9uPVwiMS4xXCI+ICA8cGF0aCBkPVwiTSAwLjAgNy4wNzEwNjc4MTE4NyBDIDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAzLjY3Mzk4NDUgNi4zMjYwMTU1IDUuMCA1LjAgQyA2LjMyNjAxNTUgMy42NzM5ODQ1IDcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IC0wLjAgQyA3LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIDYuMzI2MDE1NSAtMy42NzM5ODQ1IDUuMCAtNS4wIEMgMy42NzM5ODQ1IC02LjMyNjAxNTUgMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAwLjAgLTcuMDcxMDY3ODExODcgQyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMy42NzM5ODQ1IC02LjMyNjAxNTUgLTUuMCAtNS4wIEMgLTYuMzI2MDE1NSAtMy42NzM5ODQ1IC03LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0wLjAgQyAtNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIC02LjMyNjAxNTUgMy42NzM5ODQ1IC01LjAgNS4wIEMgLTMuNjczOTg0NSA2LjMyNjAxNTUgLTEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAwLjAgNy4wNzEwNjc4MTE4NyBaXCIgZmlsbD1cIiNGRjAwMDBcIiBzdHJva2Utd2lkdGg9XCIxLjBcIiBzdHJva2Utb3BhY2l0eT1cIjAuN1wiIGZpbGwtb3BhY2l0eT1cIjAuN1wiIHN0cm9rZT1cIiNGRjAwMDBcIiAvPjwvc3ZnPiIsICJhbmNob3JfeCI6IDkuMH0sICJnZW9tZXRyeSI6IHsiY29vcmRpbmF0ZXMiOiBbLTgzLjQ3NjQsIDQxLjU2MzFdLCAidHlwZSI6ICJQb2ludCJ9fSwgeyJ0eXBlIjogIkZlYXR1cmUiLCAicHJvcGVydGllcyI6IHsiYW5jaG9yX3kiOiA5LjAsICJodG1sIjogIjxzdmcgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiIHZpZXdCb3g9XCItOS4wIC05LjAgMTguMCAxOC4wXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHZlcnNpb249XCIxLjFcIj4gIDxwYXRoIGQ9XCJNIDAuMCA3LjA3MTA2NzgxMTg3IEMgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDMuNjczOTg0NSA2LjMyNjAxNTUgNS4wIDUuMCBDIDYuMzI2MDE1NSAzLjY3Mzk4NDUgNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgLTAuMCBDIDcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgNi4zMjYwMTU1IC0zLjY3Mzk4NDUgNS4wIC01LjAgQyAzLjY3Mzk4NDUgLTYuMzI2MDE1NSAxLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IDAuMCAtNy4wNzEwNjc4MTE4NyBDIC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0zLjY3Mzk4NDUgLTYuMzI2MDE1NSAtNS4wIC01LjAgQyAtNi4zMjYwMTU1IC0zLjY3Mzk4NDUgLTcuMDcxMDY3ODExODcgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTAuMCBDIC03LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgLTYuMzI2MDE1NSAzLjY3Mzk4NDUgLTUuMCA1LjAgQyAtMy42NzM5ODQ1IDYuMzI2MDE1NSAtMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IDAuMCA3LjA3MTA2NzgxMTg3IFpcIiBmaWxsPVwiI0ZGMDAwMFwiIHN0cm9rZS13aWR0aD1cIjEuMFwiIHN0cm9rZS1vcGFjaXR5PVwiMC43XCIgZmlsbC1vcGFjaXR5PVwiMC43XCIgc3Ryb2tlPVwiI0ZGMDAwMFwiIC8+PC9zdmc+IiwgImFuY2hvcl94IjogOS4wfSwgImdlb21ldHJ5IjogeyJjb29yZGluYXRlcyI6IFstODQuNDY2NywgNDIuMjY2N10sICJ0eXBlIjogIlBvaW50In19LCB7InR5cGUiOiAiRmVhdHVyZSIsICJwcm9wZXJ0aWVzIjogeyJhbmNob3JfeSI6IDkuMCwgImh0bWwiOiAiPHN2ZyB3aWR0aD1cIjE4cHhcIiBoZWlnaHQ9XCIxOHB4XCIgdmlld0JveD1cIi05LjAgLTkuMCAxOC4wIDE4LjBcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgdmVyc2lvbj1cIjEuMVwiPiAgPHBhdGggZD1cIk0gMC4wIDcuMDcxMDY3ODExODcgQyAxLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMy42NzM5ODQ1IDYuMzI2MDE1NSA1LjAgNS4wIEMgNi4zMjYwMTU1IDMuNjczOTg0NSA3LjA3MTA2NzgxMTg3IDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAtMC4wIEMgNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiA2LjMyNjAxNTUgLTMuNjczOTg0NSA1LjAgLTUuMCBDIDMuNjczOTg0NSAtNi4zMjYwMTU1IDEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgMC4wIC03LjA3MTA2NzgxMTg3IEMgLTEuODc1MjY5MTA0MDIgLTcuMDcxMDY3ODExODcgLTMuNjczOTg0NSAtNi4zMjYwMTU1IC01LjAgLTUuMCBDIC02LjMyNjAxNTUgLTMuNjczOTg0NSAtNy4wNzEwNjc4MTE4NyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMC4wIEMgLTcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiAtNi4zMjYwMTU1IDMuNjczOTg0NSAtNS4wIDUuMCBDIC0zLjY3Mzk4NDUgNi4zMjYwMTU1IC0xLjg3NTI2OTEwNDAyIDcuMDcxMDY3ODExODcgMC4wIDcuMDcxMDY3ODExODcgWlwiIGZpbGw9XCIjRkYwMDAwXCIgc3Ryb2tlLXdpZHRoPVwiMS4wXCIgc3Ryb2tlLW9wYWNpdHk9XCIwLjdcIiBmaWxsLW9wYWNpdHk9XCIwLjdcIiBzdHJva2U9XCIjRkYwMDAwXCIgLz48L3N2Zz4iLCAiYW5jaG9yX3giOiA5LjB9LCAiZ2VvbWV0cnkiOiB7ImNvb3JkaW5hdGVzIjogWy04My41MzMzLCA0Mi4yMzMzXSwgInR5cGUiOiAiUG9pbnQifX0sIHsidHlwZSI6ICJGZWF0dXJlIiwgInByb3BlcnRpZXMiOiB7ImFuY2hvcl95IjogOS4wLCAiaHRtbCI6ICI8c3ZnIHdpZHRoPVwiMThweFwiIGhlaWdodD1cIjE4cHhcIiB2aWV3Qm94PVwiLTkuMCAtOS4wIDE4LjAgMTguMFwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2ZXJzaW9uPVwiMS4xXCI+ICA8cGF0aCBkPVwiTSAwLjAgNy4wNzEwNjc4MTE4NyBDIDEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAzLjY3Mzk4NDUgNi4zMjYwMTU1IDUuMCA1LjAgQyA2LjMyNjAxNTUgMy42NzM5ODQ1IDcuMDcxMDY3ODExODcgMS44NzUyNjkxMDQwMiA3LjA3MTA2NzgxMTg3IC0wLjAgQyA3LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIDYuMzI2MDE1NSAtMy42NzM5ODQ1IDUuMCAtNS4wIEMgMy42NzM5ODQ1IC02LjMyNjAxNTUgMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAwLjAgLTcuMDcxMDY3ODExODcgQyAtMS44NzUyNjkxMDQwMiAtNy4wNzEwNjc4MTE4NyAtMy42NzM5ODQ1IC02LjMyNjAxNTUgLTUuMCAtNS4wIEMgLTYuMzI2MDE1NSAtMy42NzM5ODQ1IC03LjA3MTA2NzgxMTg3IC0xLjg3NTI2OTEwNDAyIC03LjA3MTA2NzgxMTg3IC0wLjAgQyAtNy4wNzEwNjc4MTE4NyAxLjg3NTI2OTEwNDAyIC02LjMyNjAxNTUgMy42NzM5ODQ1IC01LjAgNS4wIEMgLTMuNjczOTg0NSA2LjMyNjAxNTUgLTEuODc1MjY5MTA0MDIgNy4wNzEwNjc4MTE4NyAwLjAgNy4wNzEwNjc4MTE4NyBaXCIgZmlsbD1cIiNGRjAwMDBcIiBzdHJva2Utd2lkdGg9XCIxLjBcIiBzdHJva2Utb3BhY2l0eT1cIjAuN1wiIGZpbGwtb3BhY2l0eT1cIjAuN1wiIHN0cm9rZT1cIiNGRjAwMDBcIiAvPjwvc3ZnPiIsICJhbmNob3JfeCI6IDkuMH0sICJnZW9tZXRyeSI6IHsiY29vcmRpbmF0ZXMiOiBbLTgzLjc0NDQsIDQyLjIyMjhdLCAidHlwZSI6ICJQb2ludCJ9fV19OwoKaWYgKGdqRGF0YS5mZWF0dXJlcy5sZW5ndGggIT0gMCkgewogIHZhciBnaiA9IEwuZ2VvSnNvbihnakRhdGEsIHsKICAgIHN0eWxlOiBmdW5jdGlvbiAoZmVhdHVyZSkgewogICAgICByZXR1cm4gZmVhdHVyZS5wcm9wZXJ0aWVzOwogICAgfSwKICAgIHBvaW50VG9MYXllcjogZnVuY3Rpb24gKGZlYXR1cmUsIGxhdGxuZykgewogICAgICB2YXIgaWNvbiA9IEwuZGl2SWNvbih7J2h0bWwnOiBmZWF0dXJlLnByb3BlcnRpZXMuaHRtbCwgCiAgICAgICAgaWNvbkFuY2hvcjogW2ZlYXR1cmUucHJvcGVydGllcy5hbmNob3JfeCwgCiAgICAgICAgICAgICAgICAgICAgIGZlYXR1cmUucHJvcGVydGllcy5hbmNob3JfeV0sIAogICAgICAgICAgY2xhc3NOYW1lOiAnZW1wdHknfSk7ICAvLyBXaGF0IGNhbiBJIGRvIGFib3V0IGVtcHR5PwogICAgICByZXR1cm4gTC5tYXJrZXIobGF0bG5nLCB7aWNvbjogaWNvbn0pOwogICAgfQogIH0pOwogIGdqLmFkZFRvKG1hcCk7CiAgCiAgbWFwLmZpdEJvdW5kcyhnai5nZXRCb3VuZHMoKSk7Cn0gZWxzZSB7CiAgbWFwLnNldFZpZXcoWzAsIDBdLCAxKTsKfQo8L3NjcmlwdD4KPC9ib2R5Pg==\" width=\"100%\" height=\"480\"></iframe>"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"execution_count": 1,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"import matplotlib.pyplot as plt\n",
"import mplleaflet\n",
"import pandas as pd\n",
"\n",
"def leaflet_plot_stations(binsize, hashid):\n",
"\n",
" df = pd.read_csv('data/C2A2_data/BinSize_d{}.csv'.format(binsize))\n",
"\n",
" station_locations_by_hash = df[df['hash'] == hashid]\n",
"\n",
" lons = station_locations_by_hash['LONGITUDE'].tolist()\n",
" lats = station_locations_by_hash['LATITUDE'].tolist()\n",
"\n",
" plt.figure(figsize=(8,8))\n",
"\n",
" plt.scatter(lons, lats, c='r', alpha=0.7, s=200)\n",
"\n",
" return mplleaflet.display()\n",
"\n",
"leaflet_plot_stations(400,'fb441e62df2d58994928907a91895ec62c2c42e6cd075c2700843b89')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Read Data"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"collapsed": false,
"scrolled": true
},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>ID</th>\n",
" <th>Date</th>\n",
" <th>Element</th>\n",
" <th>Data_Value</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>USW00094889</td>\n",
" <td>2014-11-12</td>\n",
" <td>TMAX</td>\n",
" <td>22</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>USC00208972</td>\n",
" <td>2009-04-29</td>\n",
" <td>TMIN</td>\n",
" <td>56</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>USC00200032</td>\n",
" <td>2008-05-26</td>\n",
" <td>TMAX</td>\n",
" <td>278</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>USC00205563</td>\n",
" <td>2005-11-11</td>\n",
" <td>TMAX</td>\n",
" <td>139</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>USC00200230</td>\n",
" <td>2014-02-27</td>\n",
" <td>TMAX</td>\n",
" <td>-106</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5</th>\n",
" <td>USW00014833</td>\n",
" <td>2010-10-01</td>\n",
" <td>TMAX</td>\n",
" <td>194</td>\n",
" </tr>\n",
" <tr>\n",
" <th>6</th>\n",
" <td>USC00207308</td>\n",
" <td>2010-06-29</td>\n",
" <td>TMIN</td>\n",
" <td>144</td>\n",
" </tr>\n",
" <tr>\n",
" <th>7</th>\n",
" <td>USC00203712</td>\n",
" <td>2005-10-04</td>\n",
" <td>TMAX</td>\n",
" <td>289</td>\n",
" </tr>\n",
" <tr>\n",
" <th>8</th>\n",
" <td>USW00004848</td>\n",
" <td>2007-12-14</td>\n",
" <td>TMIN</td>\n",
" <td>-16</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9</th>\n",
" <td>USC00200220</td>\n",
" <td>2011-04-21</td>\n",
" <td>TMAX</td>\n",
" <td>72</td>\n",
" </tr>\n",
" <tr>\n",
" <th>10</th>\n",
" <td>USC00205822</td>\n",
" <td>2013-01-16</td>\n",
" <td>TMAX</td>\n",
" <td>11</td>\n",
" </tr>\n",
" <tr>\n",
" <th>11</th>\n",
" <td>USC00205822</td>\n",
" <td>2008-05-29</td>\n",
" <td>TMIN</td>\n",
" <td>28</td>\n",
" </tr>\n",
" <tr>\n",
" <th>12</th>\n",
" <td>USC00203712</td>\n",
" <td>2008-10-17</td>\n",
" <td>TMIN</td>\n",
" <td>17</td>\n",
" </tr>\n",
" <tr>\n",
" <th>13</th>\n",
" <td>USC00205563</td>\n",
" <td>2006-05-14</td>\n",
" <td>TMAX</td>\n",
" <td>183</td>\n",
" </tr>\n",
" <tr>\n",
" <th>14</th>\n",
" <td>USC00200842</td>\n",
" <td>2006-05-14</td>\n",
" <td>TMAX</td>\n",
" <td>122</td>\n",
" </tr>\n",
" <tr>\n",
" <th>15</th>\n",
" <td>USC00205563</td>\n",
" <td>2014-12-07</td>\n",
" <td>TMAX</td>\n",
" <td>67</td>\n",
" </tr>\n",
" <tr>\n",
" <th>16</th>\n",
" <td>USC00205822</td>\n",
" <td>2008-09-07</td>\n",
" <td>TMAX</td>\n",
" <td>250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>17</th>\n",
" <td>USC00205450</td>\n",
" <td>2006-04-22</td>\n",
" <td>TMIN</td>\n",
" <td>67</td>\n",
" </tr>\n",
" <tr>\n",
" <th>18</th>\n",
" <td>USC00203712</td>\n",
" <td>2008-02-22</td>\n",
" <td>TMAX</td>\n",
" <td>-44</td>\n",
" </tr>\n",
" <tr>\n",
" <th>19</th>\n",
" <td>USC00205563</td>\n",
" <td>2015-01-03</td>\n",
" <td>TMIN</td>\n",
" <td>-39</td>\n",
" </tr>\n",
" <tr>\n",
" <th>20</th>\n",
" <td>USC00201250</td>\n",
" <td>2011-03-28</td>\n",
" <td>TMIN</td>\n",
" <td>-78</td>\n",
" </tr>\n",
" <tr>\n",
" <th>21</th>\n",
" <td>USC00200230</td>\n",
" <td>2008-02-10</td>\n",
" <td>TMAX</td>\n",
" <td>-6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>22</th>\n",
" <td>USC00207320</td>\n",
" <td>2008-02-03</td>\n",
" <td>TMIN</td>\n",
" <td>-39</td>\n",
" </tr>\n",
" <tr>\n",
" <th>23</th>\n",
" <td>USC00200228</td>\n",
" <td>2008-02-23</td>\n",
" <td>TMAX</td>\n",
" <td>11</td>\n",
" </tr>\n",
" <tr>\n",
" <th>24</th>\n",
" <td>USC00201250</td>\n",
" <td>2012-03-20</td>\n",
" <td>TMIN</td>\n",
" <td>100</td>\n",
" </tr>\n",
" <tr>\n",
" <th>25</th>\n",
" <td>USC00205822</td>\n",
" <td>2006-03-29</td>\n",
" <td>TMIN</td>\n",
" <td>-17</td>\n",
" </tr>\n",
" <tr>\n",
" <th>26</th>\n",
" <td>USC00202308</td>\n",
" <td>2006-05-11</td>\n",
" <td>TMAX</td>\n",
" <td>233</td>\n",
" </tr>\n",
" <tr>\n",
" <th>27</th>\n",
" <td>USW00014833</td>\n",
" <td>2012-03-31</td>\n",
" <td>TMAX</td>\n",
" <td>61</td>\n",
" </tr>\n",
" <tr>\n",
" <th>28</th>\n",
" <td>USW00014853</td>\n",
" <td>2010-07-25</td>\n",
" <td>TMAX</td>\n",
" <td>283</td>\n",
" </tr>\n",
" <tr>\n",
" <th>29</th>\n",
" <td>USC00205822</td>\n",
" <td>2014-12-09</td>\n",
" <td>TMIN</td>\n",
" <td>17</td>\n",
" </tr>\n",
" <tr>\n",
" <th>...</th>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165055</th>\n",
" <td>USC00202308</td>\n",
" <td>2009-10-09</td>\n",
" <td>TMAX</td>\n",
" <td>111</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165056</th>\n",
" <td>USC00200228</td>\n",
" <td>2015-02-23</td>\n",
" <td>TMAX</td>\n",
" <td>-11</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165057</th>\n",
" <td>USC00208080</td>\n",
" <td>2009-11-24</td>\n",
" <td>TMAX</td>\n",
" <td>100</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165058</th>\n",
" <td>USC00208972</td>\n",
" <td>2010-03-22</td>\n",
" <td>TMAX</td>\n",
" <td>94</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165059</th>\n",
" <td>USC00207312</td>\n",
" <td>2015-06-23</td>\n",
" <td>TMIN</td>\n",
" <td>172</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165060</th>\n",
" <td>USC00200230</td>\n",
" <td>2010-05-23</td>\n",
" <td>TMAX</td>\n",
" <td>283</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165061</th>\n",
" <td>USW00004848</td>\n",
" <td>2012-12-26</td>\n",
" <td>TMIN</td>\n",
" <td>-32</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165062</th>\n",
" <td>USC00205822</td>\n",
" <td>2014-02-06</td>\n",
" <td>TMAX</td>\n",
" <td>-11</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165063</th>\n",
" <td>USC00200230</td>\n",
" <td>2010-05-23</td>\n",
" <td>TMIN</td>\n",
" <td>133</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165064</th>\n",
" <td>USC00207312</td>\n",
" <td>2008-08-04</td>\n",
" <td>TMIN</td>\n",
" <td>172</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165065</th>\n",
" <td>USC00200032</td>\n",
" <td>2006-03-01</td>\n",
" <td>TMAX</td>\n",
" <td>17</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165066</th>\n",
" <td>USC00207312</td>\n",
" <td>2008-08-04</td>\n",
" <td>TMAX</td>\n",
" <td>306</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165067</th>\n",
" <td>USC00207312</td>\n",
" <td>2005-12-31</td>\n",
" <td>TMAX</td>\n",
" <td>17</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165068</th>\n",
" <td>USW00094889</td>\n",
" <td>2005-12-20</td>\n",
" <td>TMAX</td>\n",
" <td>-39</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165069</th>\n",
" <td>USW00004848</td>\n",
" <td>2011-03-18</td>\n",
" <td>TMIN</td>\n",
" <td>44</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165070</th>\n",
" <td>USC00208202</td>\n",
" <td>2011-11-26</td>\n",
" <td>TMIN</td>\n",
" <td>28</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165071</th>\n",
" <td>USC00201250</td>\n",
" <td>2010-06-19</td>\n",
" <td>TMAX</td>\n",
" <td>294</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165072</th>\n",
" <td>USC00208080</td>\n",
" <td>2015-11-14</td>\n",
" <td>TMIN</td>\n",
" <td>-17</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165073</th>\n",
" <td>USC00205563</td>\n",
" <td>2005-05-13</td>\n",
" <td>TMAX</td>\n",
" <td>222</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165074</th>\n",
" <td>USW00094889</td>\n",
" <td>2009-07-09</td>\n",
" <td>TMAX</td>\n",
" <td>261</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165075</th>\n",
" <td>USC00205451</td>\n",
" <td>2014-10-03</td>\n",
" <td>TMIN</td>\n",
" <td>100</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165076</th>\n",
" <td>USC00205050</td>\n",
" <td>2013-09-29</td>\n",
" <td>TMAX</td>\n",
" <td>261</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165077</th>\n",
" <td>USC00205050</td>\n",
" <td>2014-07-14</td>\n",
" <td>TMIN</td>\n",
" <td>172</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165078</th>\n",
" <td>USC00200032</td>\n",
" <td>2011-06-27</td>\n",
" <td>TMIN</td>\n",
" <td>144</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165079</th>\n",
" <td>USC00202308</td>\n",
" <td>2005-03-02</td>\n",
" <td>TMIN</td>\n",
" <td>-67</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165080</th>\n",
" <td>USC00205822</td>\n",
" <td>2015-06-09</td>\n",
" <td>TMAX</td>\n",
" <td>256</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165081</th>\n",
" <td>USC00205822</td>\n",
" <td>2009-10-06</td>\n",
" <td>TMAX</td>\n",
" <td>167</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165082</th>\n",
" <td>USC00205050</td>\n",
" <td>2014-07-14</td>\n",
" <td>TMAX</td>\n",
" <td>283</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165083</th>\n",
" <td>USC00200230</td>\n",
" <td>2006-11-29</td>\n",
" <td>TMIN</td>\n",
" <td>117</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165084</th>\n",
" <td>USC00207312</td>\n",
" <td>2006-09-04</td>\n",
" <td>TMIN</td>\n",
" <td>111</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"<p>165085 rows × 4 columns</p>\n",
"</div>"
],
"text/plain": [
" ID Date Element Data_Value\n",
"0 USW00094889 2014-11-12 TMAX 22\n",
"1 USC00208972 2009-04-29 TMIN 56\n",
"2 USC00200032 2008-05-26 TMAX 278\n",
"3 USC00205563 2005-11-11 TMAX 139\n",
"4 USC00200230 2014-02-27 TMAX -106\n",
"5 USW00014833 2010-10-01 TMAX 194\n",
"6 USC00207308 2010-06-29 TMIN 144\n",
"7 USC00203712 2005-10-04 TMAX 289\n",
"8 USW00004848 2007-12-14 TMIN -16\n",
"9 USC00200220 2011-04-21 TMAX 72\n",
"10 USC00205822 2013-01-16 TMAX 11\n",
"11 USC00205822 2008-05-29 TMIN 28\n",
"12 USC00203712 2008-10-17 TMIN 17\n",
"13 USC00205563 2006-05-14 TMAX 183\n",
"14 USC00200842 2006-05-14 TMAX 122\n",
"15 USC00205563 2014-12-07 TMAX 67\n",
"16 USC00205822 2008-09-07 TMAX 250\n",
"17 USC00205450 2006-04-22 TMIN 67\n",
"18 USC00203712 2008-02-22 TMAX -44\n",
"19 USC00205563 2015-01-03 TMIN -39\n",
"20 USC00201250 2011-03-28 TMIN -78\n",
"21 USC00200230 2008-02-10 TMAX -6\n",
"22 USC00207320 2008-02-03 TMIN -39\n",
"23 USC00200228 2008-02-23 TMAX 11\n",
"24 USC00201250 2012-03-20 TMIN 100\n",
"25 USC00205822 2006-03-29 TMIN -17\n",
"26 USC00202308 2006-05-11 TMAX 233\n",
"27 USW00014833 2012-03-31 TMAX 61\n",
"28 USW00014853 2010-07-25 TMAX 283\n",
"29 USC00205822 2014-12-09 TMIN 17\n",
"... ... ... ... ...\n",
"165055 USC00202308 2009-10-09 TMAX 111\n",
"165056 USC00200228 2015-02-23 TMAX -11\n",
"165057 USC00208080 2009-11-24 TMAX 100\n",
"165058 USC00208972 2010-03-22 TMAX 94\n",
"165059 USC00207312 2015-06-23 TMIN 172\n",
"165060 USC00200230 2010-05-23 TMAX 283\n",
"165061 USW00004848 2012-12-26 TMIN -32\n",
"165062 USC00205822 2014-02-06 TMAX -11\n",
"165063 USC00200230 2010-05-23 TMIN 133\n",
"165064 USC00207312 2008-08-04 TMIN 172\n",
"165065 USC00200032 2006-03-01 TMAX 17\n",
"165066 USC00207312 2008-08-04 TMAX 306\n",
"165067 USC00207312 2005-12-31 TMAX 17\n",
"165068 USW00094889 2005-12-20 TMAX -39\n",
"165069 USW00004848 2011-03-18 TMIN 44\n",
"165070 USC00208202 2011-11-26 TMIN 28\n",
"165071 USC00201250 2010-06-19 TMAX 294\n",
"165072 USC00208080 2015-11-14 TMIN -17\n",
"165073 USC00205563 2005-05-13 TMAX 222\n",
"165074 USW00094889 2009-07-09 TMAX 261\n",
"165075 USC00205451 2014-10-03 TMIN 100\n",
"165076 USC00205050 2013-09-29 TMAX 261\n",
"165077 USC00205050 2014-07-14 TMIN 172\n",
"165078 USC00200032 2011-06-27 TMIN 144\n",
"165079 USC00202308 2005-03-02 TMIN -67\n",
"165080 USC00205822 2015-06-09 TMAX 256\n",
"165081 USC00205822 2009-10-06 TMAX 167\n",
"165082 USC00205050 2014-07-14 TMAX 283\n",
"165083 USC00200230 2006-11-29 TMIN 117\n",
"165084 USC00207312 2006-09-04 TMIN 111\n",
"\n",
"[165085 rows x 4 columns]"
]
},
"execution_count": 2,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df = pd.read_csv(r'data/C2A2_data/BinnedCsvs_d400/fb441e62df2d58994928907a91895ec62c2c42e6cd075c2700843b89.csv')\n",
"df"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Quick Look at the Data by Field"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"<class 'pandas.core.frame.DataFrame'>\n",
"RangeIndex: 165085 entries, 0 to 165084\n",
"Data columns (total 4 columns):\n",
"ID 165085 non-null object\n",
"Date 165085 non-null object\n",
"Element 165085 non-null object\n",
"Data_Value 165085 non-null int64\n",
"dtypes: int64(1), object(3)\n",
"memory usage: 5.0+ MB\n"
]
}
],
"source": [
"df.info()"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"24"
]
},
"execution_count": 4,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df['ID'].nunique()"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"4017"
]
},
"execution_count": 5,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df['Date'].nunique()"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"TMAX 83063\n",
"TMIN 82022\n",
"Name: Element, dtype: int64"
]
},
"execution_count": 6,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df['Element'].value_counts()"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"406\n",
"-343\n"
]
}
],
"source": [
"print(df['Data_Value'].max())\n",
"print(df['Data_Value'].min())"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Data Cleaning\n",
"### Delete Feb 29"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"df = df[df['Date'].str[-5:]!='02-29']"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Transfer temprature to 1 degree"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/opt/conda/lib/python3.5/site-packages/ipykernel/__main__.py:1: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" if __name__ == '__main__':\n"
]
}
],
"source": [
"df['Data_Value'] = df['Data_Value']*0.1"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {
"collapsed": false,
"scrolled": true
},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>ID</th>\n",
" <th>Date</th>\n",
" <th>Element</th>\n",
" <th>Data_Value</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>USW00094889</td>\n",
" <td>2014-11-12</td>\n",
" <td>TMAX</td>\n",
" <td>2.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>USC00208972</td>\n",
" <td>2009-04-29</td>\n",
" <td>TMIN</td>\n",
" <td>5.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>USC00200032</td>\n",
" <td>2008-05-26</td>\n",
" <td>TMAX</td>\n",
" <td>27.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>USC00205563</td>\n",
" <td>2005-11-11</td>\n",
" <td>TMAX</td>\n",
" <td>13.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>USC00200230</td>\n",
" <td>2014-02-27</td>\n",
" <td>TMAX</td>\n",
" <td>-10.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5</th>\n",
" <td>USW00014833</td>\n",
" <td>2010-10-01</td>\n",
" <td>TMAX</td>\n",
" <td>19.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>6</th>\n",
" <td>USC00207308</td>\n",
" <td>2010-06-29</td>\n",
" <td>TMIN</td>\n",
" <td>14.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>7</th>\n",
" <td>USC00203712</td>\n",
" <td>2005-10-04</td>\n",
" <td>TMAX</td>\n",
" <td>28.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>8</th>\n",
" <td>USW00004848</td>\n",
" <td>2007-12-14</td>\n",
" <td>TMIN</td>\n",
" <td>-1.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9</th>\n",
" <td>USC00200220</td>\n",
" <td>2011-04-21</td>\n",
" <td>TMAX</td>\n",
" <td>7.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>10</th>\n",
" <td>USC00205822</td>\n",
" <td>2013-01-16</td>\n",
" <td>TMAX</td>\n",
" <td>1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>11</th>\n",
" <td>USC00205822</td>\n",
" <td>2008-05-29</td>\n",
" <td>TMIN</td>\n",
" <td>2.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>12</th>\n",
" <td>USC00203712</td>\n",
" <td>2008-10-17</td>\n",
" <td>TMIN</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>13</th>\n",
" <td>USC00205563</td>\n",
" <td>2006-05-14</td>\n",
" <td>TMAX</td>\n",
" <td>18.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>14</th>\n",
" <td>USC00200842</td>\n",
" <td>2006-05-14</td>\n",
" <td>TMAX</td>\n",
" <td>12.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>15</th>\n",
" <td>USC00205563</td>\n",
" <td>2014-12-07</td>\n",
" <td>TMAX</td>\n",
" <td>6.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>16</th>\n",
" <td>USC00205822</td>\n",
" <td>2008-09-07</td>\n",
" <td>TMAX</td>\n",
" <td>25.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>17</th>\n",
" <td>USC00205450</td>\n",
" <td>2006-04-22</td>\n",
" <td>TMIN</td>\n",
" <td>6.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>18</th>\n",
" <td>USC00203712</td>\n",
" <td>2008-02-22</td>\n",
" <td>TMAX</td>\n",
" <td>-4.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>19</th>\n",
" <td>USC00205563</td>\n",
" <td>2015-01-03</td>\n",
" <td>TMIN</td>\n",
" <td>-3.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>20</th>\n",
" <td>USC00201250</td>\n",
" <td>2011-03-28</td>\n",
" <td>TMIN</td>\n",
" <td>-7.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>21</th>\n",
" <td>USC00200230</td>\n",
" <td>2008-02-10</td>\n",
" <td>TMAX</td>\n",
" <td>-0.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>22</th>\n",
" <td>USC00207320</td>\n",
" <td>2008-02-03</td>\n",
" <td>TMIN</td>\n",
" <td>-3.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>23</th>\n",
" <td>USC00200228</td>\n",
" <td>2008-02-23</td>\n",
" <td>TMAX</td>\n",
" <td>1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>24</th>\n",
" <td>USC00201250</td>\n",
" <td>2012-03-20</td>\n",
" <td>TMIN</td>\n",
" <td>10.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>25</th>\n",
" <td>USC00205822</td>\n",
" <td>2006-03-29</td>\n",
" <td>TMIN</td>\n",
" <td>-1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>26</th>\n",
" <td>USC00202308</td>\n",
" <td>2006-05-11</td>\n",
" <td>TMAX</td>\n",
" <td>23.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>27</th>\n",
" <td>USW00014833</td>\n",
" <td>2012-03-31</td>\n",
" <td>TMAX</td>\n",
" <td>6.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>28</th>\n",
" <td>USW00014853</td>\n",
" <td>2010-07-25</td>\n",
" <td>TMAX</td>\n",
" <td>28.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>29</th>\n",
" <td>USC00205822</td>\n",
" <td>2014-12-09</td>\n",
" <td>TMIN</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>...</th>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165055</th>\n",
" <td>USC00202308</td>\n",
" <td>2009-10-09</td>\n",
" <td>TMAX</td>\n",
" <td>11.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165056</th>\n",
" <td>USC00200228</td>\n",
" <td>2015-02-23</td>\n",
" <td>TMAX</td>\n",
" <td>-1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165057</th>\n",
" <td>USC00208080</td>\n",
" <td>2009-11-24</td>\n",
" <td>TMAX</td>\n",
" <td>10.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165058</th>\n",
" <td>USC00208972</td>\n",
" <td>2010-03-22</td>\n",
" <td>TMAX</td>\n",
" <td>9.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165059</th>\n",
" <td>USC00207312</td>\n",
" <td>2015-06-23</td>\n",
" <td>TMIN</td>\n",
" <td>17.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165060</th>\n",
" <td>USC00200230</td>\n",
" <td>2010-05-23</td>\n",
" <td>TMAX</td>\n",
" <td>28.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165061</th>\n",
" <td>USW00004848</td>\n",
" <td>2012-12-26</td>\n",
" <td>TMIN</td>\n",
" <td>-3.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165062</th>\n",
" <td>USC00205822</td>\n",
" <td>2014-02-06</td>\n",
" <td>TMAX</td>\n",
" <td>-1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165063</th>\n",
" <td>USC00200230</td>\n",
" <td>2010-05-23</td>\n",
" <td>TMIN</td>\n",
" <td>13.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165064</th>\n",
" <td>USC00207312</td>\n",
" <td>2008-08-04</td>\n",
" <td>TMIN</td>\n",
" <td>17.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165065</th>\n",
" <td>USC00200032</td>\n",
" <td>2006-03-01</td>\n",
" <td>TMAX</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165066</th>\n",
" <td>USC00207312</td>\n",
" <td>2008-08-04</td>\n",
" <td>TMAX</td>\n",
" <td>30.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165067</th>\n",
" <td>USC00207312</td>\n",
" <td>2005-12-31</td>\n",
" <td>TMAX</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165068</th>\n",
" <td>USW00094889</td>\n",
" <td>2005-12-20</td>\n",
" <td>TMAX</td>\n",
" <td>-3.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165069</th>\n",
" <td>USW00004848</td>\n",
" <td>2011-03-18</td>\n",
" <td>TMIN</td>\n",
" <td>4.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165070</th>\n",
" <td>USC00208202</td>\n",
" <td>2011-11-26</td>\n",
" <td>TMIN</td>\n",
" <td>2.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165071</th>\n",
" <td>USC00201250</td>\n",
" <td>2010-06-19</td>\n",
" <td>TMAX</td>\n",
" <td>29.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165072</th>\n",
" <td>USC00208080</td>\n",
" <td>2015-11-14</td>\n",
" <td>TMIN</td>\n",
" <td>-1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165073</th>\n",
" <td>USC00205563</td>\n",
" <td>2005-05-13</td>\n",
" <td>TMAX</td>\n",
" <td>22.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165074</th>\n",
" <td>USW00094889</td>\n",
" <td>2009-07-09</td>\n",
" <td>TMAX</td>\n",
" <td>26.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165075</th>\n",
" <td>USC00205451</td>\n",
" <td>2014-10-03</td>\n",
" <td>TMIN</td>\n",
" <td>10.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165076</th>\n",
" <td>USC00205050</td>\n",
" <td>2013-09-29</td>\n",
" <td>TMAX</td>\n",
" <td>26.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165077</th>\n",
" <td>USC00205050</td>\n",
" <td>2014-07-14</td>\n",
" <td>TMIN</td>\n",
" <td>17.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165078</th>\n",
" <td>USC00200032</td>\n",
" <td>2011-06-27</td>\n",
" <td>TMIN</td>\n",
" <td>14.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165079</th>\n",
" <td>USC00202308</td>\n",
" <td>2005-03-02</td>\n",
" <td>TMIN</td>\n",
" <td>-6.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165080</th>\n",
" <td>USC00205822</td>\n",
" <td>2015-06-09</td>\n",
" <td>TMAX</td>\n",
" <td>25.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165081</th>\n",
" <td>USC00205822</td>\n",
" <td>2009-10-06</td>\n",
" <td>TMAX</td>\n",
" <td>16.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165082</th>\n",
" <td>USC00205050</td>\n",
" <td>2014-07-14</td>\n",
" <td>TMAX</td>\n",
" <td>28.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165083</th>\n",
" <td>USC00200230</td>\n",
" <td>2006-11-29</td>\n",
" <td>TMIN</td>\n",
" <td>11.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165084</th>\n",
" <td>USC00207312</td>\n",
" <td>2006-09-04</td>\n",
" <td>TMIN</td>\n",
" <td>11.1</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"<p>165002 rows × 4 columns</p>\n",
"</div>"
],
"text/plain": [
" ID Date Element Data_Value\n",
"0 USW00094889 2014-11-12 TMAX 2.2\n",
"1 USC00208972 2009-04-29 TMIN 5.6\n",
"2 USC00200032 2008-05-26 TMAX 27.8\n",
"3 USC00205563 2005-11-11 TMAX 13.9\n",
"4 USC00200230 2014-02-27 TMAX -10.6\n",
"5 USW00014833 2010-10-01 TMAX 19.4\n",
"6 USC00207308 2010-06-29 TMIN 14.4\n",
"7 USC00203712 2005-10-04 TMAX 28.9\n",
"8 USW00004848 2007-12-14 TMIN -1.6\n",
"9 USC00200220 2011-04-21 TMAX 7.2\n",
"10 USC00205822 2013-01-16 TMAX 1.1\n",
"11 USC00205822 2008-05-29 TMIN 2.8\n",
"12 USC00203712 2008-10-17 TMIN 1.7\n",
"13 USC00205563 2006-05-14 TMAX 18.3\n",
"14 USC00200842 2006-05-14 TMAX 12.2\n",
"15 USC00205563 2014-12-07 TMAX 6.7\n",
"16 USC00205822 2008-09-07 TMAX 25.0\n",
"17 USC00205450 2006-04-22 TMIN 6.7\n",
"18 USC00203712 2008-02-22 TMAX -4.4\n",
"19 USC00205563 2015-01-03 TMIN -3.9\n",
"20 USC00201250 2011-03-28 TMIN -7.8\n",
"21 USC00200230 2008-02-10 TMAX -0.6\n",
"22 USC00207320 2008-02-03 TMIN -3.9\n",
"23 USC00200228 2008-02-23 TMAX 1.1\n",
"24 USC00201250 2012-03-20 TMIN 10.0\n",
"25 USC00205822 2006-03-29 TMIN -1.7\n",
"26 USC00202308 2006-05-11 TMAX 23.3\n",
"27 USW00014833 2012-03-31 TMAX 6.1\n",
"28 USW00014853 2010-07-25 TMAX 28.3\n",
"29 USC00205822 2014-12-09 TMIN 1.7\n",
"... ... ... ... ...\n",
"165055 USC00202308 2009-10-09 TMAX 11.1\n",
"165056 USC00200228 2015-02-23 TMAX -1.1\n",
"165057 USC00208080 2009-11-24 TMAX 10.0\n",
"165058 USC00208972 2010-03-22 TMAX 9.4\n",
"165059 USC00207312 2015-06-23 TMIN 17.2\n",
"165060 USC00200230 2010-05-23 TMAX 28.3\n",
"165061 USW00004848 2012-12-26 TMIN -3.2\n",
"165062 USC00205822 2014-02-06 TMAX -1.1\n",
"165063 USC00200230 2010-05-23 TMIN 13.3\n",
"165064 USC00207312 2008-08-04 TMIN 17.2\n",
"165065 USC00200032 2006-03-01 TMAX 1.7\n",
"165066 USC00207312 2008-08-04 TMAX 30.6\n",
"165067 USC00207312 2005-12-31 TMAX 1.7\n",
"165068 USW00094889 2005-12-20 TMAX -3.9\n",
"165069 USW00004848 2011-03-18 TMIN 4.4\n",
"165070 USC00208202 2011-11-26 TMIN 2.8\n",
"165071 USC00201250 2010-06-19 TMAX 29.4\n",
"165072 USC00208080 2015-11-14 TMIN -1.7\n",
"165073 USC00205563 2005-05-13 TMAX 22.2\n",
"165074 USW00094889 2009-07-09 TMAX 26.1\n",
"165075 USC00205451 2014-10-03 TMIN 10.0\n",
"165076 USC00205050 2013-09-29 TMAX 26.1\n",
"165077 USC00205050 2014-07-14 TMIN 17.2\n",
"165078 USC00200032 2011-06-27 TMIN 14.4\n",
"165079 USC00202308 2005-03-02 TMIN -6.7\n",
"165080 USC00205822 2015-06-09 TMAX 25.6\n",
"165081 USC00205822 2009-10-06 TMAX 16.7\n",
"165082 USC00205050 2014-07-14 TMAX 28.3\n",
"165083 USC00200230 2006-11-29 TMIN 11.7\n",
"165084 USC00207312 2006-09-04 TMIN 11.1\n",
"\n",
"[165002 rows x 4 columns]"
]
},
"execution_count": 10,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Seperate data into 2 datasets: 2005-2014 and 2015 data"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"2005-01-01\n",
"2014-12-31\n"
]
}
],
"source": [
"df_14=df[df['Date'].str[:4]!='2015']\n",
"\n",
"print(df_14['Date'].min())\n",
"print(df_14['Date'].max())"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"2015-01-01\n",
"2015-12-31\n"
]
}
],
"source": [
"df_15=df[df['Date'].str[:4]=='2015']\n",
"print(df_15['Date'].min())\n",
"print(df_15['Date'].max())"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Delete \"Year\" from the label"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Because we want to draw a line by day of the year"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/opt/conda/lib/python3.5/site-packages/ipykernel/__main__.py:1: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" if __name__ == '__main__':\n"
]
}
],
"source": [
"df_14['Date'] = df_14['Date'].map(lambda x: x[-5:])"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"365"
]
},
"execution_count": 14,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df_14['Date'].nunique()"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>ID</th>\n",
" <th>Date</th>\n",
" <th>Element</th>\n",
" <th>Data_Value</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>USW00094889</td>\n",
" <td>11-12</td>\n",
" <td>TMAX</td>\n",
" <td>2.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>USC00208972</td>\n",
" <td>04-29</td>\n",
" <td>TMIN</td>\n",
" <td>5.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>USC00200032</td>\n",
" <td>05-26</td>\n",
" <td>TMAX</td>\n",
" <td>27.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>USC00205563</td>\n",
" <td>11-11</td>\n",
" <td>TMAX</td>\n",
" <td>13.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>USC00200230</td>\n",
" <td>02-27</td>\n",
" <td>TMAX</td>\n",
" <td>-10.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5</th>\n",
" <td>USW00014833</td>\n",
" <td>10-01</td>\n",
" <td>TMAX</td>\n",
" <td>19.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>6</th>\n",
" <td>USC00207308</td>\n",
" <td>06-29</td>\n",
" <td>TMIN</td>\n",
" <td>14.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>7</th>\n",
" <td>USC00203712</td>\n",
" <td>10-04</td>\n",
" <td>TMAX</td>\n",
" <td>28.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>8</th>\n",
" <td>USW00004848</td>\n",
" <td>12-14</td>\n",
" <td>TMIN</td>\n",
" <td>-1.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9</th>\n",
" <td>USC00200220</td>\n",
" <td>04-21</td>\n",
" <td>TMAX</td>\n",
" <td>7.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>10</th>\n",
" <td>USC00205822</td>\n",
" <td>01-16</td>\n",
" <td>TMAX</td>\n",
" <td>1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>11</th>\n",
" <td>USC00205822</td>\n",
" <td>05-29</td>\n",
" <td>TMIN</td>\n",
" <td>2.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>12</th>\n",
" <td>USC00203712</td>\n",
" <td>10-17</td>\n",
" <td>TMIN</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>13</th>\n",
" <td>USC00205563</td>\n",
" <td>05-14</td>\n",
" <td>TMAX</td>\n",
" <td>18.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>14</th>\n",
" <td>USC00200842</td>\n",
" <td>05-14</td>\n",
" <td>TMAX</td>\n",
" <td>12.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>15</th>\n",
" <td>USC00205563</td>\n",
" <td>12-07</td>\n",
" <td>TMAX</td>\n",
" <td>6.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>16</th>\n",
" <td>USC00205822</td>\n",
" <td>09-07</td>\n",
" <td>TMAX</td>\n",
" <td>25.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>17</th>\n",
" <td>USC00205450</td>\n",
" <td>04-22</td>\n",
" <td>TMIN</td>\n",
" <td>6.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>18</th>\n",
" <td>USC00203712</td>\n",
" <td>02-22</td>\n",
" <td>TMAX</td>\n",
" <td>-4.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>20</th>\n",
" <td>USC00201250</td>\n",
" <td>03-28</td>\n",
" <td>TMIN</td>\n",
" <td>-7.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>21</th>\n",
" <td>USC00200230</td>\n",
" <td>02-10</td>\n",
" <td>TMAX</td>\n",
" <td>-0.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>22</th>\n",
" <td>USC00207320</td>\n",
" <td>02-03</td>\n",
" <td>TMIN</td>\n",
" <td>-3.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>23</th>\n",
" <td>USC00200228</td>\n",
" <td>02-23</td>\n",
" <td>TMAX</td>\n",
" <td>1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>24</th>\n",
" <td>USC00201250</td>\n",
" <td>03-20</td>\n",
" <td>TMIN</td>\n",
" <td>10.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>25</th>\n",
" <td>USC00205822</td>\n",
" <td>03-29</td>\n",
" <td>TMIN</td>\n",
" <td>-1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>26</th>\n",
" <td>USC00202308</td>\n",
" <td>05-11</td>\n",
" <td>TMAX</td>\n",
" <td>23.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>27</th>\n",
" <td>USW00014833</td>\n",
" <td>03-31</td>\n",
" <td>TMAX</td>\n",
" <td>6.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>28</th>\n",
" <td>USW00014853</td>\n",
" <td>07-25</td>\n",
" <td>TMAX</td>\n",
" <td>28.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>29</th>\n",
" <td>USC00205822</td>\n",
" <td>12-09</td>\n",
" <td>TMIN</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>31</th>\n",
" <td>USC00205050</td>\n",
" <td>03-20</td>\n",
" <td>TMIN</td>\n",
" <td>9.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>...</th>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165050</th>\n",
" <td>USC00200842</td>\n",
" <td>12-08</td>\n",
" <td>TMAX</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165051</th>\n",
" <td>USC00205451</td>\n",
" <td>09-18</td>\n",
" <td>TMIN</td>\n",
" <td>10.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165052</th>\n",
" <td>USC00208080</td>\n",
" <td>11-03</td>\n",
" <td>TMIN</td>\n",
" <td>5.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165053</th>\n",
" <td>USC00200032</td>\n",
" <td>06-27</td>\n",
" <td>TMAX</td>\n",
" <td>28.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165055</th>\n",
" <td>USC00202308</td>\n",
" <td>10-09</td>\n",
" <td>TMAX</td>\n",
" <td>11.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165057</th>\n",
" <td>USC00208080</td>\n",
" <td>11-24</td>\n",
" <td>TMAX</td>\n",
" <td>10.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165058</th>\n",
" <td>USC00208972</td>\n",
" <td>03-22</td>\n",
" <td>TMAX</td>\n",
" <td>9.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165060</th>\n",
" <td>USC00200230</td>\n",
" <td>05-23</td>\n",
" <td>TMAX</td>\n",
" <td>28.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165061</th>\n",
" <td>USW00004848</td>\n",
" <td>12-26</td>\n",
" <td>TMIN</td>\n",
" <td>-3.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165062</th>\n",
" <td>USC00205822</td>\n",
" <td>02-06</td>\n",
" <td>TMAX</td>\n",
" <td>-1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165063</th>\n",
" <td>USC00200230</td>\n",
" <td>05-23</td>\n",
" <td>TMIN</td>\n",
" <td>13.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165064</th>\n",
" <td>USC00207312</td>\n",
" <td>08-04</td>\n",
" <td>TMIN</td>\n",
" <td>17.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165065</th>\n",
" <td>USC00200032</td>\n",
" <td>03-01</td>\n",
" <td>TMAX</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165066</th>\n",
" <td>USC00207312</td>\n",
" <td>08-04</td>\n",
" <td>TMAX</td>\n",
" <td>30.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165067</th>\n",
" <td>USC00207312</td>\n",
" <td>12-31</td>\n",
" <td>TMAX</td>\n",
" <td>1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165068</th>\n",
" <td>USW00094889</td>\n",
" <td>12-20</td>\n",
" <td>TMAX</td>\n",
" <td>-3.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165069</th>\n",
" <td>USW00004848</td>\n",
" <td>03-18</td>\n",
" <td>TMIN</td>\n",
" <td>4.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165070</th>\n",
" <td>USC00208202</td>\n",
" <td>11-26</td>\n",
" <td>TMIN</td>\n",
" <td>2.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165071</th>\n",
" <td>USC00201250</td>\n",
" <td>06-19</td>\n",
" <td>TMAX</td>\n",
" <td>29.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165073</th>\n",
" <td>USC00205563</td>\n",
" <td>05-13</td>\n",
" <td>TMAX</td>\n",
" <td>22.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165074</th>\n",
" <td>USW00094889</td>\n",
" <td>07-09</td>\n",
" <td>TMAX</td>\n",
" <td>26.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165075</th>\n",
" <td>USC00205451</td>\n",
" <td>10-03</td>\n",
" <td>TMIN</td>\n",
" <td>10.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165076</th>\n",
" <td>USC00205050</td>\n",
" <td>09-29</td>\n",
" <td>TMAX</td>\n",
" <td>26.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165077</th>\n",
" <td>USC00205050</td>\n",
" <td>07-14</td>\n",
" <td>TMIN</td>\n",
" <td>17.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165078</th>\n",
" <td>USC00200032</td>\n",
" <td>06-27</td>\n",
" <td>TMIN</td>\n",
" <td>14.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165079</th>\n",
" <td>USC00202308</td>\n",
" <td>03-02</td>\n",
" <td>TMIN</td>\n",
" <td>-6.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165081</th>\n",
" <td>USC00205822</td>\n",
" <td>10-06</td>\n",
" <td>TMAX</td>\n",
" <td>16.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165082</th>\n",
" <td>USC00205050</td>\n",
" <td>07-14</td>\n",
" <td>TMAX</td>\n",
" <td>28.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165083</th>\n",
" <td>USC00200230</td>\n",
" <td>11-29</td>\n",
" <td>TMIN</td>\n",
" <td>11.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165084</th>\n",
" <td>USC00207312</td>\n",
" <td>09-04</td>\n",
" <td>TMIN</td>\n",
" <td>11.1</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"<p>151245 rows × 4 columns</p>\n",
"</div>"
],
"text/plain": [
" ID Date Element Data_Value\n",
"0 USW00094889 11-12 TMAX 2.2\n",
"1 USC00208972 04-29 TMIN 5.6\n",
"2 USC00200032 05-26 TMAX 27.8\n",
"3 USC00205563 11-11 TMAX 13.9\n",
"4 USC00200230 02-27 TMAX -10.6\n",
"5 USW00014833 10-01 TMAX 19.4\n",
"6 USC00207308 06-29 TMIN 14.4\n",
"7 USC00203712 10-04 TMAX 28.9\n",
"8 USW00004848 12-14 TMIN -1.6\n",
"9 USC00200220 04-21 TMAX 7.2\n",
"10 USC00205822 01-16 TMAX 1.1\n",
"11 USC00205822 05-29 TMIN 2.8\n",
"12 USC00203712 10-17 TMIN 1.7\n",
"13 USC00205563 05-14 TMAX 18.3\n",
"14 USC00200842 05-14 TMAX 12.2\n",
"15 USC00205563 12-07 TMAX 6.7\n",
"16 USC00205822 09-07 TMAX 25.0\n",
"17 USC00205450 04-22 TMIN 6.7\n",
"18 USC00203712 02-22 TMAX -4.4\n",
"20 USC00201250 03-28 TMIN -7.8\n",
"21 USC00200230 02-10 TMAX -0.6\n",
"22 USC00207320 02-03 TMIN -3.9\n",
"23 USC00200228 02-23 TMAX 1.1\n",
"24 USC00201250 03-20 TMIN 10.0\n",
"25 USC00205822 03-29 TMIN -1.7\n",
"26 USC00202308 05-11 TMAX 23.3\n",
"27 USW00014833 03-31 TMAX 6.1\n",
"28 USW00014853 07-25 TMAX 28.3\n",
"29 USC00205822 12-09 TMIN 1.7\n",
"31 USC00205050 03-20 TMIN 9.4\n",
"... ... ... ... ...\n",
"165050 USC00200842 12-08 TMAX 1.7\n",
"165051 USC00205451 09-18 TMIN 10.0\n",
"165052 USC00208080 11-03 TMIN 5.0\n",
"165053 USC00200032 06-27 TMAX 28.3\n",
"165055 USC00202308 10-09 TMAX 11.1\n",
"165057 USC00208080 11-24 TMAX 10.0\n",
"165058 USC00208972 03-22 TMAX 9.4\n",
"165060 USC00200230 05-23 TMAX 28.3\n",
"165061 USW00004848 12-26 TMIN -3.2\n",
"165062 USC00205822 02-06 TMAX -1.1\n",
"165063 USC00200230 05-23 TMIN 13.3\n",
"165064 USC00207312 08-04 TMIN 17.2\n",
"165065 USC00200032 03-01 TMAX 1.7\n",
"165066 USC00207312 08-04 TMAX 30.6\n",
"165067 USC00207312 12-31 TMAX 1.7\n",
"165068 USW00094889 12-20 TMAX -3.9\n",
"165069 USW00004848 03-18 TMIN 4.4\n",
"165070 USC00208202 11-26 TMIN 2.8\n",
"165071 USC00201250 06-19 TMAX 29.4\n",
"165073 USC00205563 05-13 TMAX 22.2\n",
"165074 USW00094889 07-09 TMAX 26.1\n",
"165075 USC00205451 10-03 TMIN 10.0\n",
"165076 USC00205050 09-29 TMAX 26.1\n",
"165077 USC00205050 07-14 TMIN 17.2\n",
"165078 USC00200032 06-27 TMIN 14.4\n",
"165079 USC00202308 03-02 TMIN -6.7\n",
"165081 USC00205822 10-06 TMAX 16.7\n",
"165082 USC00205050 07-14 TMAX 28.3\n",
"165083 USC00200230 11-29 TMIN 11.7\n",
"165084 USC00207312 09-04 TMIN 11.1\n",
"\n",
"[151245 rows x 4 columns]"
]
},
"execution_count": 15,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df_14"
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"/opt/conda/lib/python3.5/site-packages/ipykernel/__main__.py:1: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
"Try using .loc[row_indexer,col_indexer] = value instead\n",
"\n",
"See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/indexing.html#indexing-view-versus-copy\n",
" if __name__ == '__main__':\n"
]
}
],
"source": [
"df_15['Date'] = df_15['Date'].map(lambda x: x[-5:])"
]
},
{
"cell_type": "code",
"execution_count": 17,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"365"
]
},
"execution_count": 17,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df_15['Date'].nunique()"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>ID</th>\n",
" <th>Date</th>\n",
" <th>Element</th>\n",
" <th>Data_Value</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>19</th>\n",
" <td>USC00205563</td>\n",
" <td>01-03</td>\n",
" <td>TMIN</td>\n",
" <td>-3.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>30</th>\n",
" <td>USC00203712</td>\n",
" <td>03-17</td>\n",
" <td>TMAX</td>\n",
" <td>18.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>34</th>\n",
" <td>USC00200032</td>\n",
" <td>06-06</td>\n",
" <td>TMIN</td>\n",
" <td>12.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>46</th>\n",
" <td>USW00014833</td>\n",
" <td>08-30</td>\n",
" <td>TMIN</td>\n",
" <td>17.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>50</th>\n",
" <td>USC00202308</td>\n",
" <td>08-30</td>\n",
" <td>TMIN</td>\n",
" <td>15.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>51</th>\n",
" <td>USC00205563</td>\n",
" <td>01-03</td>\n",
" <td>TMAX</td>\n",
" <td>2.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>59</th>\n",
" <td>USC00202308</td>\n",
" <td>08-30</td>\n",
" <td>TMAX</td>\n",
" <td>26.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>72</th>\n",
" <td>USC00200230</td>\n",
" <td>04-01</td>\n",
" <td>TMIN</td>\n",
" <td>-1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>126</th>\n",
" <td>USC00200032</td>\n",
" <td>06-06</td>\n",
" <td>TMAX</td>\n",
" <td>23.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>139</th>\n",
" <td>USW00014853</td>\n",
" <td>05-17</td>\n",
" <td>TMIN</td>\n",
" <td>18.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>146</th>\n",
" <td>USC00208972</td>\n",
" <td>04-09</td>\n",
" <td>TMAX</td>\n",
" <td>6.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>155</th>\n",
" <td>USC00205050</td>\n",
" <td>01-05</td>\n",
" <td>TMIN</td>\n",
" <td>-13.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>157</th>\n",
" <td>USC00200230</td>\n",
" <td>04-01</td>\n",
" <td>TMAX</td>\n",
" <td>18.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>170</th>\n",
" <td>USC00203712</td>\n",
" <td>03-17</td>\n",
" <td>TMIN</td>\n",
" <td>1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>179</th>\n",
" <td>USC00208972</td>\n",
" <td>05-27</td>\n",
" <td>TMAX</td>\n",
" <td>27.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>188</th>\n",
" <td>USC00201250</td>\n",
" <td>05-14</td>\n",
" <td>TMIN</td>\n",
" <td>2.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>198</th>\n",
" <td>USC00205451</td>\n",
" <td>04-01</td>\n",
" <td>TMAX</td>\n",
" <td>7.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>225</th>\n",
" <td>USC00200230</td>\n",
" <td>11-24</td>\n",
" <td>TMAX</td>\n",
" <td>6.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>279</th>\n",
" <td>USC00205563</td>\n",
" <td>08-27</td>\n",
" <td>TMAX</td>\n",
" <td>18.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>284</th>\n",
" <td>USC00205822</td>\n",
" <td>09-10</td>\n",
" <td>TMAX</td>\n",
" <td>27.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>294</th>\n",
" <td>USC00205822</td>\n",
" <td>09-10</td>\n",
" <td>TMIN</td>\n",
" <td>11.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>329</th>\n",
" <td>USC00205563</td>\n",
" <td>08-27</td>\n",
" <td>TMIN</td>\n",
" <td>10.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>332</th>\n",
" <td>USC00208972</td>\n",
" <td>04-09</td>\n",
" <td>TMIN</td>\n",
" <td>2.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>338</th>\n",
" <td>USW00014853</td>\n",
" <td>05-17</td>\n",
" <td>TMAX</td>\n",
" <td>30.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>340</th>\n",
" <td>USC00200228</td>\n",
" <td>05-17</td>\n",
" <td>TMAX</td>\n",
" <td>25.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>347</th>\n",
" <td>USC00203712</td>\n",
" <td>11-30</td>\n",
" <td>TMAX</td>\n",
" <td>5.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>405</th>\n",
" <td>USC00208972</td>\n",
" <td>05-27</td>\n",
" <td>TMIN</td>\n",
" <td>16.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>406</th>\n",
" <td>USC00205451</td>\n",
" <td>04-01</td>\n",
" <td>TMIN</td>\n",
" <td>-1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>409</th>\n",
" <td>USC00200228</td>\n",
" <td>08-26</td>\n",
" <td>TMAX</td>\n",
" <td>18.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>417</th>\n",
" <td>USC00200228</td>\n",
" <td>08-26</td>\n",
" <td>TMIN</td>\n",
" <td>11.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>...</th>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164732</th>\n",
" <td>USC00205050</td>\n",
" <td>07-22</td>\n",
" <td>TMAX</td>\n",
" <td>26.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164737</th>\n",
" <td>USC00201250</td>\n",
" <td>06-08</td>\n",
" <td>TMAX</td>\n",
" <td>25.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164763</th>\n",
" <td>USC00207308</td>\n",
" <td>07-10</td>\n",
" <td>TMIN</td>\n",
" <td>11.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164774</th>\n",
" <td>USC00203712</td>\n",
" <td>10-05</td>\n",
" <td>TMIN</td>\n",
" <td>11.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164780</th>\n",
" <td>USC00203712</td>\n",
" <td>10-05</td>\n",
" <td>TMAX</td>\n",
" <td>15.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164781</th>\n",
" <td>USC00208202</td>\n",
" <td>01-19</td>\n",
" <td>TMAX</td>\n",
" <td>2.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164801</th>\n",
" <td>USC00200230</td>\n",
" <td>03-10</td>\n",
" <td>TMIN</td>\n",
" <td>-1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164821</th>\n",
" <td>USC00207308</td>\n",
" <td>07-10</td>\n",
" <td>TMAX</td>\n",
" <td>22.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164827</th>\n",
" <td>USC00208080</td>\n",
" <td>11-14</td>\n",
" <td>TMAX</td>\n",
" <td>9.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164849</th>\n",
" <td>USC00205822</td>\n",
" <td>06-10</td>\n",
" <td>TMAX</td>\n",
" <td>26.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164862</th>\n",
" <td>USC00200230</td>\n",
" <td>10-06</td>\n",
" <td>TMAX</td>\n",
" <td>20.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164895</th>\n",
" <td>USC00205822</td>\n",
" <td>06-10</td>\n",
" <td>TMIN</td>\n",
" <td>15.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164920</th>\n",
" <td>USC00207312</td>\n",
" <td>07-10</td>\n",
" <td>TMAX</td>\n",
" <td>22.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164938</th>\n",
" <td>USC00205451</td>\n",
" <td>08-08</td>\n",
" <td>TMIN</td>\n",
" <td>16.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164964</th>\n",
" <td>USW00094889</td>\n",
" <td>04-21</td>\n",
" <td>TMIN</td>\n",
" <td>2.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164966</th>\n",
" <td>USC00205822</td>\n",
" <td>06-09</td>\n",
" <td>TMIN</td>\n",
" <td>15.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164971</th>\n",
" <td>USC00200228</td>\n",
" <td>02-16</td>\n",
" <td>TMIN</td>\n",
" <td>-26.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>164975</th>\n",
" <td>USC00200228</td>\n",
" <td>02-23</td>\n",
" <td>TMIN</td>\n",
" <td>-22.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165000</th>\n",
" <td>USC00200228</td>\n",
" <td>02-16</td>\n",
" <td>TMAX</td>\n",
" <td>-13.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165007</th>\n",
" <td>USC00205451</td>\n",
" <td>08-08</td>\n",
" <td>TMAX</td>\n",
" <td>25.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165020</th>\n",
" <td>USC00205451</td>\n",
" <td>10-02</td>\n",
" <td>TMAX</td>\n",
" <td>18.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165023</th>\n",
" <td>USC00205822</td>\n",
" <td>01-16</td>\n",
" <td>TMIN</td>\n",
" <td>-15.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165032</th>\n",
" <td>USC00205451</td>\n",
" <td>10-02</td>\n",
" <td>TMIN</td>\n",
" <td>7.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165038</th>\n",
" <td>USC00207312</td>\n",
" <td>07-10</td>\n",
" <td>TMIN</td>\n",
" <td>13.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165045</th>\n",
" <td>USC00200230</td>\n",
" <td>03-10</td>\n",
" <td>TMAX</td>\n",
" <td>9.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165054</th>\n",
" <td>USC00208080</td>\n",
" <td>02-14</td>\n",
" <td>TMIN</td>\n",
" <td>-21.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165056</th>\n",
" <td>USC00200228</td>\n",
" <td>02-23</td>\n",
" <td>TMAX</td>\n",
" <td>-1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165059</th>\n",
" <td>USC00207312</td>\n",
" <td>06-23</td>\n",
" <td>TMIN</td>\n",
" <td>17.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165072</th>\n",
" <td>USC00208080</td>\n",
" <td>11-14</td>\n",
" <td>TMIN</td>\n",
" <td>-1.7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>165080</th>\n",
" <td>USC00205822</td>\n",
" <td>06-09</td>\n",
" <td>TMAX</td>\n",
" <td>25.6</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"<p>13757 rows × 4 columns</p>\n",
"</div>"
],
"text/plain": [
" ID Date Element Data_Value\n",
"19 USC00205563 01-03 TMIN -3.9\n",
"30 USC00203712 03-17 TMAX 18.9\n",
"34 USC00200032 06-06 TMIN 12.8\n",
"46 USW00014833 08-30 TMIN 17.8\n",
"50 USC00202308 08-30 TMIN 15.6\n",
"51 USC00205563 01-03 TMAX 2.2\n",
"59 USC00202308 08-30 TMAX 26.1\n",
"72 USC00200230 04-01 TMIN -1.7\n",
"126 USC00200032 06-06 TMAX 23.3\n",
"139 USW00014853 05-17 TMIN 18.3\n",
"146 USC00208972 04-09 TMAX 6.7\n",
"155 USC00205050 01-05 TMIN -13.9\n",
"157 USC00200230 04-01 TMAX 18.3\n",
"170 USC00203712 03-17 TMIN 1.1\n",
"179 USC00208972 05-27 TMAX 27.8\n",
"188 USC00201250 05-14 TMIN 2.2\n",
"198 USC00205451 04-01 TMAX 7.2\n",
"225 USC00200230 11-24 TMAX 6.7\n",
"279 USC00205563 08-27 TMAX 18.9\n",
"284 USC00205822 09-10 TMAX 27.8\n",
"294 USC00205822 09-10 TMIN 11.7\n",
"329 USC00205563 08-27 TMIN 10.6\n",
"332 USC00208972 04-09 TMIN 2.8\n",
"338 USW00014853 05-17 TMAX 30.0\n",
"340 USC00200228 05-17 TMAX 25.6\n",
"347 USC00203712 11-30 TMAX 5.0\n",
"405 USC00208972 05-27 TMIN 16.7\n",
"406 USC00205451 04-01 TMIN -1.7\n",
"409 USC00200228 08-26 TMAX 18.9\n",
"417 USC00200228 08-26 TMIN 11.7\n",
"... ... ... ... ...\n",
"164732 USC00205050 07-22 TMAX 26.7\n",
"164737 USC00201250 06-08 TMAX 25.6\n",
"164763 USC00207308 07-10 TMIN 11.1\n",
"164774 USC00203712 10-05 TMIN 11.1\n",
"164780 USC00203712 10-05 TMAX 15.6\n",
"164781 USC00208202 01-19 TMAX 2.8\n",
"164801 USC00200230 03-10 TMIN -1.1\n",
"164821 USC00207308 07-10 TMAX 22.8\n",
"164827 USC00208080 11-14 TMAX 9.4\n",
"164849 USC00205822 06-10 TMAX 26.7\n",
"164862 USC00200230 10-06 TMAX 20.6\n",
"164895 USC00205822 06-10 TMIN 15.6\n",
"164920 USC00207312 07-10 TMAX 22.8\n",
"164938 USC00205451 08-08 TMIN 16.1\n",
"164964 USW00094889 04-21 TMIN 2.2\n",
"164966 USC00205822 06-09 TMIN 15.0\n",
"164971 USC00200228 02-16 TMIN -26.1\n",
"164975 USC00200228 02-23 TMIN -22.8\n",
"165000 USC00200228 02-16 TMAX -13.9\n",
"165007 USC00205451 08-08 TMAX 25.6\n",
"165020 USC00205451 10-02 TMAX 18.9\n",
"165023 USC00205822 01-16 TMIN -15.0\n",
"165032 USC00205451 10-02 TMIN 7.2\n",
"165038 USC00207312 07-10 TMIN 13.3\n",
"165045 USC00200230 03-10 TMAX 9.4\n",
"165054 USC00208080 02-14 TMIN -21.1\n",
"165056 USC00200228 02-23 TMAX -1.1\n",
"165059 USC00207312 06-23 TMIN 17.2\n",
"165072 USC00208080 11-14 TMIN -1.7\n",
"165080 USC00205822 06-09 TMAX 25.6\n",
"\n",
"[13757 rows x 4 columns]"
]
},
"execution_count": 18,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df_15"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Get record high/Low temp by day\n",
"###### 2005 - 2014"
]
},
{
"cell_type": "code",
"execution_count": 19,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr>\n",
" <th></th>\n",
" <th></th>\n",
" <th colspan=\"2\" halign=\"left\">Data_Value</th>\n",
" </tr>\n",
" <tr>\n",
" <th></th>\n",
" <th></th>\n",
" <th>min</th>\n",
" <th>max</th>\n",
" </tr>\n",
" <tr>\n",
" <th>Date</th>\n",
" <th>Element</th>\n",
" <th></th>\n",
" <th></th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th rowspan=\"2\" valign=\"top\">01-01</th>\n",
" <th>TMAX</th>\n",
" <td>-9.3</td>\n",
" <td>15.6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>TMIN</th>\n",
" <td>-16.0</td>\n",
" <td>7.2</td>\n",
" </tr>\n",
" <tr>\n",
" <th rowspan=\"2\" valign=\"top\">01-02</th>\n",
" <th>TMAX</th>\n",
" <td>-10.0</td>\n",
" <td>13.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>TMIN</th>\n",
" <td>-26.7</td>\n",
" <td>2.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>01-03</th>\n",
" <th>TMAX</th>\n",
" <td>-11.7</td>\n",
" <td>13.3</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Data_Value \n",
" min max\n",
"Date Element \n",
"01-01 TMAX -9.3 15.6\n",
" TMIN -16.0 7.2\n",
"01-02 TMAX -10.0 13.9\n",
" TMIN -26.7 2.8\n",
"01-03 TMAX -11.7 13.3"
]
},
"execution_count": 19,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"gb_14 = df_14.groupby(['Date','Element'])\n",
"df_early = gb_14.agg({'Data_Value' : [min, max]})\n",
"df_early.head()"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"15.600000000000001"
]
},
"execution_count": 20,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df_early.loc[('01-01','TMAX'),('Data_Value','max')]"
]
},
{
"cell_type": "code",
"execution_count": 21,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"[15.600000000000001,\n",
" 13.9,\n",
" 13.300000000000001,\n",
" 10.600000000000001,\n",
" 12.800000000000001,\n",
" 18.900000000000002,\n",
" 21.700000000000003,\n",
" 19.400000000000002,\n",
" 17.800000000000001,\n",
" 10.0,\n",
" 15.600000000000001,\n",
" 16.100000000000001,\n",
" 16.699999999999999,\n",
" 15.0,\n",
" 6.7000000000000002,\n",
" 9.4000000000000004,\n",
" 13.300000000000001,\n",
" 12.200000000000001,\n",
" 10.600000000000001,\n",
" 13.300000000000001,\n",
" 13.300000000000001,\n",
" 11.700000000000001,\n",
" 12.800000000000001,\n",
" 11.700000000000001,\n",
" 10.0,\n",
" 8.9000000000000004,\n",
" 7.8000000000000007,\n",
" 12.200000000000001,\n",
" 17.800000000000001,\n",
" 18.300000000000001,\n",
" 14.4,\n",
" 15.0,\n",
" 10.600000000000001,\n",
" 8.9000000000000004,\n",
" 11.700000000000001,\n",
" 12.200000000000001,\n",
" 11.700000000000001,\n",
" 11.700000000000001,\n",
" 12.800000000000001,\n",
" 7.8000000000000007,\n",
" 16.100000000000001,\n",
" 16.100000000000001,\n",
" 19.400000000000002,\n",
" 9.4000000000000004,\n",
" 10.600000000000001,\n",
" 11.700000000000001,\n",
" 14.4,\n",
" 15.600000000000001,\n",
" 14.4,\n",
" 12.800000000000001,\n",
" 10.600000000000001,\n",
" 10.0,\n",
" 10.600000000000001,\n",
" 12.200000000000001,\n",
" 11.100000000000001,\n",
" 9.4000000000000004,\n",
" 11.100000000000001,\n",
" 12.200000000000001,\n",
" 11.700000000000001,\n",
" 11.700000000000001,\n",
" 15.600000000000001,\n",
" 16.100000000000001,\n",
" 15.600000000000001,\n",
" 15.600000000000001,\n",
" 20.600000000000001,\n",
" 21.100000000000001,\n",
" 20.0,\n",
" 18.900000000000002,\n",
" 18.900000000000002,\n",
" 20.0,\n",
" 20.600000000000001,\n",
" 22.800000000000001,\n",
" 26.700000000000003,\n",
" 26.700000000000003,\n",
" 26.100000000000001,\n",
" 26.100000000000001,\n",
" 25.0,\n",
" 26.700000000000003,\n",
" 30.0,\n",
" 30.600000000000001,\n",
" 31.700000000000003,\n",
" 30.600000000000001,\n",
" 28.300000000000001,\n",
" 23.300000000000001,\n",
" 27.200000000000003,\n",
" 26.700000000000003,\n",
" 27.200000000000003,\n",
" 22.200000000000003,\n",
" 23.900000000000002,\n",
" 23.300000000000001,\n",
" 27.200000000000003,\n",
" 27.800000000000001,\n",
" 27.200000000000003,\n",
" 25.600000000000001,\n",
" 25.600000000000001,\n",
" 28.300000000000001,\n",
" 27.800000000000001,\n",
" 22.800000000000001,\n",
" 21.700000000000003,\n",
" 30.0,\n",
" 28.900000000000002,\n",
" 24.400000000000002,\n",
" 27.200000000000003,\n",
" 27.800000000000001,\n",
" 28.900000000000002,\n",
" 28.900000000000002,\n",
" 24.400000000000002,\n",
" 28.300000000000001,\n",
" 28.900000000000002,\n",
" 28.900000000000002,\n",
" 27.800000000000001,\n",
" 27.200000000000003,\n",
" 27.800000000000001,\n",
" 30.0,\n",
" 30.600000000000001,\n",
" 29.400000000000002,\n",
" 29.400000000000002,\n",
" 29.400000000000002,\n",
" 27.200000000000003,\n",
" 27.800000000000001,\n",
" 28.300000000000001,\n",
" 30.600000000000001,\n",
" 33.300000000000004,\n",
" 32.200000000000003,\n",
" 27.800000000000001,\n",
" 28.300000000000001,\n",
" 25.600000000000001,\n",
" 31.700000000000003,\n",
" 31.700000000000003,\n",
" 29.400000000000002,\n",
" 29.400000000000002,\n",
" 31.700000000000003,\n",
" 32.200000000000003,\n",
" 30.600000000000001,\n",
" 32.800000000000004,\n",
" 31.700000000000003,\n",
" 30.0,\n",
" 28.900000000000002,\n",
" 31.100000000000001,\n",
" 33.899999999999999,\n",
" 32.800000000000004,\n",
" 31.700000000000003,\n",
" 32.800000000000004,\n",
" 32.800000000000004,\n",
" 33.300000000000004,\n",
" 33.300000000000004,\n",
" 32.200000000000003,\n",
" 36.700000000000003,\n",
" 35.0,\n",
" 35.0,\n",
" 34.399999999999999,\n",
" 35.0,\n",
" 32.200000000000003,\n",
" 32.200000000000003,\n",
" 36.100000000000001,\n",
" 35.0,\n",
" 34.399999999999999,\n",
" 37.200000000000003,\n",
" 38.300000000000004,\n",
" 36.700000000000003,\n",
" 35.0,\n",
" 35.0,\n",
" 32.200000000000003,\n",
" 32.800000000000004,\n",
" 32.800000000000004,\n",
" 32.800000000000004,\n",
" 33.899999999999999,\n",
" 35.0,\n",
" 35.600000000000001,\n",
" 36.700000000000003,\n",
" 36.100000000000001,\n",
" 36.700000000000003,\n",
" 34.399999999999999,\n",
" 33.899999999999999,\n",
" 36.700000000000003,\n",
" 37.200000000000003,\n",
" 37.800000000000004,\n",
" 36.100000000000001,\n",
" 40.600000000000001,\n",
" 38.900000000000006,\n",
" 36.700000000000003,\n",
" 36.700000000000003,\n",
" 38.300000000000004,\n",
" 36.100000000000001,\n",
" 40.0,\n",
" 38.900000000000006,\n",
" 38.300000000000004,\n",
" 39.400000000000006,\n",
" 39.400000000000006,\n",
" 35.600000000000001,\n",
" 36.100000000000001,\n",
" 35.600000000000001,\n",
" 35.0,\n",
" 34.399999999999999,\n",
" 33.899999999999999,\n",
" 36.100000000000001,\n",
" 37.200000000000003,\n",
" 40.600000000000001,\n",
" 38.900000000000006,\n",
" 36.100000000000001,\n",
" 37.200000000000003,\n",
" 40.600000000000001,\n",
" 38.300000000000004,\n",
" 38.300000000000004,\n",
" 36.100000000000001,\n",
" 34.399999999999999,\n",
" 34.399999999999999,\n",
" 33.300000000000004,\n",
" 36.100000000000001,\n",
" 33.899999999999999,\n",
" 34.399999999999999,\n",
" 35.0,\n",
" 35.600000000000001,\n",
" 36.700000000000003,\n",
" 37.200000000000003,\n",
" 36.700000000000003,\n",
" 33.899999999999999,\n",
" 32.800000000000004,\n",
" 36.100000000000001,\n",
" 33.899999999999999,\n",
" 34.399999999999999,\n",
" 34.399999999999999,\n",
" 36.100000000000001,\n",
" 32.800000000000004,\n",
" 33.300000000000004,\n",
" 31.700000000000003,\n",
" 33.300000000000004,\n",
" 33.300000000000004,\n",
" 33.899999999999999,\n",
" 33.899999999999999,\n",
" 32.200000000000003,\n",
" 32.200000000000003,\n",
" 32.200000000000003,\n",
" 33.300000000000004,\n",
" 34.399999999999999,\n",
" 34.399999999999999,\n",
" 35.600000000000001,\n",
" 35.0,\n",
" 33.899999999999999,\n",
" 32.200000000000003,\n",
" 34.399999999999999,\n",
" 34.399999999999999,\n",
" 36.100000000000001,\n",
" 35.0,\n",
" 37.200000000000003,\n",
" 36.700000000000003,\n",
" 36.100000000000001,\n",
" 35.600000000000001,\n",
" 34.399999999999999,\n",
" 34.399999999999999,\n",
" 33.300000000000004,\n",
" 33.300000000000004,\n",
" 36.100000000000001,\n",
" 36.700000000000003,\n",
" 33.899999999999999,\n",
" 33.300000000000004,\n",
" 33.300000000000004,\n",
" 31.100000000000001,\n",
" 27.800000000000001,\n",
" 28.900000000000002,\n",
" 29.400000000000002,\n",
" 31.100000000000001,\n",
" 30.600000000000001,\n",
" 32.800000000000004,\n",
" 32.800000000000004,\n",
" 33.300000000000004,\n",
" 33.899999999999999,\n",
" 32.800000000000004,\n",
" 31.700000000000003,\n",
" 27.800000000000001,\n",
" 28.300000000000001,\n",
" 27.800000000000001,\n",
" 27.800000000000001,\n",
" 27.200000000000003,\n",
" 28.900000000000002,\n",
" 31.100000000000001,\n",
" 31.100000000000001,\n",
" 32.200000000000003,\n",
" 31.700000000000003,\n",
" 32.800000000000004,\n",
" 32.800000000000004,\n",
" 32.800000000000004,\n",
" 30.600000000000001,\n",
" 31.100000000000001,\n",
" 29.400000000000002,\n",
" 28.900000000000002,\n",
" 28.300000000000001,\n",
" 24.400000000000002,\n",
" 23.300000000000001,\n",
" 25.600000000000001,\n",
" 26.700000000000003,\n",
" 25.600000000000001,\n",
" 22.200000000000003,\n",
" 27.800000000000001,\n",
" 27.200000000000003,\n",
" 26.700000000000003,\n",
" 26.700000000000003,\n",
" 27.200000000000003,\n",
" 25.600000000000001,\n",
" 26.700000000000003,\n",
" 25.600000000000001,\n",
" 21.100000000000001,\n",
" 25.0,\n",
" 25.0,\n",
" 22.200000000000003,\n",
" 21.100000000000001,\n",
" 22.800000000000001,\n",
" 25.0,\n",
" 23.900000000000002,\n",
" 23.300000000000001,\n",
" 22.800000000000001,\n",
" 22.800000000000001,\n",
" 25.600000000000001,\n",
" 22.200000000000003,\n",
" 22.200000000000003,\n",
" 21.100000000000001,\n",
" 22.800000000000001,\n",
" 21.100000000000001,\n",
" 20.600000000000001,\n",
" 19.400000000000002,\n",
" 19.400000000000002,\n",
" 19.400000000000002,\n",
" 17.800000000000001,\n",
" 16.699999999999999,\n",
" 17.199999999999999,\n",
" 21.700000000000003,\n",
" 18.300000000000001,\n",
" 17.199999999999999,\n",
" 19.400000000000002,\n",
" 19.400000000000002,\n",
" 18.300000000000001,\n",
" 20.0,\n",
" 20.600000000000001,\n",
" 18.900000000000002,\n",
" 18.300000000000001,\n",
" 15.600000000000001,\n",
" 18.300000000000001,\n",
" 18.300000000000001,\n",
" 17.199999999999999,\n",
" 12.800000000000001,\n",
" 8.3000000000000007,\n",
" 7.2000000000000002,\n",
" 8.3000000000000007,\n",
" 11.100000000000001,\n",
" 12.800000000000001,\n",
" 13.300000000000001,\n",
" 11.100000000000001,\n",
" 13.9,\n",
" 15.0,\n",
" 13.9,\n",
" 14.4,\n",
" 15.600000000000001,\n",
" 12.200000000000001,\n",
" 13.300000000000001,\n",
" 15.600000000000001,\n",
" 13.300000000000001,\n",
" 13.300000000000001,\n",
" 13.9,\n",
" 10.0,\n",
" 10.600000000000001,\n",
" 18.900000000000002,\n",
" 19.400000000000002,\n",
" 12.800000000000001,\n",
" 11.700000000000001,\n",
" 13.9]"
]
},
"execution_count": 21,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"high_14=[]\n",
"for x in list(df_early.xs('TMAX',level='Element').xs('max',level=1,axis=1).values):\n",
" high_14.extend(x)\n",
"high_14"
]
},
{
"cell_type": "code",
"execution_count": 22,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"[-16.0,\n",
" -26.700000000000003,\n",
" -26.700000000000003,\n",
" -26.100000000000001,\n",
" -15.0,\n",
" -26.600000000000001,\n",
" -30.600000000000001,\n",
" -29.400000000000002,\n",
" -27.800000000000001,\n",
" -25.600000000000001,\n",
" -18.300000000000001,\n",
" -19.300000000000001,\n",
" -25.0,\n",
" -26.600000000000001,\n",
" -27.200000000000003,\n",
" -29.400000000000002,\n",
" -29.400000000000002,\n",
" -28.900000000000002,\n",
" -30.0,\n",
" -23.900000000000002,\n",
" -26.0,\n",
" -27.700000000000003,\n",
" -25.0,\n",
" -26.700000000000003,\n",
" -24.300000000000001,\n",
" -23.800000000000001,\n",
" -23.900000000000002,\n",
" -29.400000000000002,\n",
" -27.800000000000001,\n",
" -23.300000000000001,\n",
" -19.400000000000002,\n",
" -21.100000000000001,\n",
" -21.100000000000001,\n",
" -23.200000000000003,\n",
" -26.100000000000001,\n",
" -28.200000000000003,\n",
" -26.100000000000001,\n",
" -23.300000000000001,\n",
" -22.800000000000001,\n",
" -21.0,\n",
" -25.600000000000001,\n",
" -25.5,\n",
" -28.800000000000001,\n",
" -27.200000000000003,\n",
" -21.700000000000003,\n",
" -25.600000000000001,\n",
" -22.200000000000003,\n",
" -24.300000000000001,\n",
" -22.200000000000003,\n",
" -18.800000000000001,\n",
" -17.800000000000001,\n",
" -17.800000000000001,\n",
" -17.199999999999999,\n",
" -22.800000000000001,\n",
" -21.100000000000001,\n",
" -17.199999999999999,\n",
" -20.0,\n",
" -23.800000000000001,\n",
" -27.100000000000001,\n",
" -26.700000000000003,\n",
" -18.199999999999999,\n",
" -24.400000000000002,\n",
" -23.900000000000002,\n",
" -18.900000000000002,\n",
" -17.800000000000001,\n",
" -17.800000000000001,\n",
" -16.699999999999999,\n",
" -14.4,\n",
" -15.600000000000001,\n",
" -12.200000000000001,\n",
" -14.4,\n",
" -22.200000000000003,\n",
" -20.600000000000001,\n",
" -10.600000000000001,\n",
" -13.9,\n",
" -17.800000000000001,\n",
" -16.100000000000001,\n",
" -10.0,\n",
" -10.600000000000001,\n",
" -13.300000000000001,\n",
" -12.200000000000001,\n",
" -13.300000000000001,\n",
" -15.0,\n",
" -13.9,\n",
" -15.600000000000001,\n",
" -15.600000000000001,\n",
" -10.600000000000001,\n",
" -10.0,\n",
" -9.4000000000000004,\n",
" -8.3000000000000007,\n",
" -8.3000000000000007,\n",
" -7.8000000000000007,\n",
" -8.9000000000000004,\n",
" -8.3000000000000007,\n",
" -7.2000000000000002,\n",
" -9.4000000000000004,\n",
" -8.3000000000000007,\n",
" -8.9000000000000004,\n",
" -6.7000000000000002,\n",
" -8.3000000000000007,\n",
" -6.7000000000000002,\n",
" -7.2000000000000002,\n",
" -5.0,\n",
" -6.7000000000000002,\n",
" -8.3000000000000007,\n",
" -11.700000000000001,\n",
" -8.9000000000000004,\n",
" -2.8000000000000003,\n",
" -3.9000000000000004,\n",
" -4.4000000000000004,\n",
" -7.2000000000000002,\n",
" -5.0,\n",
" -5.6000000000000005,\n",
" -3.3000000000000003,\n",
" -3.9000000000000004,\n",
" -6.6000000000000005,\n",
" -3.9000000000000004,\n",
" -3.9000000000000004,\n",
" -5.0,\n",
" -4.9000000000000004,\n",
" -3.3000000000000003,\n",
" -2.8000000000000003,\n",
" -4.4000000000000004,\n",
" -6.1000000000000005,\n",
" -3.3000000000000003,\n",
" -1.7000000000000002,\n",
" -2.8000000000000003,\n",
" 0.0,\n",
" -1.7000000000000002,\n",
" -1.7000000000000002,\n",
" -1.1000000000000001,\n",
" -3.8000000000000003,\n",
" -6.0,\n",
" -2.8000000000000003,\n",
" 2.2000000000000002,\n",
" -3.3000000000000003,\n",
" -1.0,\n",
" -2.7000000000000002,\n",
" -1.6000000000000001,\n",
" 1.7000000000000002,\n",
" 2.2000000000000002,\n",
" 0.60000000000000009,\n",
" -2.2000000000000002,\n",
" 0.0,\n",
" -1.7000000000000002,\n",
" -1.0,\n",
" 0.0,\n",
" -1.1000000000000001,\n",
" 0.0,\n",
" 3.3000000000000003,\n",
" 2.2000000000000002,\n",
" 4.4000000000000004,\n",
" 3.3000000000000003,\n",
" 1.7000000000000002,\n",
" 3.3000000000000003,\n",
" 1.1000000000000001,\n",
" 2.8000000000000003,\n",
" 1.7000000000000002,\n",
" 6.1000000000000005,\n",
" 6.7000000000000002,\n",
" 5.0,\n",
" 2.8000000000000003,\n",
" 3.3000000000000003,\n",
" 5.0,\n",
" 2.8000000000000003,\n",
" 3.9000000000000004,\n",
" 5.6000000000000005,\n",
" 6.1000000000000005,\n",
" 6.1000000000000005,\n",
" 4.4000000000000004,\n",
" 4.4000000000000004,\n",
" 8.3000000000000007,\n",
" 5.0,\n",
" 3.9000000000000004,\n",
" 6.7000000000000002,\n",
" 7.8000000000000007,\n",
" 5.6000000000000005,\n",
" 6.1000000000000005,\n",
" 10.0,\n",
" 7.8000000000000007,\n",
" 6.1000000000000005,\n",
" 6.1000000000000005,\n",
" 4.4000000000000004,\n",
" 7.8000000000000007,\n",
" 6.7000000000000002,\n",
" 5.0,\n",
" 6.7000000000000002,\n",
" 7.8000000000000007,\n",
" 5.0,\n",
" 9.4000000000000004,\n",
" 9.4000000000000004,\n",
" 8.9000000000000004,\n",
" 8.9000000000000004,\n",
" 3.9000000000000004,\n",
" 5.6000000000000005,\n",
" 7.2000000000000002,\n",
" 7.8000000000000007,\n",
" 8.3000000000000007,\n",
" 7.2000000000000002,\n",
" 7.2000000000000002,\n",
" 8.3000000000000007,\n",
" 5.0,\n",
" 7.2000000000000002,\n",
" 8.9000000000000004,\n",
" 8.9000000000000004,\n",
" 6.1000000000000005,\n",
" 8.9000000000000004,\n",
" 10.0,\n",
" 6.1000000000000005,\n",
" 5.0,\n",
" 4.4000000000000004,\n",
" 6.7000000000000002,\n",
" 7.2000000000000002,\n",
" 7.8000000000000007,\n",
" 8.3000000000000007,\n",
" 7.2000000000000002,\n",
" 7.2000000000000002,\n",
" 6.7000000000000002,\n",
" 8.9000000000000004,\n",
" 8.9000000000000004,\n",
" 8.3000000000000007,\n",
" 6.7000000000000002,\n",
" 8.9000000000000004,\n",
" 6.7000000000000002,\n",
" 7.8000000000000007,\n",
" 5.0,\n",
" 3.9000000000000004,\n",
" 5.6000000000000005,\n",
" 7.2000000000000002,\n",
" 4.4000000000000004,\n",
" 7.2000000000000002,\n",
" 6.1000000000000005,\n",
" 6.1000000000000005,\n",
" 7.8000000000000007,\n",
" 3.9000000000000004,\n",
" 7.2000000000000002,\n",
" 5.0,\n",
" 6.7000000000000002,\n",
" 5.0,\n",
" 6.7000000000000002,\n",
" 7.8000000000000007,\n",
" 6.7000000000000002,\n",
" 3.3000000000000003,\n",
" 4.4000000000000004,\n",
" 5.6000000000000005,\n",
" 6.7000000000000002,\n",
" 6.7000000000000002,\n",
" 2.8000000000000003,\n",
" 4.4000000000000004,\n",
" 4.4000000000000004,\n",
" 3.9000000000000004,\n",
" 5.0,\n",
" 2.2000000000000002,\n",
" 4.4000000000000004,\n",
" 3.9000000000000004,\n",
" 1.7000000000000002,\n",
" -0.60000000000000009,\n",
" 0.60000000000000009,\n",
" -1.0,\n",
" -0.60000000000000009,\n",
" 1.1000000000000001,\n",
" -1.0,\n",
" 1.1000000000000001,\n",
" -0.5,\n",
" 0.0,\n",
" 1.1000000000000001,\n",
" -2.1000000000000001,\n",
" 0.0,\n",
" 0.60000000000000009,\n",
" 3.3000000000000003,\n",
" 0.60000000000000009,\n",
" -2.1000000000000001,\n",
" -1.1000000000000001,\n",
" -3.2000000000000002,\n",
" -1.7000000000000002,\n",
" -0.60000000000000009,\n",
" -2.7000000000000002,\n",
" -2.2000000000000002,\n",
" -1.1000000000000001,\n",
" -0.60000000000000009,\n",
" -6.1000000000000005,\n",
" -5.6000000000000005,\n",
" -4.4000000000000004,\n",
" -6.1000000000000005,\n",
" -3.3000000000000003,\n",
" -5.6000000000000005,\n",
" -4.4000000000000004,\n",
" -6.1000000000000005,\n",
" -3.3000000000000003,\n",
" -4.4000000000000004,\n",
" -4.9000000000000004,\n",
" -4.2999999999999998,\n",
" -2.7000000000000002,\n",
" -3.2000000000000002,\n",
" -5.6000000000000005,\n",
" -5.6000000000000005,\n",
" -5.0,\n",
" -5.0,\n",
" -5.0,\n",
" -6.1000000000000005,\n",
" -5.0,\n",
" -7.2000000000000002,\n",
" -8.2000000000000011,\n",
" -6.1000000000000005,\n",
" -7.1000000000000005,\n",
" -9.9000000000000004,\n",
" -8.9000000000000004,\n",
" -9.3000000000000007,\n",
" -7.8000000000000007,\n",
" -7.8000000000000007,\n",
" -6.7000000000000002,\n",
" -8.2000000000000011,\n",
" -6.1000000000000005,\n",
" -3.9000000000000004,\n",
" -7.7000000000000002,\n",
" -9.4000000000000004,\n",
" -11.100000000000001,\n",
" -9.4000000000000004,\n",
" -9.4000000000000004,\n",
" -7.8000000000000007,\n",
" -12.200000000000001,\n",
" -14.4,\n",
" -12.800000000000001,\n",
" -12.200000000000001,\n",
" -18.199999999999999,\n",
" -17.199999999999999,\n",
" -13.800000000000001,\n",
" -15.0,\n",
" -15.600000000000001,\n",
" -12.200000000000001,\n",
" -11.100000000000001,\n",
" -13.300000000000001,\n",
" -12.100000000000001,\n",
" -10.600000000000001,\n",
" -13.200000000000001,\n",
" -13.300000000000001,\n",
" -10.0,\n",
" -12.200000000000001,\n",
" -15.5,\n",
" -18.300000000000001,\n",
" -19.400000000000002,\n",
" -20.0,\n",
" -18.900000000000002,\n",
" -17.199999999999999,\n",
" -16.699999999999999,\n",
" -21.0,\n",
" -17.800000000000001,\n",
" -16.100000000000001,\n",
" -16.600000000000001,\n",
" -22.800000000000001,\n",
" -22.200000000000003,\n",
" -19.400000000000002,\n",
" -16.100000000000001,\n",
" -16.699999999999999,\n",
" -19.400000000000002,\n",
" -20.0,\n",
" -20.0,\n",
" -16.699999999999999,\n",
" -16.699999999999999,\n",
" -15.600000000000001,\n",
" -13.800000000000001,\n",
" -16.600000000000001,\n",
" -15.0,\n",
" -14.4,\n",
" -15.0]"
]
},
"execution_count": 22,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"low_14=[]\n",
"for x in list(df_early.xs('TMIN',level='Element').xs('min',level=1,axis=1).values):\n",
" low_14.extend(x)\n",
"low_14"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"date = list(df_early.index.levels[0])"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### 2015"
]
},
{
"cell_type": "code",
"execution_count": 24,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr>\n",
" <th></th>\n",
" <th></th>\n",
" <th colspan=\"2\" halign=\"left\">Data_Value</th>\n",
" </tr>\n",
" <tr>\n",
" <th></th>\n",
" <th></th>\n",
" <th>min</th>\n",
" <th>max</th>\n",
" </tr>\n",
" <tr>\n",
" <th>Date</th>\n",
" <th>Element</th>\n",
" <th></th>\n",
" <th></th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th rowspan=\"2\" valign=\"top\">01-01</th>\n",
" <th>TMAX</th>\n",
" <td>-6.7</td>\n",
" <td>1.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>TMIN</th>\n",
" <td>-13.3</td>\n",
" <td>-7.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th rowspan=\"2\" valign=\"top\">01-02</th>\n",
" <th>TMAX</th>\n",
" <td>-2.2</td>\n",
" <td>3.9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>TMIN</th>\n",
" <td>-12.2</td>\n",
" <td>-2.8</td>\n",
" </tr>\n",
" <tr>\n",
" <th>01-03</th>\n",
" <th>TMAX</th>\n",
" <td>0.0</td>\n",
" <td>3.9</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Data_Value \n",
" min max\n",
"Date Element \n",
"01-01 TMAX -6.7 1.1\n",
" TMIN -13.3 -7.1\n",
"01-02 TMAX -2.2 3.9\n",
" TMIN -12.2 -2.8\n",
"01-03 TMAX 0.0 3.9"
]
},
"execution_count": 24,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"gb_15 = df_15.groupby(['Date','Element'])\n",
"df_late = gb_15.agg({'Data_Value' : [min, max]})\n",
"df_late.head()"
]
},
{
"cell_type": "code",
"execution_count": 25,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"[1.1000000000000001,\n",
" 3.9000000000000004,\n",
" 3.9000000000000004,\n",
" 4.4000000000000004,\n",
" 2.8000000000000003,\n",
" 3.3000000000000003,\n",
" -6.7000000000000002,\n",
" -8.2000000000000011,\n",
" -6.6000000000000005,\n",
" -7.1000000000000005,\n",
" 0.60000000000000009,\n",
" 0.60000000000000009,\n",
" 0.0,\n",
" -5.6000000000000005,\n",
" -0.5,\n",
" 0.60000000000000009,\n",
" 7.8000000000000007,\n",
" 8.3000000000000007,\n",
" 6.7000000000000002,\n",
" 3.9000000000000004,\n",
" 2.2000000000000002,\n",
" -0.5,\n",
" 1.1000000000000001,\n",
" 4.4000000000000004,\n",
" 3.3000000000000003,\n",
" 2.8000000000000003,\n",
" -0.5,\n",
" 0.60000000000000009,\n",
" 3.9000000000000004,\n",
" 2.8000000000000003,\n",
" 2.8000000000000003,\n",
" 3.9000000000000004,\n",
" -2.2000000000000002,\n",
" -2.1000000000000001,\n",
" 1.1000000000000001,\n",
" 1.1000000000000001,\n",
" 0.0,\n",
" 5.6000000000000005,\n",
" 8.3000000000000007,\n",
" 8.3000000000000007,\n",
" 0.0,\n",
" 3.3000000000000003,\n",
" 1.1000000000000001,\n",
" -3.2000000000000002,\n",
" -2.7000000000000002,\n",
" -3.9000000000000004,\n",
" -12.100000000000001,\n",
" -5.5,\n",
" -3.9000000000000004,\n",
" -5.6000000000000005,\n",
" -8.8000000000000007,\n",
" -1.0,\n",
" 0.0,\n",
" 2.2000000000000002,\n",
" -3.8000000000000003,\n",
" -3.8000000000000003,\n",
" -3.3000000000000003,\n",
" -5.0,\n",
" -3.9000000000000004,\n",
" -1.7000000000000002,\n",
" 1.7000000000000002,\n",
" 4.4000000000000004,\n",
" 3.3000000000000003,\n",
" 3.9000000000000004,\n",
" -3.9000000000000004,\n",
" 7.8000000000000007,\n",
" 8.3000000000000007,\n",
" 9.4000000000000004,\n",
" 10.0,\n",
" 13.300000000000001,\n",
" 12.800000000000001,\n",
" 15.0,\n",
" 12.800000000000001,\n",
" 13.9,\n",
" 20.600000000000001,\n",
" 19.400000000000002,\n",
" 11.700000000000001,\n",
" 10.600000000000001,\n",
" 11.700000000000001,\n",
" 12.800000000000001,\n",
" 11.700000000000001,\n",
" 11.100000000000001,\n",
" 7.2000000000000002,\n",
" 12.800000000000001,\n",
" 11.100000000000001,\n",
" 12.800000000000001,\n",
" 4.4000000000000004,\n",
" 8.9000000000000004,\n",
" 16.699999999999999,\n",
" 15.0,\n",
" 20.600000000000001,\n",
" 19.400000000000002,\n",
" 17.199999999999999,\n",
" 15.600000000000001,\n",
" 19.400000000000002,\n",
" 18.300000000000001,\n",
" 17.199999999999999,\n",
" 16.699999999999999,\n",
" 21.100000000000001,\n",
" 21.700000000000003,\n",
" 18.900000000000002,\n",
" 21.100000000000001,\n",
" 24.400000000000002,\n",
" 23.900000000000002,\n",
" 20.0,\n",
" 18.900000000000002,\n",
" 27.800000000000001,\n",
" 26.700000000000003,\n",
" 25.600000000000001,\n",
" 19.400000000000002,\n",
" 19.400000000000002,\n",
" 12.800000000000001,\n",
" 7.8000000000000007,\n",
" 16.699999999999999,\n",
" 16.100000000000001,\n",
" 16.699999999999999,\n",
" 16.100000000000001,\n",
" 20.0,\n",
" 21.100000000000001,\n",
" 20.0,\n",
" 25.600000000000001,\n",
" 26.700000000000003,\n",
" 28.900000000000002,\n",
" 26.700000000000003,\n",
" 25.600000000000001,\n",
" 24.400000000000002,\n",
" 30.600000000000001,\n",
" 33.300000000000004,\n",
" 31.100000000000001,\n",
" 29.400000000000002,\n",
" 30.600000000000001,\n",
" 30.0,\n",
" 17.800000000000001,\n",
" 18.900000000000002,\n",
" 26.700000000000003,\n",
" 27.200000000000003,\n",
" 30.0,\n",
" 31.700000000000003,\n",
" 28.900000000000002,\n",
" 17.199999999999999,\n",
" 20.0,\n",
" 21.700000000000003,\n",
" 26.700000000000003,\n",
" 28.300000000000001,\n",
" 30.600000000000001,\n",
" 31.700000000000003,\n",
" 30.0,\n",
" 26.700000000000003,\n",
" 30.0,\n",
" 30.0,\n",
" 28.900000000000002,\n",
" 20.0,\n",
" 23.900000000000002,\n",
" 26.100000000000001,\n",
" 28.900000000000002,\n",
" 28.900000000000002,\n",
" 28.300000000000001,\n",
" 28.900000000000002,\n",
" 28.300000000000001,\n",
" 28.900000000000002,\n",
" 33.899999999999999,\n",
" 32.200000000000003,\n",
" 28.900000000000002,\n",
" 28.300000000000001,\n",
" 30.600000000000001,\n",
" 30.600000000000001,\n",
" 30.0,\n",
" 30.0,\n",
" 30.0,\n",
" 29.400000000000002,\n",
" 26.100000000000001,\n",
" 30.600000000000001,\n",
" 30.600000000000001,\n",
" 29.400000000000002,\n",
" 28.300000000000001,\n",
" 27.200000000000003,\n",
" 26.100000000000001,\n",
" 25.0,\n",
" 26.700000000000003,\n",
" 26.700000000000003,\n",
" 26.100000000000001,\n",
" 25.600000000000001,\n",
" 26.100000000000001,\n",
" 26.700000000000003,\n",
" 28.900000000000002,\n",
" 29.400000000000002,\n",
" 30.600000000000001,\n",
" 30.600000000000001,\n",
" 28.300000000000001,\n",
" 25.600000000000001,\n",
" 28.300000000000001,\n",
" 29.400000000000002,\n",
" 28.300000000000001,\n",
" 28.300000000000001,\n",
" 28.300000000000001,\n",
" 27.200000000000003,\n",
" 27.200000000000003,\n",
" 32.200000000000003,\n",
" 33.300000000000004,\n",
" 33.300000000000004,\n",
" 32.200000000000003,\n",
" 30.0,\n",
" 28.900000000000002,\n",
" 31.100000000000001,\n",
" 32.800000000000004,\n",
" 33.300000000000004,\n",
" 32.800000000000004,\n",
" 33.899999999999999,\n",
" 35.0,\n",
" 36.100000000000001,\n",
" 33.300000000000004,\n",
" 32.800000000000004,\n",
" 31.100000000000001,\n",
" 35.600000000000001,\n",
" 32.800000000000004,\n",
" 32.200000000000003,\n",
" 32.200000000000003,\n",
" 27.800000000000001,\n",
" 28.900000000000002,\n",
" 27.800000000000001,\n",
" 29.400000000000002,\n",
" 28.900000000000002,\n",
" 28.900000000000002,\n",
" 29.400000000000002,\n",
" 30.600000000000001,\n",
" 31.700000000000003,\n",
" 31.100000000000001,\n",
" 32.800000000000004,\n",
" 32.800000000000004,\n",
" 31.700000000000003,\n",
" 32.800000000000004,\n",
" 30.600000000000001,\n",
" 27.200000000000003,\n",
" 28.300000000000001,\n",
" 29.400000000000002,\n",
" 28.300000000000001,\n",
" 24.400000000000002,\n",
" 21.100000000000001,\n",
" 23.300000000000001,\n",
" 26.100000000000001,\n",
" 27.200000000000003,\n",
" 30.600000000000001,\n",
" 31.100000000000001,\n",
" 33.300000000000004,\n",
" 33.899999999999999,\n",
" 33.899999999999999,\n",
" 33.300000000000004,\n",
" 31.700000000000003,\n",
" 33.300000000000004,\n",
" 35.0,\n",
" 33.899999999999999,\n",
" 32.800000000000004,\n",
" 28.300000000000001,\n",
" 27.800000000000001,\n",
" 26.100000000000001,\n",
" 22.200000000000003,\n",
" 27.800000000000001,\n",
" 30.0,\n",
" 31.100000000000001,\n",
" 31.700000000000003,\n",
" 30.0,\n",
" 28.300000000000001,\n",
" 27.800000000000001,\n",
" 25.0,\n",
" 27.800000000000001,\n",
" 28.300000000000001,\n",
" 29.400000000000002,\n",
" 29.400000000000002,\n",
" 27.800000000000001,\n",
" 27.800000000000001,\n",
" 29.400000000000002,\n",
" 28.300000000000001,\n",
" 25.600000000000001,\n",
" 21.700000000000003,\n",
" 18.900000000000002,\n",
" 17.199999999999999,\n",
" 18.300000000000001,\n",
" 25.0,\n",
" 22.800000000000001,\n",
" 26.100000000000001,\n",
" 26.100000000000001,\n",
" 26.100000000000001,\n",
" 20.600000000000001,\n",
" 26.100000000000001,\n",
" 27.200000000000003,\n",
" 25.600000000000001,\n",
" 18.900000000000002,\n",
" 20.600000000000001,\n",
" 18.900000000000002,\n",
" 14.4,\n",
" 13.300000000000001,\n",
" 21.700000000000003,\n",
" 27.200000000000003,\n",
" 25.600000000000001,\n",
" 25.0,\n",
" 21.700000000000003,\n",
" 22.800000000000001,\n",
" 21.100000000000001,\n",
" 20.600000000000001,\n",
" 20.600000000000001,\n",
" 20.600000000000001,\n",
" 20.600000000000001,\n",
" 20.600000000000001,\n",
" 12.800000000000001,\n",
" 20.600000000000001,\n",
" 22.800000000000001,\n",
" 26.100000000000001,\n",
" 26.100000000000001,\n",
" 25.600000000000001,\n",
" 23.900000000000002,\n",
" 22.200000000000003,\n",
" 15.600000000000001,\n",
" 15.0,\n",
" 15.0,\n",
" 15.600000000000001,\n",
" 15.0,\n",
" 13.9,\n",
" 12.200000000000001,\n",
" 20.0,\n",
" 19.400000000000002,\n",
" 18.900000000000002,\n",
" 20.0,\n",
" 17.800000000000001,\n",
" 15.0,\n",
" 11.100000000000001,\n",
" 2.2000000000000002,\n",
" 2.8000000000000003,\n",
" 8.3000000000000007,\n",
" 15.600000000000001,\n",
" 17.800000000000001,\n",
" 17.199999999999999,\n",
" 12.800000000000001,\n",
" 12.200000000000001,\n",
" 10.0,\n",
" 11.100000000000001,\n",
" 10.0,\n",
" 9.4000000000000004,\n",
" 9.4000000000000004,\n",
" 9.4000000000000004,\n",
" 10.0,\n",
" 10.0,\n",
" 10.0,\n",
" 12.200000000000001,\n",
" 15.0,\n",
" 15.600000000000001,\n",
" 20.0,\n",
" 19.400000000000002,\n",
" 18.300000000000001,\n",
" 16.100000000000001,\n",
" 15.0,\n",
" 12.200000000000001,\n",
" 3.3000000000000003,\n",
" 1.1000000000000001,\n",
" 8.3000000000000007,\n",
" 12.200000000000001,\n",
" 13.300000000000001,\n",
" 18.300000000000001,\n",
" 17.199999999999999,\n",
" 11.100000000000001,\n",
" 11.700000000000001,\n",
" 8.3000000000000007,\n",
" 6.1000000000000005,\n",
" 10.0,\n",
" 6.7000000000000002,\n",
" 1.7000000000000002]"
]
},
"execution_count": 25,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"high_15=[]\n",
"for x in list(df_late.xs('TMAX',level='Element').xs('max',level=1,axis=1).values):\n",
" high_15.extend(x)\n",
"high_15"
]
},
{
"cell_type": "code",
"execution_count": 26,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"[-13.300000000000001,\n",
" -12.200000000000001,\n",
" -6.7000000000000002,\n",
" -8.8000000000000007,\n",
" -15.5,\n",
" -18.199999999999999,\n",
" -18.199999999999999,\n",
" -21.100000000000001,\n",
" -20.600000000000001,\n",
" -20.600000000000001,\n",
" -20.0,\n",
" -11.700000000000001,\n",
" -21.600000000000001,\n",
" -24.400000000000002,\n",
" -20.0,\n",
" -16.699999999999999,\n",
" -11.700000000000001,\n",
" -10.0,\n",
" -1.7000000000000002,\n",
" -3.3000000000000003,\n",
" -6.1000000000000005,\n",
" -6.7000000000000002,\n",
" -10.0,\n",
" -6.1000000000000005,\n",
" -8.8000000000000007,\n",
" -15.0,\n",
" -16.100000000000001,\n",
" -17.199999999999999,\n",
" -16.699999999999999,\n",
" -14.300000000000001,\n",
" -15.600000000000001,\n",
" -12.200000000000001,\n",
" -19.300000000000001,\n",
" -23.800000000000001,\n",
" -21.100000000000001,\n",
" -27.700000000000003,\n",
" -25.0,\n",
" -12.200000000000001,\n",
" -5.6000000000000005,\n",
" -11.600000000000001,\n",
" -17.100000000000001,\n",
" -15.0,\n",
" -21.100000000000001,\n",
" -26.600000000000001,\n",
" -23.900000000000002,\n",
" -26.0,\n",
" -29.400000000000002,\n",
" -27.200000000000003,\n",
" -21.700000000000003,\n",
" -26.0,\n",
" -34.300000000000004,\n",
" -32.200000000000003,\n",
" -16.0,\n",
" -26.700000000000003,\n",
" -27.200000000000003,\n",
" -21.700000000000003,\n",
" -21.600000000000001,\n",
" -28.800000000000001,\n",
" -27.200000000000003,\n",
" -24.400000000000002,\n",
" -14.4,\n",
" -12.200000000000001,\n",
" -12.200000000000001,\n",
" -22.100000000000001,\n",
" -25.5,\n",
" -22.200000000000003,\n",
" -10.600000000000001,\n",
" -8.9000000000000004,\n",
" -6.7000000000000002,\n",
" -3.8000000000000003,\n",
" -6.7000000000000002,\n",
" -5.0,\n",
" -3.3000000000000003,\n",
" -2.2000000000000002,\n",
" -6.7000000000000002,\n",
" -5.5,\n",
" -7.8000000000000007,\n",
" -6.7000000000000002,\n",
" -5.0,\n",
" -2.2000000000000002,\n",
" -7.2000000000000002,\n",
" -9.4000000000000004,\n",
" -11.100000000000001,\n",
" -11.100000000000001,\n",
" -2.8000000000000003,\n",
" -11.700000000000001,\n",
" -12.200000000000001,\n",
" -11.100000000000001,\n",
" -12.200000000000001,\n",
" -6.7000000000000002,\n",
" -4.2999999999999998,\n",
" -3.3000000000000003,\n",
" -0.5,\n",
" -5.6000000000000005,\n",
" -5.6000000000000005,\n",
" -2.2000000000000002,\n",
" -1.7000000000000002,\n",
" 1.1000000000000001,\n",
" 1.7000000000000002,\n",
" 1.7000000000000002,\n",
" -1.6000000000000001,\n",
" -2.1000000000000001,\n",
" -0.60000000000000009,\n",
" 0.60000000000000009,\n",
" -1.0,\n",
" 0.0,\n",
" 4.4000000000000004,\n",
" 4.4000000000000004,\n",
" 4.4000000000000004,\n",
" 3.3000000000000003,\n",
" 2.2000000000000002,\n",
" 0.0,\n",
" -4.2999999999999998,\n",
" -7.1000000000000005,\n",
" -5.0,\n",
" -2.2000000000000002,\n",
" -2.1000000000000001,\n",
" -3.2000000000000002,\n",
" -1.1000000000000001,\n",
" 2.2000000000000002,\n",
" 4.4000000000000004,\n",
" 4.4000000000000004,\n",
" 4.4000000000000004,\n",
" 7.2000000000000002,\n",
" 8.3000000000000007,\n",
" 8.3000000000000007,\n",
" 8.3000000000000007,\n",
" 8.9000000000000004,\n",
" 10.600000000000001,\n",
" 13.9,\n",
" 13.300000000000001,\n",
" 8.3000000000000007,\n",
" 2.8000000000000003,\n",
" 0.60000000000000009,\n",
" 2.2000000000000002,\n",
" 8.3000000000000007,\n",
" 13.300000000000001,\n",
" 12.800000000000001,\n",
" 2.8000000000000003,\n",
" 0.0,\n",
" 3.3000000000000003,\n",
" 1.1000000000000001,\n",
" 0.0,\n",
" 4.4000000000000004,\n",
" 10.0,\n",
" 8.9000000000000004,\n",
" 14.4,\n",
" 8.3000000000000007,\n",
" 11.700000000000001,\n",
" 10.0,\n",
" 7.8000000000000007,\n",
" 5.0,\n",
" 3.3000000000000003,\n",
" 4.4000000000000004,\n",
" 5.6000000000000005,\n",
" 8.3000000000000007,\n",
" 10.0,\n",
" 5.6000000000000005,\n",
" 8.3000000000000007,\n",
" 12.800000000000001,\n",
" 13.9,\n",
" 13.9,\n",
" 13.9,\n",
" 12.200000000000001,\n",
" 13.300000000000001,\n",
" 17.199999999999999,\n",
" 16.699999999999999,\n",
" 13.9,\n",
" 13.9,\n",
" 13.300000000000001,\n",
" 10.600000000000001,\n",
" 10.600000000000001,\n",
" 13.300000000000001,\n",
" 11.700000000000001,\n",
" 10.0,\n",
" 11.100000000000001,\n",
" 11.700000000000001,\n",
" 11.100000000000001,\n",
" 10.600000000000001,\n",
" 11.700000000000001,\n",
" 12.200000000000001,\n",
" 11.700000000000001,\n",
" 9.4000000000000004,\n",
" 7.2000000000000002,\n",
" 7.8000000000000007,\n",
" 10.600000000000001,\n",
" 10.0,\n",
" 12.200000000000001,\n",
" 11.100000000000001,\n",
" 12.200000000000001,\n",
" 10.0,\n",
" 10.600000000000001,\n",
" 14.4,\n",
" 10.0,\n",
" 14.4,\n",
" 11.100000000000001,\n",
" 8.3000000000000007,\n",
" 10.0,\n",
" 17.199999999999999,\n",
" 15.600000000000001,\n",
" 12.200000000000001,\n",
" 11.700000000000001,\n",
" 10.600000000000001,\n",
" 11.100000000000001,\n",
" 12.800000000000001,\n",
" 13.300000000000001,\n",
" 16.699999999999999,\n",
" 12.800000000000001,\n",
" 13.9,\n",
" 12.800000000000001,\n",
" 13.300000000000001,\n",
" 13.9,\n",
" 13.300000000000001,\n",
" 12.200000000000001,\n",
" 8.9000000000000004,\n",
" 8.3000000000000007,\n",
" 8.3000000000000007,\n",
" 11.100000000000001,\n",
" 10.0,\n",
" 10.0,\n",
" 13.300000000000001,\n",
" 16.699999999999999,\n",
" 15.0,\n",
" 12.200000000000001,\n",
" 11.100000000000001,\n",
" 12.800000000000001,\n",
" 15.0,\n",
" 14.4,\n",
" 16.100000000000001,\n",
" 16.699999999999999,\n",
" 17.199999999999999,\n",
" 13.9,\n",
" 9.4000000000000004,\n",
" 10.0,\n",
" 10.0,\n",
" 8.9000000000000004,\n",
" 10.600000000000001,\n",
" 10.600000000000001,\n",
" 7.2000000000000002,\n",
" 5.6000000000000005,\n",
" 7.8000000000000007,\n",
" 7.2000000000000002,\n",
" 14.4,\n",
" 13.9,\n",
" 15.600000000000001,\n",
" 17.199999999999999,\n",
" 16.100000000000001,\n",
" 16.699999999999999,\n",
" 15.0,\n",
" 15.600000000000001,\n",
" 17.800000000000001,\n",
" 11.100000000000001,\n",
" 7.2000000000000002,\n",
" 8.3000000000000007,\n",
" 4.4000000000000004,\n",
" 3.3000000000000003,\n",
" 1.7000000000000002,\n",
" 5.6000000000000005,\n",
" 6.7000000000000002,\n",
" 7.8000000000000007,\n",
" 10.600000000000001,\n",
" 9.4000000000000004,\n",
" 3.9000000000000004,\n",
" 5.6000000000000005,\n",
" 1.7000000000000002,\n",
" 5.6000000000000005,\n",
" 5.6000000000000005,\n",
" 7.8000000000000007,\n",
" 11.100000000000001,\n",
" 10.600000000000001,\n",
" 11.700000000000001,\n",
" 11.100000000000001,\n",
" 6.1000000000000005,\n",
" 4.4000000000000004,\n",
" 5.0,\n",
" 4.4000000000000004,\n",
" 6.1000000000000005,\n",
" 9.4000000000000004,\n",
" 9.4000000000000004,\n",
" 6.7000000000000002,\n",
" 5.0,\n",
" 2.8000000000000003,\n",
" 0.0,\n",
" 2.8000000000000003,\n",
" 2.8000000000000003,\n",
" 7.2000000000000002,\n",
" -1.0,\n",
" -1.6000000000000001,\n",
" -1.0,\n",
" -5.5,\n",
" -5.5,\n",
" -6.1000000000000005,\n",
" -3.9000000000000004,\n",
" -2.8000000000000003,\n",
" 1.1000000000000001,\n",
" 1.7000000000000002,\n",
" 2.2000000000000002,\n",
" 2.8000000000000003,\n",
" -1.0,\n",
" -1.1000000000000001,\n",
" 2.2000000000000002,\n",
" 0.60000000000000009,\n",
" -6.1000000000000005,\n",
" 0.60000000000000009,\n",
" 0.60000000000000009,\n",
" -1.0,\n",
" 1.1000000000000001,\n",
" 3.3000000000000003,\n",
" 3.9000000000000004,\n",
" 7.8000000000000007,\n",
" -0.5,\n",
" -5.5,\n",
" -6.1000000000000005,\n",
" -4.4000000000000004,\n",
" -3.3000000000000003,\n",
" -1.7000000000000002,\n",
" 0.0,\n",
" -2.8000000000000003,\n",
" -2.2000000000000002,\n",
" -3.2000000000000002,\n",
" -2.2000000000000002,\n",
" 2.8000000000000003,\n",
" 2.2000000000000002,\n",
" -1.7000000000000002,\n",
" -3.3000000000000003,\n",
" -11.600000000000001,\n",
" -11.100000000000001,\n",
" -11.0,\n",
" -9.4000000000000004,\n",
" -8.9000000000000004,\n",
" 0.60000000000000009,\n",
" -3.9000000000000004,\n",
" -9.3000000000000007,\n",
" -8.9000000000000004,\n",
" -2.8000000000000003,\n",
" -6.1000000000000005,\n",
" -7.8000000000000007,\n",
" -4.2999999999999998,\n",
" -5.0,\n",
" -5.6000000000000005,\n",
" -6.7000000000000002,\n",
" -6.7000000000000002,\n",
" -3.3000000000000003,\n",
" -4.4000000000000004,\n",
" 0.0,\n",
" 2.8000000000000003,\n",
" 6.7000000000000002,\n",
" 6.1000000000000005,\n",
" 3.9000000000000004,\n",
" 0.60000000000000009,\n",
" -1.1000000000000001,\n",
" -5.0,\n",
" -6.7000000000000002,\n",
" -9.4000000000000004,\n",
" -8.3000000000000007,\n",
" 0.60000000000000009,\n",
" 0.0,\n",
" 0.0,\n",
" -3.2000000000000002,\n",
" -3.9000000000000004,\n",
" -0.60000000000000009,\n",
" -3.9000000000000004,\n",
" -3.9000000000000004,\n",
" -2.2000000000000002,\n",
" -5.6000000000000005]"
]
},
"execution_count": 26,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"low_15=[]\n",
"for x in list(df_late.xs('TMIN',level='Element').xs('min',level=1,axis=1).values):\n",
" low_15.extend(x)\n",
"low_15"
]
},
{
"cell_type": "code",
"execution_count": 27,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"%matplotlib notebook"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"import numpy as np\n",
"import datetime as dt\n",
"import seaborn as sns\n",
"import matplotlib.dates as mdates"
]
},
{
"cell_type": "code",
"execution_count": 29,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"sns.set_color_codes()"
]
},
{
"cell_type": "code",
"execution_count": 30,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"sns.set_style('whitegrid')"
]
},
{
"cell_type": "code",
"execution_count": 31,
"metadata": {
"collapsed": false,
"scrolled": true
},
"outputs": [],
"source": [
"date_1=[dt.datetime.strptime(d,'%m-%d').date() for d in date]"
]
},
{
"cell_type": "code",
"execution_count": 32,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"[datetime.date(1900, 1, 1),\n",
" datetime.date(1900, 1, 2),\n",
" datetime.date(1900, 1, 3),\n",
" datetime.date(1900, 1, 4),\n",
" datetime.date(1900, 1, 5),\n",
" datetime.date(1900, 1, 6),\n",
" datetime.date(1900, 1, 7),\n",
" datetime.date(1900, 1, 8),\n",
" datetime.date(1900, 1, 9),\n",
" datetime.date(1900, 1, 10),\n",
" datetime.date(1900, 1, 11),\n",
" datetime.date(1900, 1, 12),\n",
" datetime.date(1900, 1, 13),\n",
" datetime.date(1900, 1, 14),\n",
" datetime.date(1900, 1, 15),\n",
" datetime.date(1900, 1, 16),\n",
" datetime.date(1900, 1, 17),\n",
" datetime.date(1900, 1, 18),\n",
" datetime.date(1900, 1, 19),\n",
" datetime.date(1900, 1, 20),\n",
" datetime.date(1900, 1, 21),\n",
" datetime.date(1900, 1, 22),\n",
" datetime.date(1900, 1, 23),\n",
" datetime.date(1900, 1, 24),\n",
" datetime.date(1900, 1, 25),\n",
" datetime.date(1900, 1, 26),\n",
" datetime.date(1900, 1, 27),\n",
" datetime.date(1900, 1, 28),\n",
" datetime.date(1900, 1, 29),\n",
" datetime.date(1900, 1, 30),\n",
" datetime.date(1900, 1, 31),\n",
" datetime.date(1900, 2, 1),\n",
" datetime.date(1900, 2, 2),\n",
" datetime.date(1900, 2, 3),\n",
" datetime.date(1900, 2, 4),\n",
" datetime.date(1900, 2, 5),\n",
" datetime.date(1900, 2, 6),\n",
" datetime.date(1900, 2, 7),\n",
" datetime.date(1900, 2, 8),\n",
" datetime.date(1900, 2, 9),\n",
" datetime.date(1900, 2, 10),\n",
" datetime.date(1900, 2, 11),\n",
" datetime.date(1900, 2, 12),\n",
" datetime.date(1900, 2, 13),\n",
" datetime.date(1900, 2, 14),\n",
" datetime.date(1900, 2, 15),\n",
" datetime.date(1900, 2, 16),\n",
" datetime.date(1900, 2, 17),\n",
" datetime.date(1900, 2, 18),\n",
" datetime.date(1900, 2, 19),\n",
" datetime.date(1900, 2, 20),\n",
" datetime.date(1900, 2, 21),\n",
" datetime.date(1900, 2, 22),\n",
" datetime.date(1900, 2, 23),\n",
" datetime.date(1900, 2, 24),\n",
" datetime.date(1900, 2, 25),\n",
" datetime.date(1900, 2, 26),\n",
" datetime.date(1900, 2, 27),\n",
" datetime.date(1900, 2, 28),\n",
" datetime.date(1900, 3, 1),\n",
" datetime.date(1900, 3, 2),\n",
" datetime.date(1900, 3, 3),\n",
" datetime.date(1900, 3, 4),\n",
" datetime.date(1900, 3, 5),\n",
" datetime.date(1900, 3, 6),\n",
" datetime.date(1900, 3, 7),\n",
" datetime.date(1900, 3, 8),\n",
" datetime.date(1900, 3, 9),\n",
" datetime.date(1900, 3, 10),\n",
" datetime.date(1900, 3, 11),\n",
" datetime.date(1900, 3, 12),\n",
" datetime.date(1900, 3, 13),\n",
" datetime.date(1900, 3, 14),\n",
" datetime.date(1900, 3, 15),\n",
" datetime.date(1900, 3, 16),\n",
" datetime.date(1900, 3, 17),\n",
" datetime.date(1900, 3, 18),\n",
" datetime.date(1900, 3, 19),\n",
" datetime.date(1900, 3, 20),\n",
" datetime.date(1900, 3, 21),\n",
" datetime.date(1900, 3, 22),\n",
" datetime.date(1900, 3, 23),\n",
" datetime.date(1900, 3, 24),\n",
" datetime.date(1900, 3, 25),\n",
" datetime.date(1900, 3, 26),\n",
" datetime.date(1900, 3, 27),\n",
" datetime.date(1900, 3, 28),\n",
" datetime.date(1900, 3, 29),\n",
" datetime.date(1900, 3, 30),\n",
" datetime.date(1900, 3, 31),\n",
" datetime.date(1900, 4, 1),\n",
" datetime.date(1900, 4, 2),\n",
" datetime.date(1900, 4, 3),\n",
" datetime.date(1900, 4, 4),\n",
" datetime.date(1900, 4, 5),\n",
" datetime.date(1900, 4, 6),\n",
" datetime.date(1900, 4, 7),\n",
" datetime.date(1900, 4, 8),\n",
" datetime.date(1900, 4, 9),\n",
" datetime.date(1900, 4, 10),\n",
" datetime.date(1900, 4, 11),\n",
" datetime.date(1900, 4, 12),\n",
" datetime.date(1900, 4, 13),\n",
" datetime.date(1900, 4, 14),\n",
" datetime.date(1900, 4, 15),\n",
" datetime.date(1900, 4, 16),\n",
" datetime.date(1900, 4, 17),\n",
" datetime.date(1900, 4, 18),\n",
" datetime.date(1900, 4, 19),\n",
" datetime.date(1900, 4, 20),\n",
" datetime.date(1900, 4, 21),\n",
" datetime.date(1900, 4, 22),\n",
" datetime.date(1900, 4, 23),\n",
" datetime.date(1900, 4, 24),\n",
" datetime.date(1900, 4, 25),\n",
" datetime.date(1900, 4, 26),\n",
" datetime.date(1900, 4, 27),\n",
" datetime.date(1900, 4, 28),\n",
" datetime.date(1900, 4, 29),\n",
" datetime.date(1900, 4, 30),\n",
" datetime.date(1900, 5, 1),\n",
" datetime.date(1900, 5, 2),\n",
" datetime.date(1900, 5, 3),\n",
" datetime.date(1900, 5, 4),\n",
" datetime.date(1900, 5, 5),\n",
" datetime.date(1900, 5, 6),\n",
" datetime.date(1900, 5, 7),\n",
" datetime.date(1900, 5, 8),\n",
" datetime.date(1900, 5, 9),\n",
" datetime.date(1900, 5, 10),\n",
" datetime.date(1900, 5, 11),\n",
" datetime.date(1900, 5, 12),\n",
" datetime.date(1900, 5, 13),\n",
" datetime.date(1900, 5, 14),\n",
" datetime.date(1900, 5, 15),\n",
" datetime.date(1900, 5, 16),\n",
" datetime.date(1900, 5, 17),\n",
" datetime.date(1900, 5, 18),\n",
" datetime.date(1900, 5, 19),\n",
" datetime.date(1900, 5, 20),\n",
" datetime.date(1900, 5, 21),\n",
" datetime.date(1900, 5, 22),\n",
" datetime.date(1900, 5, 23),\n",
" datetime.date(1900, 5, 24),\n",
" datetime.date(1900, 5, 25),\n",
" datetime.date(1900, 5, 26),\n",
" datetime.date(1900, 5, 27),\n",
" datetime.date(1900, 5, 28),\n",
" datetime.date(1900, 5, 29),\n",
" datetime.date(1900, 5, 30),\n",
" datetime.date(1900, 5, 31),\n",
" datetime.date(1900, 6, 1),\n",
" datetime.date(1900, 6, 2),\n",
" datetime.date(1900, 6, 3),\n",
" datetime.date(1900, 6, 4),\n",
" datetime.date(1900, 6, 5),\n",
" datetime.date(1900, 6, 6),\n",
" datetime.date(1900, 6, 7),\n",
" datetime.date(1900, 6, 8),\n",
" datetime.date(1900, 6, 9),\n",
" datetime.date(1900, 6, 10),\n",
" datetime.date(1900, 6, 11),\n",
" datetime.date(1900, 6, 12),\n",
" datetime.date(1900, 6, 13),\n",
" datetime.date(1900, 6, 14),\n",
" datetime.date(1900, 6, 15),\n",
" datetime.date(1900, 6, 16),\n",
" datetime.date(1900, 6, 17),\n",
" datetime.date(1900, 6, 18),\n",
" datetime.date(1900, 6, 19),\n",
" datetime.date(1900, 6, 20),\n",
" datetime.date(1900, 6, 21),\n",
" datetime.date(1900, 6, 22),\n",
" datetime.date(1900, 6, 23),\n",
" datetime.date(1900, 6, 24),\n",
" datetime.date(1900, 6, 25),\n",
" datetime.date(1900, 6, 26),\n",
" datetime.date(1900, 6, 27),\n",
" datetime.date(1900, 6, 28),\n",
" datetime.date(1900, 6, 29),\n",
" datetime.date(1900, 6, 30),\n",
" datetime.date(1900, 7, 1),\n",
" datetime.date(1900, 7, 2),\n",
" datetime.date(1900, 7, 3),\n",
" datetime.date(1900, 7, 4),\n",
" datetime.date(1900, 7, 5),\n",
" datetime.date(1900, 7, 6),\n",
" datetime.date(1900, 7, 7),\n",
" datetime.date(1900, 7, 8),\n",
" datetime.date(1900, 7, 9),\n",
" datetime.date(1900, 7, 10),\n",
" datetime.date(1900, 7, 11),\n",
" datetime.date(1900, 7, 12),\n",
" datetime.date(1900, 7, 13),\n",
" datetime.date(1900, 7, 14),\n",
" datetime.date(1900, 7, 15),\n",
" datetime.date(1900, 7, 16),\n",
" datetime.date(1900, 7, 17),\n",
" datetime.date(1900, 7, 18),\n",
" datetime.date(1900, 7, 19),\n",
" datetime.date(1900, 7, 20),\n",
" datetime.date(1900, 7, 21),\n",
" datetime.date(1900, 7, 22),\n",
" datetime.date(1900, 7, 23),\n",
" datetime.date(1900, 7, 24),\n",
" datetime.date(1900, 7, 25),\n",
" datetime.date(1900, 7, 26),\n",
" datetime.date(1900, 7, 27),\n",
" datetime.date(1900, 7, 28),\n",
" datetime.date(1900, 7, 29),\n",
" datetime.date(1900, 7, 30),\n",
" datetime.date(1900, 7, 31),\n",
" datetime.date(1900, 8, 1),\n",
" datetime.date(1900, 8, 2),\n",
" datetime.date(1900, 8, 3),\n",
" datetime.date(1900, 8, 4),\n",
" datetime.date(1900, 8, 5),\n",
" datetime.date(1900, 8, 6),\n",
" datetime.date(1900, 8, 7),\n",
" datetime.date(1900, 8, 8),\n",
" datetime.date(1900, 8, 9),\n",
" datetime.date(1900, 8, 10),\n",
" datetime.date(1900, 8, 11),\n",
" datetime.date(1900, 8, 12),\n",
" datetime.date(1900, 8, 13),\n",
" datetime.date(1900, 8, 14),\n",
" datetime.date(1900, 8, 15),\n",
" datetime.date(1900, 8, 16),\n",
" datetime.date(1900, 8, 17),\n",
" datetime.date(1900, 8, 18),\n",
" datetime.date(1900, 8, 19),\n",
" datetime.date(1900, 8, 20),\n",
" datetime.date(1900, 8, 21),\n",
" datetime.date(1900, 8, 22),\n",
" datetime.date(1900, 8, 23),\n",
" datetime.date(1900, 8, 24),\n",
" datetime.date(1900, 8, 25),\n",
" datetime.date(1900, 8, 26),\n",
" datetime.date(1900, 8, 27),\n",
" datetime.date(1900, 8, 28),\n",
" datetime.date(1900, 8, 29),\n",
" datetime.date(1900, 8, 30),\n",
" datetime.date(1900, 8, 31),\n",
" datetime.date(1900, 9, 1),\n",
" datetime.date(1900, 9, 2),\n",
" datetime.date(1900, 9, 3),\n",
" datetime.date(1900, 9, 4),\n",
" datetime.date(1900, 9, 5),\n",
" datetime.date(1900, 9, 6),\n",
" datetime.date(1900, 9, 7),\n",
" datetime.date(1900, 9, 8),\n",
" datetime.date(1900, 9, 9),\n",
" datetime.date(1900, 9, 10),\n",
" datetime.date(1900, 9, 11),\n",
" datetime.date(1900, 9, 12),\n",
" datetime.date(1900, 9, 13),\n",
" datetime.date(1900, 9, 14),\n",
" datetime.date(1900, 9, 15),\n",
" datetime.date(1900, 9, 16),\n",
" datetime.date(1900, 9, 17),\n",
" datetime.date(1900, 9, 18),\n",
" datetime.date(1900, 9, 19),\n",
" datetime.date(1900, 9, 20),\n",
" datetime.date(1900, 9, 21),\n",
" datetime.date(1900, 9, 22),\n",
" datetime.date(1900, 9, 23),\n",
" datetime.date(1900, 9, 24),\n",
" datetime.date(1900, 9, 25),\n",
" datetime.date(1900, 9, 26),\n",
" datetime.date(1900, 9, 27),\n",
" datetime.date(1900, 9, 28),\n",
" datetime.date(1900, 9, 29),\n",
" datetime.date(1900, 9, 30),\n",
" datetime.date(1900, 10, 1),\n",
" datetime.date(1900, 10, 2),\n",
" datetime.date(1900, 10, 3),\n",
" datetime.date(1900, 10, 4),\n",
" datetime.date(1900, 10, 5),\n",
" datetime.date(1900, 10, 6),\n",
" datetime.date(1900, 10, 7),\n",
" datetime.date(1900, 10, 8),\n",
" datetime.date(1900, 10, 9),\n",
" datetime.date(1900, 10, 10),\n",
" datetime.date(1900, 10, 11),\n",
" datetime.date(1900, 10, 12),\n",
" datetime.date(1900, 10, 13),\n",
" datetime.date(1900, 10, 14),\n",
" datetime.date(1900, 10, 15),\n",
" datetime.date(1900, 10, 16),\n",
" datetime.date(1900, 10, 17),\n",
" datetime.date(1900, 10, 18),\n",
" datetime.date(1900, 10, 19),\n",
" datetime.date(1900, 10, 20),\n",
" datetime.date(1900, 10, 21),\n",
" datetime.date(1900, 10, 22),\n",
" datetime.date(1900, 10, 23),\n",
" datetime.date(1900, 10, 24),\n",
" datetime.date(1900, 10, 25),\n",
" datetime.date(1900, 10, 26),\n",
" datetime.date(1900, 10, 27),\n",
" datetime.date(1900, 10, 28),\n",
" datetime.date(1900, 10, 29),\n",
" datetime.date(1900, 10, 30),\n",
" datetime.date(1900, 10, 31),\n",
" datetime.date(1900, 11, 1),\n",
" datetime.date(1900, 11, 2),\n",
" datetime.date(1900, 11, 3),\n",
" datetime.date(1900, 11, 4),\n",
" datetime.date(1900, 11, 5),\n",
" datetime.date(1900, 11, 6),\n",
" datetime.date(1900, 11, 7),\n",
" datetime.date(1900, 11, 8),\n",
" datetime.date(1900, 11, 9),\n",
" datetime.date(1900, 11, 10),\n",
" datetime.date(1900, 11, 11),\n",
" datetime.date(1900, 11, 12),\n",
" datetime.date(1900, 11, 13),\n",
" datetime.date(1900, 11, 14),\n",
" datetime.date(1900, 11, 15),\n",
" datetime.date(1900, 11, 16),\n",
" datetime.date(1900, 11, 17),\n",
" datetime.date(1900, 11, 18),\n",
" datetime.date(1900, 11, 19),\n",
" datetime.date(1900, 11, 20),\n",
" datetime.date(1900, 11, 21),\n",
" datetime.date(1900, 11, 22),\n",
" datetime.date(1900, 11, 23),\n",
" datetime.date(1900, 11, 24),\n",
" datetime.date(1900, 11, 25),\n",
" datetime.date(1900, 11, 26),\n",
" datetime.date(1900, 11, 27),\n",
" datetime.date(1900, 11, 28),\n",
" datetime.date(1900, 11, 29),\n",
" datetime.date(1900, 11, 30),\n",
" datetime.date(1900, 12, 1),\n",
" datetime.date(1900, 12, 2),\n",
" datetime.date(1900, 12, 3),\n",
" datetime.date(1900, 12, 4),\n",
" datetime.date(1900, 12, 5),\n",
" datetime.date(1900, 12, 6),\n",
" datetime.date(1900, 12, 7),\n",
" datetime.date(1900, 12, 8),\n",
" datetime.date(1900, 12, 9),\n",
" datetime.date(1900, 12, 10),\n",
" datetime.date(1900, 12, 11),\n",
" datetime.date(1900, 12, 12),\n",
" datetime.date(1900, 12, 13),\n",
" datetime.date(1900, 12, 14),\n",
" datetime.date(1900, 12, 15),\n",
" datetime.date(1900, 12, 16),\n",
" datetime.date(1900, 12, 17),\n",
" datetime.date(1900, 12, 18),\n",
" datetime.date(1900, 12, 19),\n",
" datetime.date(1900, 12, 20),\n",
" datetime.date(1900, 12, 21),\n",
" datetime.date(1900, 12, 22),\n",
" datetime.date(1900, 12, 23),\n",
" datetime.date(1900, 12, 24),\n",
" datetime.date(1900, 12, 25),\n",
" datetime.date(1900, 12, 26),\n",
" datetime.date(1900, 12, 27),\n",
" datetime.date(1900, 12, 28),\n",
" datetime.date(1900, 12, 29),\n",
" datetime.date(1900, 12, 30),\n",
" datetime.date(1900, 12, 31)]"
]
},
"execution_count": 32,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"date_1"
]
},
{
"cell_type": "code",
"execution_count": 42,
"metadata": {
"collapsed": false,
"scrolled": false
},
"outputs": [
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support.' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" this.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>')\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option)\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width, fig.canvas.height);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overriden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>')\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" // select the cell after this one\n",
" var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
" IPython.notebook.select(index + 1);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"800\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"plt.gca().xaxis.set_major_formatter(mdates.DateFormatter('%b'))\n",
"plt.gca().xaxis.set_major_locator(mdates.MonthLocator())\n",
"plt.plot(date_1,low_14,'b-',alpha=0.7,label='2005-2014 Record Low')\n",
"plt.plot(date_1,high_14,'r-',alpha=0.7,label='2005-2014 Record High')\n",
"plt.gca().fill_between(date_1, \n",
" low_14, high_14, \n",
" facecolor='yellow', \n",
" alpha=0.25)\n",
"#plt.xticks(range(12), ['Jan','f','f','f','f','f','f','f','f','f','f','f'])\n",
"#plt.xticks(np.arange(12), ('Jan','f','f','f','f','f','f','f','f','f','f','f'))\n",
"plt.plot(date_1,low_15,'bo',label='2015 Low',markersize=3)\n",
"plt.plot(date_1,high_15,'ro',label='2015 High',markersize=3)\n",
"plt.xlabel('Month')\n",
"plt.ylabel('Temprature (Celsius)')\n",
"plt.title('2005 - 2014 Record vs. 2015 Record Temprature \\n(Ann Arbor, Michigan, United States)')\n",
"plt.legend()\n",
"plt.gcf().autofmt_xdate()"
]
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3",
"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.5.2"
}
},
"nbformat": 4,
"nbformat_minor": 1
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment