Open In Colab

1.9. Tabular Data with Pandas#

1200px-Pandas_logo.svg.png

1.9.1. Introduction#

Pandas is a an open source library providing high-performance, easy-to-use data structures and data analysis tools. Pandas is particularly suited to the analysis of tabular data, i.e. data that can can go into a table. In other words, if you can imagine the data in an Excel spreadsheet, then Pandas is the tool for the job.

A 2017 recent analysis of questions from Stack Overflow showed that python was the fastest growing and most widely used programming language in the world (in developed countries). As of 2021, the growth has now leveled off, but Python remains at the top.

![SO_language_growth_2021.svg](data:image/svg+xml;base64,
            <svg id="trend-chart" width="660" height="400" title="Stack Overflow Trends Chart" version="1.1" xmlns="http://www.w3.org/2000/svg"><g></g><g class="chart-area" transform="translate(100, 20)"><g transform="translate(0,300)" fill="none" font-size="10" font-family="sans-serif" text-anchor="middle"><path class="domain" stroke="#000" d="M0.5,6V0.5H410.5V6"></path><g class="tick" opacity="1" transform="translate(13.129751691427774,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2009</text></g><g class="tick" opacity="1" transform="translate(44.44383413545372,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2010</text></g><g class="tick" opacity="1" transform="translate(75.75791657947967,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2011</text></g><g class="tick" opacity="1" transform="translate(107.07199902350561,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2012</text></g><g class="tick" opacity="1" transform="translate(138.47187347422752,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2013</text></g><g class="tick" opacity="1" transform="translate(169.78595591825348,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2014</text></g><g class="tick" opacity="1" transform="translate(201.10003836227943,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2015</text></g><g class="tick" opacity="1" transform="translate(232.41412080630533,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2016</text></g><g class="tick" opacity="1" transform="translate(263.8139952570273,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2017</text></g><g class="tick" opacity="1" transform="translate(295.12807770105326,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2018</text></g><g class="tick" opacity="1" transform="translate(326.4421601450792,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2019</text></g><g class="tick" opacity="1" transform="translate(357.7562425891051,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2020</text></g><g class="tick" opacity="1" transform="translate(389.156117039827,0)"><line stroke="#000" y2="6" x1="0.5" x2="0.5"></line><text fill="#000" y="9" x="0.5" dy="0.71em" style="font-size: 12px;">2021</text></g></g><g class="grid-lines" transform="translate(0,300)" fill="none" font-size="10" font-family="sans-serif" text-anchor="middle"><path class="domain" stroke="#000" d="M0.5,-300V0.5H410.5V-300"></path><g class="tick" opacity="1" transform="translate(13.129751691427774,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(44.44383413545372,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(75.75791657947967,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(107.07199902350561,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(138.47187347422752,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(169.78595591825348,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(201.10003836227943,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(232.41412080630533,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(263.8139952570273,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(295.12807770105326,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(326.4421601450792,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(357.7562425891051,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(389.156117039827,0)"><line stroke="#000" y2="-300" x1="0.5" x2="0.5" style="stroke: #ccc; fill: none;"></line></g></g><text x="205" y="360" class="axis-label x-axis-label" style="text-anchor: middle; font-weight: bold;">Year</text><g fill="none" font-size="10" font-family="sans-serif" text-anchor="end"><path class="domain" stroke="#000" d="M-6,300.5H0.5V0.5H-6"></path><g class="tick" opacity="1" transform="translate(0,300)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">0.00%</text></g><g class="tick" opacity="1" transform="translate(0,264.70588235294116)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">2.00%</text></g><g class="tick" opacity="1" transform="translate(0,229.41176470588235)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">4.00%</text></g><g class="tick" opacity="1" transform="translate(0,194.11764705882354)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">6.00%</text></g><g class="tick" opacity="1" transform="translate(0,158.8235294117647)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">8.00%</text></g><g class="tick" opacity="1" transform="translate(0,123.52941176470588)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">10.00%</text></g><g class="tick" opacity="1" transform="translate(0,88.23529411764707)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">12.00%</text></g><g class="tick" opacity="1" transform="translate(0,52.9411764705882)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">14.00%</text></g><g class="tick" opacity="1" transform="translate(0,17.64705882352939)"><line stroke="#000" x2="-6" y1="0.5" y2="0.5"></line><text fill="#000" x="-9" y="0.5" dy="0.32em" style="font-size: 12px;">16.00%</text></g></g><g class="grid-lines" fill="none" font-size="10" font-family="sans-serif" text-anchor="end"><path class="domain" stroke="#000" d="M410,300.5H0.5V0.5H410"></path><g class="tick" opacity="1" transform="translate(0,300)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(0,264.70588235294116)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(0,229.41176470588235)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(0,194.11764705882354)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(0,158.8235294117647)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(0,123.52941176470588)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(0,88.23529411764707)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(0,52.9411764705882)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g><g class="tick" opacity="1" transform="translate(0,17.64705882352939)"><line stroke="#000" x2="410" y1="0.5" y2="0.5" style="stroke: #ccc; fill: none;"></line></g></g><g class="lines"><path class="line" d="M2.6595522075748064,155.67272265278822L5.233312408453652,158.8431005590059L7.892864616028457,165.28103950162944L10.470199483852968,177.44072610218825L13.129751691427774,170.9107712800941L15.789303899002581,177.5832832271647L18.191480086489502,174.69028399470002L20.847457627118647,171.74592203869412L23.421217827997488,174.4431596744118L26.080770035572296,166.8705227101412L28.65453023645114,175.8735940953L31.314082444025946,180.72706949332942L33.973634651600754,177.9612734757353L36.5473948524796,177.23657320964116L39.206947060054404,172.22340533885296L41.784281927878915,173.3568451426765L44.44383413545372,152.52900684928238L47.10338634302853,158.09336102329414L49.50556253051545,148.79587897320002L52.16154007114459,161.9592694634647L54.73530027202343,157.4026844260941L57.394852479598235,163.43683953829412L59.96861268047709,168.10330982728237L62.62816488805189,168.7325876161941L65.2877170956267,163.05664079507648L67.86147729650554,160.14666933742944L70.52102950408035,157.29117460145292L73.09836437190486,155.13322827360003L75.75791657947967,154.94656607066472L78.41746878705447,153.01781880896473L80.81964497454139,151.04386994315297L83.47562251517054,153.6823069911L86.04938271604938,148.75210336185884L88.70893492362418,158.59127249989413L91.28269512450304,156.44906614526474L93.94224733207784,156.52234185112943L96.60179953965265,155.5451761447765L99.17555974053148,150.5692599620647L101.8351119481063,143.26417234235296L104.41244681593082,142.94487449167062L107.07199902350561,145.51140178801765L109.73155123108043,143.42564752711766L112.21951942526331,135.86591572987058L114.87549696589245,134.80399776885886L117.44925716677129,139.6008920123294L120.1088093743461,149.70922590557652L122.68256957522495,147.01281922764707L125.34212178279977,146.4127471029353L128.00167399037457,144.18031080862943L130.5754341912534,140.31084704322353L133.2349863988282,136.90249680425293L135.8123212666527,137.22213394842353L138.47187347422752,145.60511274135882L141.1314256818023,141.26193691242355L143.53360186928924,137.54696840744114L146.1895794099184,132.15915941779411L148.76333961079723,137.45794371331763L151.42289181837205,143.99704427220004L153.9966520192509,147.57032667651177L156.6562042268257,143.19404606941765L159.3157564344005,126.06165527412355L161.88951663527936,120.05423312186471L164.54906884285415,111.6180552564353L167.12640371067866,113.16889423727648L169.78595591825348,124.87494409210592L172.44550812582827,118.4585908033236L174.8476843133152,112.69854601048235L177.50366185394435,109.83068210302943L180.0774220548232,119.46299190227649L182.73697426239798,126.60379710506473L185.31073446327684,126.23141396131768L187.97028667085164,129.46115077108234L190.62983887842645,121.76194654847646L193.2035990793053,116.48918197773531L195.86315128688008,110.11307193082942L198.44048615470462,113.06014130779417L201.10003836227943,123.2582404755706L203.75959056985423,123.29979418681768L206.16176675734113,115.0699135429941L208.81774429797028,114.48797934455294L211.39150449884914,122.56804727696473L214.05105670642396,131.1514479412765L216.62481690730277,129.96694810771766L219.2843691148776,132.55479909119998L221.94392132245238,130.56179146927062L224.51768152333125,123.08070686424708L227.17723373090607,122.69053685338235L229.75456859873057,129.35850465545295L232.41412080630533,136.68904900408236L235.07367301388015,131.471432529L237.56164120806304,124.2954142980706L240.2176187486922,123.78507066455296L242.79137894957105,139.9749687109059L245.45093115714582,146.26702956956476L248.0246913580247,149.55761409654707L250.68424356559953,151.25962303831767L253.3437957731743,147.55859287196472L255.91755597405316,144.16104002308236L258.5771081816279,140.8826780228647L261.1544430494524,147.9727135012765L263.8139952570273,153.12836284946474L266.47354746460206,151.76023286784707L268.875723652089,146.94869137083535L271.5317011927182,141.1440815208L274.10546139359695,143.9532852325059L276.7650136011718,153.95881837048233L279.33877380205064,159.78378960109413L281.99832600962543,161.83454470941177L284.6578782172003,159.82247548120588L287.2316384180791,153.19410362269414L289.8911906256539,150.46722408144709L292.4685254934784,153.1758828019588L295.12807770105326,162.72757495009412L297.787629908628,159.83151394298824L300.1898060961149,160.0664672260765L302.8457836367441,151.96991520515294L305.41954383762294,156.63784939408234L308.07909604519773,163.66429590111179L310.65285624607657,168.43546263827648L313.3124084536514,172.1240657793353L315.9719606612262,166.4840807942647L318.54572086210504,160.07557810452354L321.20527306967983,159.36669114483533L323.78260793750434,157.86818859335293L326.4421601450792,167.25216018780003L329.101712352654,165.56804449535295L331.5038885401409,166.16945286141177L334.15986608077003,169.79090842388825L336.73362628164887,168.7023297453L339.3931784892237,173.05758964095884L341.9669386901025,171.6708682347353L344.62649089767734,181.3078034776412L347.28604310525213,173.38784617381765L349.85980330613097,168.66407930422943L352.5193555137058,175.72036802410588L355.0966903815303,178.25536088142354L357.7562425891051,178.65811579277647L360.4157947966799,176.42730468554117L362.9037629908628,173.57212003872354L365.55974053149197,176.8624557614647L368.1335007323708,184.83136611266474L370.7930529399456,187.59861494355886L373.36681314082443,187.60537330729414L376.0263653483993,187.62884089369413L378.6859175559741,186.8839382466706L381.2596777568529,187.7198727784412L383.9192299644277,187.64270856562942L386.4965648322522,195.70845917791766L389.156117039827,198.29177148928235L391.81566924740184,197.64026908794708L394.2178454348888,197.45010087171175L396.8738229755179,197.52362210235884L399.44758317639673,193.91516420209413L402.1071353839715,195.49142097974118L404.6808955848504,201.33146065434707L407.3404477924252,203.10415740105884L410,201.7873959138" data-legend="java" style="stroke: rgb(31, 119, 180); fill: none;"></path><path class="line" d="M2.6595522075748064,259.34442891628237L5.233312408453652,262.9371399214765L7.892864616028457,263.57806809074117L10.470199483852968,272.0919243774882L13.129751691427774,263.96726746166473L15.789303899002581,266.35567055581765L18.191480086489502,262.4419418649L20.847457627118647,261.7913209724294L23.421217827997488,266.8314345865235L26.080770035572296,268.37151083791764L28.65453023645114,270.3152085081882L31.314082444025946,271.14803597968233L33.973634651600754,269.0317289898706L36.5473948524796,262.0192990968L39.206947060054404,255.60226294201766L41.784281927878915,259.92305226035296L44.44383413545372,261.1835137427294L47.10338634302853,258.9677112131118L49.50556253051545,262.0968967543059L52.16154007114459,257.9984094072353L54.73530027202343,259.6242076977353L57.394852479598235,263.21337834435883L59.96861268047709,262.41951732294706L62.62816488805189,261.93328703975294L65.2877170956267,260.0315799861882L67.86147729650554,259.85511117047645L70.52102950408035,257.28165898055295L73.09836437190486,262.5203790655059L75.75791657947967,267.5958613194706L78.41746878705447,264.96553946581764L80.81964497454139,262.9322521028647L83.47562251517054,262.1838151917L86.04938271604938,267.7876751821059L88.70893492362418,268.4845236500118L91.28269512450304,270.8291279685353L93.94224733207784,269.91491019031764L96.60179953965265,266.7935881815706L99.17555974053148,262.6946366782059L101.8351119481063,264.32069513260586L104.41244681593082,265.83164858461765L107.07199902350561,266.0106826467L109.73155123108043,265.6355916474706L112.21951942526331,263.83284559468234L114.87549696589245,263.3370214244647L117.44925716677129,267.3256204492941L120.1088093743461,268.73789568568236L122.68256957522495,270.4008488750471L125.34212178279977,270.9541280725059L128.00167399037457,266.08653939778236L130.5754341912534,262.72106279664706L133.2349863988282,261.7107712060059L135.8123212666527,266.4098771985353L138.47187347422752,267.30275890004117L141.1314256818023,264.16899633815297L143.53360186928924,264.87446857582944L146.1895794099184,263.5173542330647L148.76333961079723,266.03963707586473L151.42289181837205,267.1225587391412L153.9966520192509,269.7123120202588L156.6562042268257,268.7302291419882L159.3157564344005,263.7077110176353L161.88951663527936,259.3203626156647L164.54906884285415,256.99650703051765L167.12640371067866,262.6060083881118L169.78595591825348,265.0142880936353L172.44550812582827,262.61774235615883L174.8476843133152,261.1505255404412L177.50366185394435,263.5281766631294L180.0774220548232,267.23799336471177L182.73697426239798,269.8105795962882L185.31073446327684,271.6823781612L187.97028667085164,271.01770286617057L190.62983887842645,265.5349609733647L193.2035990793053,261.0207172788706L195.86315128688008,260.9606069584941L198.44048615470462,264.0346817382882L201.10003836227943,265.69789952571176L203.75959056985423,264.53567042364705L206.16176675734113,263.3913719844L208.81774429797028,263.05651269185296L211.39150449884914,266.3331303149118L214.05105670642396,270.04650301660587L216.62481690730277,274.42784265495885L219.2843691148776,274.78488384608823L221.94392132245238,269.1721724680765L224.51768152333125,264.95147921779414L227.17723373090607,263.94431942869414L229.75456859873057,268.17780620754706L232.41412080630533,270.0903958681941L235.07367301388015,269.07715397874705L237.56164120806304,269.5802676337059L240.2176187486922,269.6280840548647L242.79137894957105,274.4399249061353L245.45093115714582,277.7941264933941L248.0246913580247,276.3645135129706L250.68424356559953,278.2940089702588L253.3437957731743,273.9498861237L255.91755597405316,267.3841962959647L258.5771081816279,266.8111925621471L261.1544430494524,269.28952259599413L263.8139952570273,272.19904543341175L266.47354746460206,272.26731005784706L268.875723652089,273.7626328064294L271.5317011927182,271.51755238309414L274.10546139359695,273.8045357120471L276.7650136011718,276.4952179983706L279.33877380205064,279.6875655086823L281.99832600962543,279.44480223485294L284.6578782172003,276.92627867331174L287.2316384180791,270.8418601762941L289.8911906256539,268.82714640391765L292.4685254934784,273.0720405572647L295.12807770105326,275.34427317065297L297.787629908628,274.99816761815293L300.1898060961149,274.52101115080586L302.8457836367441,275.9660805962294L305.41954383762294,274.76834655582354L308.07909604519773,278.7693786212294L310.65285624607657,282.0751280108647L313.3124084536514,280.98670493562355L315.9719606612262,277.1164884988588L318.54572086210504,272.4895108408941L321.20527306967983,269.56585044695294L323.78260793750434,270.05487699158823L326.4421601450792,272.4195888769059L329.101712352654,274.8762912318706L331.5038885401409,273.5378996082353L334.15986608077003,271.6754462689588L336.73362628164887,275.2451275655471L339.3931784892237,277.27208993364707L341.9669386901025,279.18923137318234L344.62649089767734,279.73579648745294L347.28604310525213,273.7683445230176L349.85980330613097,270.9506219021824L352.5193555137058,269.7652722828L355.0966903815303,271.0355821041706L357.7562425891051,275.0738843722765L360.4157947966799,275.57483537742354L362.9037629908628,271.5619839417L365.55974053149197,268.3629887129647L368.1335007323708,267.73982508748236L370.7930529399456,273.0890316602118L373.36681314082443,277.44829269199414L376.0263653483993,277.27445887722354L378.6859175559741,272.69612302507056L381.2596777568529,272.8290864008824L383.9192299644277,268.27236270185296L386.4965648322522,268.92159036495883L389.156117039827,270.84775660413527L391.81566924740184,273.64510528558236L394.2178454348888,273.8929924071882L396.8738229755179,273.6031013126471L399.44758317639673,275.3456348836235L402.1071353839715,277.32990360970587L404.6808955848504,279.7204861907647L407.3404477924252,280.28787265854703L410,277.49173633464704" data-legend="c" style="stroke: rgb(255, 127, 14); fill: none;"></path><path class="line" d="M2.6595522075748064,204.20531063398238L5.233312408453652,200.9210671168059L7.892864616028457,196.78108872045883L10.470199483852968,206.67775770672353L13.129751691427774,204.36171924404118L15.789303899002581,214.4704396057412L18.191480086489502,208.3269671505L20.847457627118647,214.88745021864707L23.421217827997488,215.9729676192L26.080770035572296,221.11779197024117L28.65453023645114,219.4662601194L31.314082444025946,223.7872648519588L33.973634651600754,221.06867510832353L36.5473948524796,217.37359777702943L39.206947060054404,218.93593577837646L41.784281927878915,222.06212398394118L44.44383413545372,220.86343270688823L47.10338634302853,209.64166192674708L49.50556253051545,217.1167329385059L52.16154007114459,211.59428522737062L54.73530027202343,217.23133517036473L57.394852479598235,209.97797265550588L59.96861268047709,221.56862745098823L62.62816488805189,226.48801804893532L65.2877170956267,220.52757153390002L67.86147729650554,218.37484142352355L70.52102950408035,213.97708774422352L73.09836437190486,219.96353242238825L75.75791657947967,222.48291260198823L78.41746878705447,226.31641236857647L80.81964497454139,226.58477798001178L83.47562251517054,222.7741997643353L86.04938271604938,231.44511255192356L88.70893492362418,231.87726115503528L91.28269512450304,232.3038834712588L93.94224733207784,234.7468759695706L96.60179953965265,231.5940984095294L99.17555974053148,224.02890947650587L101.8351119481063,227.22979430181175L104.41244681593082,225.64762233151765L107.07199902350561,230.78898628459413L109.73155123108043,227.08806254408825L112.21951942526331,230.6674988859L114.87549696589245,227.12667221405295L117.44925716677129,234.37500822121766L120.1088093743461,237.04291065388236L122.68256957522495,234.05079523801766L125.34212178279977,235.2921127551353L128.00167399037457,234.19636309065882L130.5754341912534,230.05468444775295L133.2349863988282,224.8826890847647L135.8123212666527,225.55171613008235L138.47187347422752,232.01764255817648L141.1314256818023,229.7392698072353L143.53360186928924,226.67723902302353L146.1895794099184,226.31125656705882L148.76333961079723,227.26423677938826L151.42289181837205,230.79080624071764L153.9966520192509,234.12803331612355L156.6562042268257,235.0087420306412L159.3157564344005,229.93379316135884L161.88951663527936,223.4175371665765L164.54906884285415,218.38051229551763L167.12640371067866,224.98771691221768L169.78595591825348,227.95132878335295L172.44550812582827,227.6524004895353L174.8476843133152,226.1740815101294L177.50366185394435,226.05737410138238L180.0774220548232,231.85863633705884L182.73697426239798,238.2622547811706L185.31073446327684,237.31594460779414L187.97028667085164,236.31037392358235L190.62983887842645,233.9357938163294L193.2035990793053,229.92534516854118L195.86315128688008,230.21549192715884L198.44048615470462,230.65704247669413L201.10003836227943,234.53455334317061L203.75959056985423,231.73616870082353L206.16176675734113,230.9116068376059L208.81774429797028,233.1427577864647L211.39150449884914,234.7973170986706L214.05105670642396,238.40215899441176L216.62481690730277,239.06634382625293L219.2843691148776,242.4758758755L221.94392132245238,240.9308066565L224.51768152333125,232.79905800552353L227.17723373090607,229.32329428768236L229.75456859873057,232.41258419687648L232.41412080630533,240.1807917363706L235.07367301388015,238.0977072631059L237.56164120806304,238.04987566784118L240.2176187486922,237.66620463372354L242.79137894957105,242.3654568210353L245.45093115714582,244.77000691944707L248.0246913580247,244.93434531211764L250.68424356559953,250.8604560314294L253.3437957731743,246.62372126897648L255.91755597405316,239.30739142621763L258.5771081816279,238.12273458707648L261.1544430494524,242.56186166131764L263.8139952570273,243.0785528058706L266.47354746460206,247.43191360305883L268.875723652089,244.96336780607646L271.5317011927182,241.3508732590941L274.10546139359695,249.37452165841765L276.7650136011718,253.15019662207058L279.33877380205064,250.23404031257647L281.99832600962543,251.8639021085647L284.6578782172003,250.8434190108L287.2316384180791,245.33633729389413L289.8911906256539,246.90396007965882L292.4685254934784,245.36036606024118L295.12807770105326,247.13456769922942L297.787629908628,246.84347503365882L300.1898060961149,246.53842574260588L302.8457836367441,248.87309937054707L305.41954383762294,250.12149755304705L308.07909604519773,252.6065073356294L310.65285624607657,256.2159298918588L313.3124084536514,255.78931035298234L315.9719606612262,253.50553778512943L318.54572086210504,251.8621859718L321.20527306967983,247.74917069712353L323.78260793750434,251.5340603373706L326.4421601450792,253.1240142413647L329.101712352654,254.31166401601763L331.5038885401409,250.88145977595883L334.15986608077003,248.98785142187648L336.73362628164887,251.24612909855296L339.3931784892237,252.0597524511353L341.9669386901025,249.54571038031764L344.62649089767734,257.0216442544235L347.28604310525213,250.60662880552943L349.85980330613097,243.38585990835884L352.5193555137058,243.09958833824118L355.0966903815303,243.4152207232059L357.7562425891051,248.4852186759L360.4157947966799,249.67827529565295L362.9037629908628,246.90507374295885L365.55974053149197,239.35915619091176L368.1335007323708,238.60467597866472L370.7930529399456,241.6584272080059L373.36681314082443,244.48234180981765L376.0263653483993,242.56984104887647L378.6859175559741,250.4466614938059L381.2596777568529,249.53973188735296L383.9192299644277,248.33428990265296L386.4965648322522,246.1382094886059L389.156117039827,251.9876706978L391.81566924740184,250.1490466079647L394.2178454348888,253.54820946571766L396.8738229755179,253.28868539784708L399.44758317639673,249.7947473993647L402.1071353839715,252.65850693954707L404.6808955848504,255.22979724015883L407.3404477924252,257.76489729347645L410,250.41220674961764" data-legend="c++" style="stroke: rgb(44, 160, 44); fill: none;"></path><path class="line" d="M2.6595522075748064,231.39372379621767L5.233312408453652,237.61696818465884L7.892864616028457,236.43740068344707L10.470199483852968,235.02881865658236L13.129751691427774,229.16930145891178L15.789303899002581,236.25818307109412L18.191480086489502,233.4237670180588L20.847457627118647,235.87296101934706L23.421217827997488,230.9679232332L26.080770035572296,234.28582829468826L28.65453023645114,236.23267012868826L31.314082444025946,238.0499338582412L33.973634651600754,237.0923275299353L36.5473948524796,230.36054711812943L39.206947060054404,227.91733409876474L41.784281927878915,225.07968240199415L44.44383413545372,223.00012002379412L47.10338634302853,226.07045066735293L49.50556253051545,229.46756460654706L52.16154007114459,235.59519413754708L54.73530027202343,231.35089674601767L57.394852479598235,229.67826050922355L59.96861268047709,224.22583329684707L62.62816488805189,230.5038471084706L65.2877170956267,234.7211498830412L67.86147729650554,225.63597516192354L70.52102950408035,233.5775676034059L73.09836437190486,236.6494902788647L75.75791657947967,235.6131316977353L78.41746878705447,235.57765865142352L80.81964497454139,234.13886878369414L83.47562251517054,238.07854501256472L86.04938271604938,237.9405292823294L88.70893492362418,237.96953861271177L91.28269512450304,235.60956396668826L93.94224733207784,236.80975925327647L96.60179953965265,238.95982128157058L99.17555974053148,236.77796070991766L101.8351119481063,237.0947408044941L104.41244681593082,238.2413438756294L107.07199902350561,235.90107698768824L109.73155123108043,235.85405619945882L112.21951942526331,233.32548719869413L114.87549696589245,232.51707647151176L117.44925716677129,232.8754594012588L120.1088093743461,228.54762657365296L122.68256957522495,228.56022757572356L125.34212178279977,226.52071053370588L128.00167399037457,229.62722438447645L130.5754341912534,227.50003646682353L133.2349863988282,223.45747224820587L135.8123212666527,224.63502661891766L138.47187347422752,226.07678113327057L141.1314256818023,222.11910160764705L143.53360186928924,222.23807395342942L146.1895794099184,218.05356989062943L148.76333961079723,217.00703796192352L151.42289181837205,215.00605715525293L153.9966520192509,213.6725799136059L156.6562042268257,217.46234901428824L159.3157564344005,214.9302770457353L161.88951663527936,208.91444550774708L164.54906884285415,204.83736706032354L167.12640371067866,209.6178357555353L169.78595591825348,207.88062751586472L172.44550812582827,206.83118830752352L174.8476843133152,202.73160721967645L177.50366185394435,202.0909543339412L180.0774220548232,207.21944126422943L182.73697426239798,202.9850962611706L185.31073446327684,200.95320355782354L187.97028667085164,201.30001872270003L190.62983887842645,206.45964678397058L193.2035990793053,201.86067116311764L195.86315128688008,198.30216872537648L198.44048615470462,196.8918213384353L201.10003836227943,196.6026009668294L203.75959056985423,192.5221208799706L206.16176675734113,191.47255925355884L208.81774429797028,192.8620171966765L211.39150449884914,192.7208972225647L214.05105670642396,188.3285268566118L216.62481690730277,188.08548752828824L219.2843691148776,190.08870789409414L221.94392132245238,190.36997387574706L224.51768152333125,181.00269826295295L227.17723373090607,177.3967380186353L229.75456859873057,179.9589842704412L232.41412080630533,178.8018500988353L235.07367301388015,174.92189890298826L237.56164120806304,175.95871519604117L240.2176187486922,176.47971245752942L242.79137894957105,176.93053817272943L245.45093115714582,175.4019848570294L248.0246913580247,170.88989785782354L250.68424356559953,173.49431209044707L253.3437957731743,171.96955183291766L255.91755597405316,162.83490771042355L258.5771081816279,155.85675275913528L261.1544430494524,156.69541072750593L263.8139952570273,156.00918640238825L266.47354746460206,149.71687851361764L268.875723652089,148.61834201041762L271.5317011927182,144.0541146573L274.10546139359695,145.50879003358236L276.7650136011718,139.90986838055295L279.33877380205064,132.40013218104704L281.99832600962543,134.70529687775297L284.6578782172003,130.24725818811177L287.2316384180791,122.56026469088826L289.8911906256539,120.88514469725297L292.4685254934784,116.90457044661179L295.12807770105326,119.51341589917058L297.787629908628,110.00236173661767L300.1898060961149,115.49626675634116L302.8457836367441,113.74808900006474L305.41954383762294,113.05396929813531L308.07909604519773,105.79410378594707L310.65285624607657,99.5744519168824L313.3124084536514,99.62393179051764L315.9719606612262,101.69267296101177L318.54572086210504,97.68373947575296L321.20527306967983,84.67008305691175L323.78260793750434,86.86276451190002L326.4421601450792,96.47394502249412L329.101712352654,85.74754715724708L331.5038885401409,78.97211660190001L334.15986608077003,69.03609167745884L336.73362628164887,76.58018996057649L339.3931784892237,73.29928455501181L341.9669386901025,66.13898755611174L344.62649089767734,64.64854312757649L347.28604310525213,79.23867235775293L349.85980330613097,60.684559992529415L352.5193555137058,51.96948327377649L355.0966903815303,56.1209453735118L357.7562425891051,56.98857573259414L360.4157947966799,53.65161524481175L362.9037629908628,40.584249188558886L365.55974053149197,30.68702646102355L368.1335007323708,18.44279710136476L370.7930529399456,18.55181343935294L373.36681314082443,17.734397186911792L376.0263653483993,22.805840428182364L378.6859175559741,25.694490896205878L381.2596777568529,21.021164365394156L383.9192299644277,16.458232040576434L386.4965648322522,15.140663341464744L389.156117039827,19.621194677894152L391.81566924740184,20.92846656204705L394.2178454348888,23.128055445847053L396.8738229755179,14.38168063844114L399.44758317639673,14.632557027582436L402.1071353839715,21.977556039247077L404.6808955848504,14.945789942364684L407.3404477924252,18.879006463747032L410,26.42017668601767" data-legend="python" style="stroke: rgb(214, 39, 40); fill: none;"></path><path class="line" d="M2.6595522075748064,90.62380891882941L5.233312408453652,56.70617592015884L7.892864616028457,56.29649421328236L10.470199483852968,64.33180585431177L13.129751691427774,33.06592530785298L15.789303899002581,36.621649923335326L18.191480086489502,24.370909788052984L20.847457627118647,22.924371340429445L23.421217827997488,54.41441358437646L26.080770035572296,55.5407610579L28.65453023645114,57.73911832505294L31.314082444025946,57.4257515573824L33.973634651600754,65.25618960783532L36.5473948524796,68.48925023647061L39.206947060054404,83.3353394876118L41.784281927878915,88.48801463516472L44.44383413545372,97.7665022824412L47.10338634302853,97.65605365150589L49.50556253051545,94.69719480744709L52.16154007114459,94.64311074502945L54.73530027202343,97.19796787715296L57.394852479598235,104.01720109277647L59.96861268047709,104.88517074737646L62.62816488805189,105.79004464821176L65.2877170956267,114.06122105410589L67.86147729650554,112.49026284748237L70.52102950408035,113.50232622947647L73.09836437190486,118.54658673510002L75.75791657947967,122.83075990404708L78.41746878705447,124.10048630456473L80.81964497454139,124.53428151813532L83.47562251517054,128.02066271892352L86.04938271604938,123.15874939694118L88.70893492362418,125.53932734825293L91.28269512450304,130.98829296769412L93.94224733207784,133.73160733265294L96.60179953965265,138.6473413206706L99.17555974053148,139.04104810805296L101.8351119481063,139.09428541605882L104.41244681593082,141.08734316784708L107.07199902350561,140.7948895321941L109.73155123108043,146.2952969159294L112.21951942526331,146.49786898102943L114.87549696589245,147.25816333062357L117.44925716677129,147.65110146684708L120.1088093743461,146.7737535402706L122.68256957522495,146.25162689264118L125.34212178279977,150.24710293115297L128.00167399037457,148.85664338475883L130.5754341912534,149.58327304812354L133.2349863988282,153.4421980756059L135.8123212666527,156.52499594038238L138.47187347422752,156.38417570548236L141.1314256818023,155.36735464357062L143.53360186928924,154.73214996418236L146.1895794099184,156.43613814487063L148.76333961079723,156.72872242425882L151.42289181837205,156.9199691608765L153.9966520192509,157.84310944252942L156.6562042268257,155.9097269764765L159.3157564344005,152.97407891821766L161.88951663527936,154.00988422785886L164.54906884285415,153.62985341950588L167.12640371067866,154.2798550239706L169.78595591825348,156.34243517024117L172.44550812582827,157.68409939011178L174.8476843133152,162.13714102824704L177.50366185394435,160.5334185795706L180.0774220548232,160.32775377518823L182.73697426239798,163.83777797749414L185.31073446327684,163.1830657227706L187.97028667085164,164.60137436839412L190.62983887842645,168.61735354667647L193.2035990793053,171.29771899012943L195.86315128688008,173.79103729452356L198.44048615470462,173.52291406854704L201.10003836227943,174.42847625934706L203.75959056985423,175.6694546126118L206.16176675734113,175.97531151741177L208.81774429797028,177.4938256140353L211.39150449884914,172.21306232497062L214.05105670642396,172.06238942191766L216.62481690730277,171.6215950330588L219.2843691148776,170.47042776658236L221.94392132245238,170.90659977151768L224.51768152333125,178.03991218976472L227.17723373090607,176.49011548976472L229.75456859873057,174.85260830115885L232.41412080630533,178.66451508478235L235.07367301388015,179.78012516929414L237.56164120806304,179.9429861405647L240.2176187486922,175.98284887127647L242.79137894957105,173.21339173967647L245.45093115714582,173.83859871705886L248.0246913580247,179.19751991668238L250.68424356559953,175.4132900976L253.3437957731743,184.71968721882354L255.91755597405316,183.64119095747645L258.5771081816279,181.54836402647646L261.1544430494524,182.68795126701178L263.8139952570273,182.20856423851768L266.47354746460206,183.09166629956468L268.875723652089,185.21814412590004L271.5317011927182,189.41874081271766L274.10546139359695,185.56065291758824L276.7650136011718,187.06920797006472L279.33877380205064,188.97981928438236L281.99832600962543,190.04775804820588L284.6578782172003,191.52825057411178L287.2316384180791,192.8600583721059L289.8911906256539,196.76823508342943L292.4685254934784,194.5046063668765L295.12807770105326,195.7018330385294L297.787629908628,200.08574383651768L300.1898060961149,199.04221118747648L302.8457836367441,198.5356340499706L305.41954383762294,194.33115384398826L308.07909604519773,198.3864111702353L310.65285624607657,194.78636547518823L313.3124084536514,192.8464210742294L315.9719606612262,196.2844295541L318.54572086210504,195.99882361808824L321.20527306967983,198.65570636348824L323.78260793750434,197.74573794972355L326.4421601450792,194.95160631790588L329.101712352654,197.90826737835886L331.5038885401409,200.49806443882943L334.15986608077003,193.60822436961178L336.73362628164887,193.31547581085886L339.3931784892237,199.8999218303647L341.9669386901025,200.07283769020592L344.62649089767734,199.3826911123059L347.28604310525213,197.43788488554705L349.85980330613097,201.5360516225647L352.5193555137058,203.41951245501178L355.0966903815303,202.93223849477647L357.7562425891051,205.00407344992942L360.4157947966799,205.2053475415765L362.9037629908628,211.09845680770587L365.55974053149197,216.30183807538236L368.1335007323708,217.7584672637824L370.7930529399456,218.0156625559059L373.36681314082443,216.10807694340002L376.0263653483993,214.98565343011765L378.6859175559741,218.52733815838238L381.2596777568529,225.61441571571177L383.9192299644277,225.69832606462944L386.4965648322522,227.5582394118353L389.156117039827,226.20938172197648L391.81566924740184,226.3514700670941L394.2178454348888,228.09018963225884L396.8738229755179,227.19321948504705L399.44758317639673,228.2563441713L402.1071353839715,227.18432880119997L404.6808955848504,229.9392202738765L407.3404477924252,230.04245627101767L410,226.88294968088826" data-legend="c#" style="stroke: rgb(148, 103, 189); fill: none;"></path><path class="line" d="M2.6595522075748064,273.0656841570353L5.233312408453652,270.5209594755L7.892864616028457,268.21870034172355L10.470199483852968,268.6957035345353L13.129751691427774,272.38613020427647L15.789303899002581,271.32124929908827L18.191480086489502,265.8404668469647L20.847457627118647,268.6471452180706L23.421217827997488,270.35559466171765L26.080770035572296,272.6558480152412L28.65453023645114,275.4275892651L31.314082444025946,270.16815795635296L33.973634651600754,274.1571396971294L36.5473948524796,279.07385898624705L39.206947060054404,279.30574716901765L41.784281927878915,276.56677290988233L44.44383413545372,278.83096824910587L47.10338634302853,276.19016124552354L49.50556253051545,277.13565046579413L52.16154007114459,278.5198966114765L54.73530027202343,281.3334609678L57.394852479598235,282.5311363368353L59.96861268047709,280.1147562524647L62.62816488805189,282.7096248825353L65.2877170956267,282.87482366874707L67.86147729650554,282.38966415171177L70.52102950408035,281.8268632775294L73.09836437190486,284.18150784248826L75.75791657947967,281.48018083625294L78.41746878705447,282.7394324474471L80.81964497454139,284.29451818955295L83.47562251517054,281.5273217766529L86.04938271604938,283.6908558182294L88.70893492362418,283.9564071642353L91.28269512450304,284.47385171562354L93.94224733207784,284.83368209814705L96.60179953965265,285.26855425591765L99.17555974053148,284.3558153811882L101.8351119481063,285.9327160891235L104.41244681593082,285.24199884005293L107.07199902350561,284.7093715577118L109.73155123108043,284.7380338476L112.21951942526331,286.11498642575293L114.87549696589245,286.3799709220059L117.44925716677129,286.0173649507235L120.1088093743461,287.71700964197646L122.68256957522495,287.25938731088826L125.34212178279977,286.1662456393765L128.00167399037457,284.97945897467645L130.5754341912534,285.8193382909941L133.2349863988282,284.4064510823294L135.8123212666527,285.58178354604706L138.47187347422752,284.94531707098236L141.1314256818023,284.9102140364118L143.53360186928924,285.6518020969235L146.1895794099184,283.8773576780647L148.76333961079723,284.7576962650412L151.42289181837205,284.23760891608237L153.9966520192509,283.71974193222354L156.6562042268257,283.54441294381763L159.3157564344005,283.1717319243882L161.88951663527936,282.48502290409414L164.54906884285415,283.7722668039706L167.12640371067866,283.43385290202355L169.78595591825348,283.28845106585294L172.44550812582827,283.90917161544706L174.8476843133152,283.28212799331175L177.50366185394435,283.34429183271175L180.0774220548232,285.4391081620941L182.73697426239798,285.35644606274116L185.31073446327684,285.03767531324115L187.97028667085164,285.67118692861766L190.62983887842645,286.12875399917647L193.2035990793053,285.6656170713L195.86315128688008,285.9177815089765L198.44048615470462,285.1806929508L201.10003836227943,285.85425361704705L203.75959056985423,287.19197363682355L206.16176675734113,287.23975864524704L208.81774429797028,287.47361513338234L211.39150449884914,287.2709990290941L214.05105670642396,286.9455273317471L216.62481690730277,287.5680811770706L219.2843691148776,287.9746302859412L221.94392132245238,287.60695368735884L224.51768152333125,288.32033528705296L227.17723373090607,288.7120513713L229.75456859873057,288.1915055710412L232.41412080630533,287.85566090024116L235.07367301388015,288.52892594209413L237.56164120806304,288.5496284138471L240.2176187486922,289.1774077030765L242.79137894957105,288.56695869838234L245.45093115714582,289.3265119086L248.0246913580247,289.27854102333526L250.68424356559953,289.25959758248825L253.3437957731743,290.0094545349L255.91755597405316,289.9573381496647L258.5771081816279,290.0138972416941L261.1544430494524,290.41051902427057L263.8139952570273,290.4006124268294L266.47354746460206,290.60666953572354L268.875723652089,290.68882659192354L271.5317011927182,290.60218750778824L274.10546139359695,290.9437174465412L276.7650136011718,291.39289631036473L279.33877380205064,291.4234186887L281.99832600962543,292.1713602261706L284.6578782172003,291.78527198841175L287.2316384180791,292.1191388057294L289.8911906256539,291.8986399407353L292.4685254934784,292.0403939800941L295.12807770105326,293.01421073168825L297.787629908628,292.5075942048L300.1898060961149,293.0867765799529L302.8457836367441,293.68451752895294L305.41954383762294,292.7165265026294L308.07909604519773,293.1502946259L310.65285624607657,293.3619863082706L313.3124084536514,294.20943408744705L315.9719606612262,292.8119142213706L318.54572086210504,293.47152372494116L321.20527306967983,293.3766554404941L323.78260793750434,293.8039938479118L326.4421601450792,292.9888380874059L329.101712352654,292.4421642715941L331.5038885401409,293.15424908105297L334.15986608077003,292.6975759912235L336.73362628164887,293.2325658850588L339.3931784892237,293.1119578515L341.9669386901025,293.3783918005588L344.62649089767734,293.9533180515706L347.28604310525213,293.96462906855294L349.85980330613097,293.6523894136412L352.5193555137058,294.08764465944705L355.0966903815303,293.57540985884117L357.7562425891051,294.42985049994707L360.4157947966799,294.1512030497294L362.9037629908628,294.0436193838706L365.55974053149197,294.3255483441L368.1335007323708,295.12191094058824L370.7930529399456,295.02529755134117L373.36681314082443,295.0229976752647L376.0263653483993,294.8062744353529L378.6859175559741,294.8327067920647L381.2596777568529,294.67107989945293L383.9192299644277,295.19643790648234L386.4965648322522,295.41649354304116L389.156117039827,295.10404090468234L391.81566924740184,295.2985547988353L394.2178454348888,294.8670968122588L396.8738229755179,294.62803733892355L399.44758317639673,295.7251189532118L402.1071353839715,296.12177403398823L404.6808955848504,296.24758416174706L407.3404477924252,295.7053137493588L410,296.1016615507588" data-legend="vb.net" style="stroke: rgb(140, 86, 75); fill: none;"></path><path class="line" d="M2.6595522075748064,218.81590649219999L5.233312408453652,211.19591941581177L7.892864616028457,218.57799777813528L10.470199483852968,207.5637283614L13.129751691427774,211.09680943812356L15.789303899002581,203.93125206900004L18.191480086489502,212.33548379601177L20.847457627118647,212.21200661057645L23.421217827997488,201.0471131831294L26.080770035572296,201.90127963071177L28.65453023645114,203.68934315985882L31.314082444025946,198.90925059292942L33.973634651600754,205.31478114497648L36.5473948524796,199.82896432755882L39.206947060054404,196.89910278608824L41.784281927878915,191.32074760011176L44.44383413545372,196.2519602787353L47.10338634302853,195.27639254488236L49.50556253051545,198.36932729364707L52.16154007114459,193.30956911978825L54.73530027202343,189.5734046263059L57.394852479598235,189.416992614L59.96861268047709,186.79135094098234L62.62816488805189,188.44919279048824L65.2877170956267,184.04223823152353L67.86147729650554,185.54672720394709L70.52102950408035,184.1048349549706L73.09836437190486,173.68168601315296L75.75791657947967,179.72098284421764L78.41746878705447,180.4807292643353L80.81964497454139,181.04942132151177L83.47562251517054,172.54407873771177L86.04938271604938,170.9388936610941L88.70893492362418,162.6825673321765L91.28269512450304,157.32823648980005L93.94224733207784,152.92467340432944L96.60179953965265,157.88487635119418L99.17555974053148,159.76043643264705L101.8351119481063,158.9539803490765L104.41244681593082,157.7199172234059L107.07199902350561,153.78812006922354L109.73155123108043,157.33131172958826L112.21951942526331,158.21417567320592L114.87549696589245,153.4989621528706L117.44925716677129,148.37456800279415L120.1088093743461,147.88301037877062L122.68256957522495,146.3888910841941L125.34212178279977,144.21989654758238L128.00167399037457,150.37075679767057L130.5754341912534,153.04860572597647L133.2349863988282,152.05291107525883L135.8123212666527,146.2318822866L138.47187347422752,144.74998874837647L141.1314256818023,142.17682032848828L143.53360186928924,143.8230293679L146.1895794099184,141.53302902421765L148.76333961079723,139.93455233971767L151.42289181837205,136.4623977540706L153.9966520192509,131.35014336172944L156.6562042268257,124.70228788759414L159.3157564344005,110.69532297933529L161.88951663527936,110.28958543092355L164.54906884285415,114.2124891439588L167.12640371067866,107.09143601758237L169.78595591825348,102.0439365897L172.44550812582827,100.63736357435295L174.8476843133152,106.91028075356473L177.50366185394435,104.93568390118236L180.0774220548232,101.02120120672942L182.73697426239798,100.67590093551178L185.31073446327684,98.78218588351768L187.97028667085164,99.91609058609998L190.62983887842645,106.6122446950412L193.2035990793053,106.10699319937063L195.86315128688008,108.80680279478827L198.44048615470462,105.96967285810592L201.10003836227943,101.98090270858239L203.75959056985423,103.06606174958824L206.16176675734113,107.87709813802942L208.81774429797028,104.28925853151176L211.39150449884914,88.0602225727765L214.05105670642396,86.0842344099706L216.62481690730277,82.0282341075353L219.2843691148776,82.95626444463531L221.94392132245238,86.1325706433706L224.51768152333125,91.90952991414707L227.17723373090607,87.84036535891767L229.75456859873057,82.75252882290002L232.41412080630533,78.90043701963532L235.07367301388015,87.81343027565296L237.56164120806304,87.46735233737647L240.2176187486922,87.9476552706353L242.79137894957105,83.93617021277649L245.45093115714582,86.11526530759411L248.0246913580247,76.55916263998236L250.68424356559953,77.95662130634119L253.3437957731743,87.6360688777059L255.91755597405316,92.31287884224707L258.5771081816279,91.46010435123532L261.1544430494524,82.5689422239353L263.8139952570273,84.25049062978235L266.47354746460206,84.54302396114122L268.875723652089,90.41025701430002L271.5317011927182,88.20539651694708L274.10546139359695,86.23737703083532L276.7650136011718,84.34312588305883L279.33877380205064,85.86277007731766L281.99832600962543,85.5856006557353L284.6578782172003,91.2931936732059L287.2316384180791,91.94735766132354L289.8911906256539,95.40115252118824L292.4685254934784,91.91140754408826L295.12807770105326,89.84880042114708L297.787629908628,99.56651080757646L300.1898060961149,102.51465496902355L302.8457836367441,102.97010415795884L305.41954383762294,107.72693247742944L308.07909604519773,101.34699321421766L310.65285624607657,100.93781499834711L313.3124084536514,98.49955005991768L315.9719606612262,101.71733191736473L318.54572086210504,105.77505981667059L321.20527306967983,106.74789825531181L323.78260793750434,106.64697504529411L326.4421601450792,108.19889321251767L329.101712352654,108.18944324756472L331.5038885401409,107.63107061110591L334.15986608077003,111.39480957211765L336.73362628164887,109.23630746119414L339.3931784892237,105.08418133955294L341.9669386901025,108.76559034003535L344.62649089767734,101.42383721915294L347.28604310525213,105.40500996751766L349.85980330613097,113.02020013094119L352.5193555137058,110.55227247146468L355.0966903815303,107.47734480741175L357.7562425891051,105.12971531156472L360.4157947966799,106.4134040856706L362.9037629908628,99.41916747338826L365.55974053149197,96.27358241542942L368.1335007323708,94.7486863141059L370.7930529399456,94.13419492560001L373.36681314082443,86.44913896076471L376.0263653483993,83.1440070111353L378.6859175559741,88.78061913871764L381.2596777568529,98.00541956292352L383.9192299644277,101.59533827825294L386.4965648322522,93.2726795067L389.156117039827,92.0388157313647L391.81566924740184,99.51295558978234L394.2178454348888,105.19550756251766L396.8738229755179,99.10582120515886L399.44758317639673,98.19500163269998L402.1071353839715,100.01696017187649L404.6808955848504,94.7816717424353L407.3404477924252,92.91408938578235L410,92.90076988318236" data-legend="javascript" style="stroke: rgb(227, 119, 194); fill: none;"></path><path class="line" d="M2.6595522075748064,296.44263753017646L5.233312408453652,298.16520494661177L7.892864616028457,297.60937126464705L10.470199483852968,297.48974981174115L13.129751691427774,297.53046692885295L15.789303899002581,296.2504813571294L18.191480086489502,297.9086000110412L20.847457627118647,295.81961936241174L23.421217827997488,296.75224463661175L26.080770035572296,296.9127570339882L28.65453023645114,298.2409012449353L31.314082444025946,297.38699193778234L33.973634651600754,296.6549951173765L36.5473948524796,296.37345565570587L39.206947060054404,296.20373885428234L41.784281927878915,297.0767402825294L44.44383413545372,296.0036033517L47.10338634302853,297.2618685432353L49.50556253051545,295.8150074513294L52.16154007114459,295.5974664129353L54.73530027202343,296.30771755408233L57.394852479598235,297.0991485522882L59.96861268047709,297.16759376871175L62.62816488805189,297.6016576450059L65.2877170956267,296.60399045634705L67.86147729650554,296.57808639915885L70.52102950408035,295.7944354008353L73.09836437190486,296.7852741744529L75.75791657947967,297.02795716415295L78.41746878705447,296.8772703064941L80.81964497454139,296.62701061789414L83.47562251517054,297.0540061810412L86.04938271604938,297.2112069472765L88.70893492362418,297.51663763455883L91.28269512450304,297.52073962844116L93.94224733207784,297.37601246311766L96.60179953965265,297.3136775407941L99.17555974053148,296.3026007367L101.8351119481063,296.60892463971174L104.41244681593082,296.13156320634704L107.07199902350561,297.4135255371353L109.73155123108043,296.6877678696353L112.21951942526331,296.54858234011766L114.87549696589245,296.2143725825647L117.44925716677129,297.0272102341235L120.1088093743461,297.26744047101175L122.68256957522495,297.4918088633647L125.34212178279977,297.6317214002294L128.00167399037457,296.9851724079529L130.5754341912534,296.2744716944647L133.2349863988282,296.3710865422059L135.8123212666527,296.5427709865235L138.47187347422752,296.69202034295296L141.1314256818023,296.24781991388824L143.53360186928924,296.2751833324235L146.1895794099184,296.57910602017057L148.76333961079723,296.8006043066824L151.42289181837205,296.6798367717L153.9966520192509,297.0262997256353L156.6562042268257,297.7976108233059L159.3157564344005,296.90539141286473L161.88951663527936,296.35504310161764L164.54906884285415,295.8028270314L167.12640371067866,296.1762213661765L169.78595591825348,296.8186301021294L172.44550812582827,296.4733719204L174.8476843133152,296.1525060351353L177.50366185394435,296.68520529931766L180.0774220548232,296.68067823806473L182.73697426239798,297.0538952360823L185.31073446327684,297.8340063662294L187.97028667085164,298.0195069546412L190.62983887842645,296.9636673500647L193.2035990793053,295.99661162491765L195.86315128688008,295.89003125488233L198.44048615470462,296.26097483682355L201.10003836227943,296.434204308L203.75959056985423,296.2186830062647L206.16176675734113,296.39425097881764L208.81774429797028,295.88685870051177L211.39150449884914,296.4737227040118L214.05105670642396,297.4873446239118L216.62481690730277,297.63893433605296L219.2843691148776,297.8571554374588L221.94392132245238,297.4434972957L224.51768152333125,295.8844900848353L227.17723373090607,295.9949202570706L229.75456859873057,296.3761202798647L232.41412080630533,297.5672083225059L235.07367301388015,296.6982928287353L237.56164120806304,296.1655799538353L240.2176187486922,296.2780400448L242.79137894957105,296.96808510638823L245.45093115714582,297.21099633054706L248.0246913580247,297.9784115813294L250.68424356559953,297.47399833754116L253.3437957731743,296.5245766035353L255.91755597405316,295.9585647963353L258.5771081816279,295.8145734115765L261.1544430494524,296.56578084051176L263.8139952570273,296.9177202545824L266.47354746460206,296.9400514396765L268.875723652089,296.6960352423L271.5317011927182,296.8507860577588L274.10546139359695,296.66950199034704L276.7650136011718,297.6035906200588L279.33877380205064,297.8112881411118L281.99832600962543,297.83206898571177L284.6578782172003,297.48506321571176L287.2316384180791,296.51483827664117L289.8911906256539,295.9440525060882L292.4685254934784,296.97534971244704L295.12807770105326,297.1901356361294L297.787629908628,296.69589558100586L300.1898060961149,296.7236884536882L302.8457836367441,296.4804342479118L305.41954383762294,296.8526888245059L308.07909604519773,297.62050707072353L310.65285624607657,297.9661304850353L313.3124084536514,297.9648690676235L315.9719606612262,296.7696767169882L318.54572086210504,296.3755318473L321.20527306967983,296.32036413361766L323.78260793750434,296.8549556625L326.4421601450792,297.30980884168235L329.101712352654,297.25723703405293L331.5038885401409,296.9599096405412L334.15986608077003,296.43613756510587L336.73362628164887,297.18909368350586L339.3931784892237,297.38412139780587L341.9669386901025,297.7888558334118L344.62649089767734,297.81068412211766L347.28604310525213,297.12601384217646L349.85980330613097,296.29430468532354L352.5193555137058,296.6112109633412L355.0966903815303,296.69362097338234L357.7562425891051,297.2209929509647L360.4157947966799,296.68936021683527L362.9037629908628,296.6061158248412L365.55974053149197,296.31743633975293L368.1335007323708,296.6082037008706L370.7930529399456,296.59734489478234L373.36681314082443,297.0566115283941L376.0263653483993,296.8287159570706L378.6859175559741,296.2750337797235L381.2596777568529,295.94300321564117L383.9192299644277,295.49254789854706L386.4965648322522,296.50088409504707L389.156117039827,296.4663947399118L391.81566924740184,297.14116396318235L394.2178454348888,296.6567297244706L396.8738229755179,296.30744851152355L399.44758317639673,296.43577692774704L402.1071353839715,296.84540803348233L404.6808955848504,297.7532557206706L407.3404477924252,297.9853578543353L410,297.5403340737" data-legend="assembly" style="stroke: rgb(127, 127, 127); fill: none;"></path><path class="line" d="M2.6595522075748064,239.01664337442352L5.233312408453652,224.77340281092353L7.892864616028457,229.26551447737057L10.470199483852968,229.12234762535294L13.129751691427774,228.72029544596472L15.789303899002581,222.37483025828826L18.191480086489502,221.39821708152354L20.847457627118647,219.48586891999412L23.421217827997488,218.5988123811L26.080770035572296,200.57817550242353L28.65453023645114,188.51711639737061L31.314082444025946,180.99925783312943L33.973634651600754,177.79941840077646L36.5473948524796,184.34263983024707L39.206947060054404,175.55670780827649L41.784281927878915,166.7087867529353L44.44383413545372,164.08294567408237L47.10338634302853,174.3634175055353L49.50556253051545,172.44278808967061L52.16154007114459,170.51580651575293L54.73530027202343,163.45392510137648L57.394852479598235,169.5573173181L59.96861268047709,165.56290423840588L62.62816488805189,156.60143733215298L65.2877170956267,163.66618096958825L67.86147729650554,174.33509158487647L70.52102950408035,169.67847396628235L73.09836437190486,162.35360453260589L75.75791657947967,157.14232906134706L78.41746878705447,156.39721121701766L80.81964497454139,157.38579268764707L83.47562251517054,158.01792053599414L86.04938271604938,156.83607309698826L88.70893492362418,156.17937379964118L91.28269512450304,146.83094257611174L93.94224733207784,152.24804768726472L96.60179953965265,159.8086298542412L99.17555974053148,158.90584886707057L101.8351119481063,158.66192601183533L104.41244681593082,157.53245993385883L107.07199902350561,157.8504064315059L109.73155123108043,157.7881713337765L112.21951942526331,155.5032920706L114.87549696589245,156.87310832931178L117.44925716677129,155.83285029153532L120.1088093743461,156.54062472804708L122.68256957522495,153.31449347641768L125.34212178279977,150.77338706444118L128.00167399037457,152.54143266395295L130.5754341912534,160.33408330124118L133.2349863988282,158.67597755105297L135.8123212666527,154.8225725625353L138.47187347422752,154.96647013817648L141.1314256818023,154.4061480165706L143.53360186928924,155.57916306942354L146.1895794099184,161.06623029885884L148.76333961079723,160.22573632161178L151.42289181837205,157.33359218931176L153.9966520192509,156.04086685200002L156.6562042268257,150.466085803853L159.3157564344005,147.19036217948823L161.88951663527936,152.25454972154114L164.54906884285415,149.93353641374122L167.12640371067866,144.987432087L169.78595591825348,142.04498457037062L172.44550812582827,143.5963957547647L174.8476843133152,143.27420601458826L177.50366185394435,138.41056956347646L180.0774220548232,151.24223862014117L182.73697426239798,157.65204509678827L185.31073446327684,156.84478942117062L187.97028667085164,156.51706669139998L190.62983887842645,157.03667428177062L193.2035990793053,160.1373779956412L195.86315128688008,160.8876470482059L198.44048615470462,158.60101181670004L201.10003836227943,154.11198164292352L203.75959056985423,157.07885713644706L206.16176675734113,160.1230936704L208.81774429797028,159.48013633194705L211.39150449884914,160.18167176761764L214.05105670642396,163.7403992477294L216.62481690730277,159.87983386574118L219.2843691148776,160.18673080198235L221.94392132245238,164.6851107684706L224.51768152333125,167.05569243931765L227.17723373090607,166.81615422015884L229.75456859873057,157.9377379029L232.41412080630533,156.5928163978059L235.07367301388015,158.94163619401766L237.56164120806304,166.27129535525293L240.2176187486922,168.9815892468L242.79137894957105,164.0613266583353L245.45093115714582,168.10618287051176L248.0246913580247,169.75338297568237L250.68424356559953,173.60200983575294L253.3437957731743,173.7331995266647L255.91755597405316,175.23338103626472L258.5771081816279,178.41945288755295L261.1544430494524,173.94331014840003L263.8139952570273,172.66961352308823L266.47354746460206,172.7427372815647L268.875723652089,175.56243963345884L271.5317011927182,176.04454742507647L274.10546139359695,175.47372914622355L276.7650136011718,182.42616479641765L279.33877380205064,183.1960739197059L281.99832600962543,182.95179866345296L284.6578782172003,182.4239597698059L287.2316384180791,186.5281579437706L289.8911906256539,188.1928032391412L292.4685254934784,187.92874723965883L295.12807770105326,187.42772651246472L297.787629908628,193.59387670339413L300.1898060961149,198.49615926308823L302.8457836367441,201.901698492L305.41954383762294,199.1265502634118L308.07909604519773,202.38303521650587L310.65285624607657,204.22933108044708L313.3124084536514,203.97780020712355L315.9719606612262,204.55750941254118L318.54572086210504,208.3574841388059L321.20527306967983,214.67992707199411L323.78260793750434,215.15100468935293L326.4421601450792,213.1520588890059L329.101712352654,210.6590676556412L331.5038885401409,213.40180563615883L334.15986608077003,216.22593956108824L336.73362628164887,217.7042217923294L339.3931784892237,220.84009576658826L341.9669386901025,221.0136736209353L344.62649089767734,224.1819060861706L347.28604310525213,227.10526017848824L349.85980330613097,228.72673711775295L352.5193555137058,226.61228848609414L355.0966903815303,229.43703296837649L357.7562425891051,228.1462849894059L360.4157947966799,230.04740754427058L362.9037629908628,235.03786800296473L365.55974053149197,235.02558523452353L368.1335007323708,237.32798860764706L370.7930529399456,238.19371760239412L373.36681314082443,235.8662410110706L376.0263653483993,239.8892084993647L378.6859175559741,239.6480220471353L381.2596777568529,242.7744156280059L383.9192299644277,239.72516605921766L386.4965648322522,238.12266283094118L389.156117039827,239.89678041021176L391.81566924740184,241.3826939169353L394.2178454348888,245.1605343332647L396.8738229755179,244.95622227222353L399.44758317639673,244.33908079489413L402.1071353839715,244.7889871950706L404.6808955848504,245.25472316228823L407.3404477924252,243.9519316839353L410,243.12602655280588" data-legend="php" style="stroke: rgb(188, 189, 34); fill: none;"></path><path class="line" d="M2.6595522075748064,283.35662558761766L5.233312408453652,284.46540188128233L7.892864616028457,286.3593536865L10.470199483852968,280.21332204541767L13.129751691427774,283.3867775212765L15.789303899002581,283.2791736196059L18.191480086489502,287.9744500634824L20.847457627118647,286.5391743469588L23.421217827997488,286.4561691228353L26.080770035572296,284.4377752529294L28.65453023645114,285.8172662872412L31.314082444025946,286.3361453413235L33.973634651600754,286.51207708618233L36.5473948524796,286.1799256068353L39.206947060054404,285.0464347552412L41.784281927878915,287.6940195764118L44.44383413545372,288.05037833874707L47.10338634302853,286.19029352241176L49.50556253051545,286.66246277172354L52.16154007114459,287.04092936064706L54.73530027202343,290.2222890783706L57.394852479598235,286.9621072295118L59.96861268047709,287.29797205554706L62.62816488805189,284.74542711411175L65.2877170956267,286.64816760614116L67.86147729650554,286.1176025461412L70.52102950408035,288.1479543114353L73.09836437190486,287.21763778884707L75.75791657947967,289.3760558330118L78.41746878705447,289.6693257399353L80.81964497454139,289.3891375687941L83.47562251517054,289.7723988171706L86.04938271604938,289.7273572361647L88.70893492362418,289.8700254589412L91.28269512450304,288.41253485911767L93.94224733207784,289.88362037668236L96.60179953965265,291.33444367995884L99.17555974053148,290.3204877776647L101.8351119481063,290.16750397925296L104.41244681593082,290.8316343833118L107.07199902350561,291.43420516118823L109.73155123108043,291.2482832072823L112.21951942526331,291.95991594938823L114.87549696589245,291.77037517946474L117.44925716677129,291.52886456092943L120.1088093743461,289.98963340865294L122.68256957522495,291.67679856647646L125.34212178279977,290.4391715786647L128.00167399037457,291.1029087949941L130.5754341912534,291.8866272457235L133.2349863988282,292.3828747222588L135.8123212666527,292.78434399081175L138.47187347422752,292.56267158738825L141.1314256818023,291.33755955428825L143.53360186928924,291.30535944991766L146.1895794099184,291.3289122384L148.76333961079723,290.38055447689413L151.42289181837205,290.74378736348825L153.9966520192509,290.42808935253527L156.6562042268257,291.29432957507646L159.3157564344005,292.67965003178824L161.88951663527936,292.18252665215294L164.54906884285415,291.7759450901647L167.12640371067866,291.83975732892355L169.78595591825348,292.40214012624705L172.44550812582827,292.5141441297L174.8476843133152,292.2624512962941L177.50366185394435,292.5349007014765L180.0774220548232,292.0075545490412L182.73697426239798,292.6184312372647L185.31073446327684,292.6935145625647L187.97028667085164,292.60832377057056L190.62983887842645,292.76607063398825L193.2035990793053,293.4573780775412L195.86315128688008,293.03323127442354L198.44048615470462,293.5365022331647L201.10003836227943,293.70113934645883L203.75959056985423,294.0383693079353L206.16176675734113,294.01221470835884L208.81774429797028,294.60617606862354L211.39150449884914,294.93515727134115L214.05105670642396,294.5307238242353L216.62481690730277,294.75116940859414L219.2843691148776,294.5890728625941L221.94392132245238,295.35635250977646L224.51768152333125,295.2462049822588L227.17723373090607,295.3772213912471L229.75456859873057,295.0789360618588L232.41412080630533,295.62489883805296L235.07367301388015,295.28327546961174L237.56164120806304,295.86587815711766L240.2176187486922,295.54629549051174L242.79137894957105,295.4380475594647L245.45093115714582,295.7537660395941L248.0246913580247,295.74561243234706L250.68424356559953,295.4864854015765L253.3437957731743,295.1862792359294L255.91755597405316,295.8773299178647L258.5771081816279,296.18029029794116L261.1544430494524,296.2914821856L263.8139952570273,296.7162640620706L266.47354746460206,295.9031253494647L268.875723652089,296.3426700275647L271.5317011927182,296.3026633779353L274.10546139359695,296.61224414491767L276.7650136011718,296.8547126888294L279.33877380205064,296.71198037488233L281.99832600962543,296.4269285134941L284.6578782172003,296.7272875034118L287.2316384180791,296.51483827664117L289.8911906256539,297.2082439327765L292.4685254934784,297.0978051896647L295.12807770105326,297.2789851021765L297.787629908628,297.3125066169353L300.1898060961149,297.0224715821294L302.8457836367441,297.21504766034116L305.41954383762294,297.4268604578647L308.07909604519773,297.23932616458234L310.65285624607657,297.2620987298471L313.3124084536514,297.44765347155885L315.9719606612262,297.4477980168529L318.54572086210504,296.8964798692412L321.20527306967983,297.17498923807057L323.78260793750434,297.02968034791763L326.4421601450792,296.8336688136706L329.101712352654,296.9159154205059L331.5038885401409,297.42590889271764L334.15986608077003,297.5891518822765L336.73362628164887,297.3780621753706L339.3931784892237,296.8977520094647L341.9669386901025,297.1976408155941L344.62649089767734,297.4588297846059L347.28604310525213,297.40034888451174L349.85980330613097,297.5568128682353L352.5193555137058,297.3202129249059L355.0966903815303,297.87639070648237L357.7562425891051,297.9976586764588L360.4157947966799,297.7929068112176L362.9037629908628,297.7222253858118L365.55974053149197,297.8623641022412L368.1335007323708,297.9515836957588L370.7930529399456,297.9418590700941L373.36681314082443,298.11623137817645L376.0263653483993,297.70231495757645L378.6859175559741,297.93057432206473L381.2596777568529,298.09211502573527L383.9192299644277,298.34397745178825L386.4965648322522,298.53551379058234L389.156117039827,298.4460651567176L391.81566924740184,298.51474534025294L394.2178454348888,298.48569522815296L396.8738229755179,298.4605397584588L399.44758317639673,298.66614964780587L402.1071353839715,298.2248353450059L404.6808955848504,298.3531717324412L407.3404477924252,298.5644166746471L410,298.5729296748353" data-legend="perl" style="stroke: rgb(23, 190, 207); fill: none;"></path><path class="line" d="M2.6595522075748064,263.2829373650118L5.233312408453652,269.54240211368824L7.892864616028457,277.6405900634294L10.470199483852968,276.22645409934705L13.129751691427774,276.76393883041766L15.789303899002581,270.91589593228235L18.191480086489502,271.24325015177646L20.847457627118647,270.06847463484706L23.421217827997488,272.22132646621765L26.080770035572296,272.7818579322353L28.65453023645114,272.5140819520235L31.314082444025946,273.59773103800586L33.973634651600754,274.2650430804353L36.5473948524796,275.8393734899647L39.206947060054404,269.7225025694294L41.784281927878915,272.9834222884412L44.44383413545372,272.9352939857647L47.10338634302853,272.6980515615353L49.50556253051545,276.35309088352943L52.16154007114459,273.26525974948237L54.73530027202343,273.4702668699706L57.394852479598235,272.8085023637294L59.96861268047709,273.369541413L62.62816488805189,272.2517367066353L65.2877170956267,272.8319236507412L67.86147729650554,274.2382764683647L70.52102950408035,276.32139689315295L73.09836437190486,273.8994879401118L75.75791657947967,273.29597332554704L78.41746878705447,273.24291200961176L80.81964497454139,271.20661668084705L83.47562251517054,272.6522837937L86.04938271604938,272.3768283068471L88.70893492362418,272.1649024074353L91.28269512450304,272.16546689221764L93.94224733207784,269.30429673834703L96.60179953965265,273.1541065204941L99.17555974053148,271.81605089855293L101.8351119481063,271.75185549151763L104.41244681593082,271.2508684101L107.07199902350561,270.97062779315297L109.73155123108043,270.7752621945882L112.21951942526331,271.00015736348826L114.87549696589245,272.9519664231353L117.44925716677129,273.9683586429706L120.1088093743461,274.41945510238236L122.68256957522495,274.29416049014117L125.34212178279977,274.1744857452353L128.00167399037457,273.75090109847645L130.5754341912534,273.2589857180294L133.2349863988282,274.4778396747L135.8123212666527,275.05294973225296L138.47187347422752,274.04248616050586L141.1314256818023,274.27903712574704L143.53360186928924,273.87525844104704L146.1895794099184,274.53449315304704L148.76333961079723,275.0851046340706L151.42289181837205,275.1267232895647L153.9966520192509,275.5095256864765L156.6562042268257,274.194647571L159.3157564344005,274.4534725599L161.88951663527936,273.2479347642353L164.54906884285415,274.1959007944588L167.12640371067866,273.85304442562943L169.78595591825348,274.09054927288236L172.44550812582827,275.4546685659353L174.8476843133152,274.88914337080587L177.50366185394435,275.0346010077L180.0774220548232,273.11449654447057L182.73697426239798,274.5830518891412L185.31073446327684,274.4173194315L187.97028667085164,273.2795774371059L190.62983887842645,275.7093388003941L193.2035990793053,276.00014743937646L195.86315128688008,277.5279228303L198.44048615470462,275.5253444349L201.10003836227943,274.0465589004L203.75959056985423,276.21667473021176L206.16176675734113,277.00167334155884L208.81774429797028,276.58313873812943L211.39150449884914,276.0614508767647L214.05105670642396,275.64802421218235L216.62481690730277,276.5255586871765L219.2843691148776,277.3386849001059L221.94392132245238,278.3995494164118L224.51768152333125,279.09854455120586L227.17723373090607,280.49267130185297L229.75456859873057,279.11121604501767L232.41412080630533,278.95831391842944L235.07367301388015,278.7747396132353L237.56164120806304,280.06101575991175L240.2176187486922,279.99898218248825L242.79137894957105,280.0250312891118L245.45093115714582,279.60842645828825L248.0246913580247,280.8703424262353L250.68424356559953,281.5934762580353L253.3437957731743,280.0189090698L255.91755597405316,281.5089107892176L258.5771081816279,282.1306665799941L261.1544430494524,282.1376715921L263.8139952570273,281.6372680525765L266.47354746460206,283.44984632484704L268.875723652089,284.17807251054705L271.5317011927182,285.1608241771941L274.10546139359695,285.4946791556647L276.7650136011718,285.85119961925295L279.33877380205064,284.92660882702944L281.99832600962543,286.00881558368826L284.6578782172003,286.57968231261174L287.2316384180791,286.40472949355296L289.8911906256539,287.6003890900412L292.4685254934784,287.4850502271706L295.12807770105326,287.0835088727471L297.787629908628,288.00517022537645L300.1898060961149,289.04805291278825L302.8457836367441,289.1562288821647L305.41954383762294,289.0056765017824L308.07909604519773,288.54147094247645L310.65285624607657,289.47304899391764L313.3124084536514,290.09419695345883L315.9719606612262,290.3830070200059L318.54572086210504,289.98006357783527L321.20527306967983,290.0768529538412L323.78260793750434,289.11330806248236L326.4421601450792,289.0606828562294L329.101712352654,290.4186147056118L331.5038885401409,290.63563407520587L334.15986608077003,291.0670506942L336.73362628164887,291.0358071671118L339.3931784892237,290.74583650277646L341.9669386901025,291.03718033004117L344.62649089767734,289.8483507805412L347.28604310525213,290.59422711981176L349.85980330613097,290.0635930047706L352.5193555137058,291.7803840387353L355.0966903815303,291.0082619154L357.7562425891051,290.70428209794704L360.4157947966799,291.98089474741766L362.9037629908628,291.8911223734412L365.55974053149197,292.50855783098825L368.1335007323708,293.35932016715293L370.7930529399456,293.63941370908236L373.36681314082443,292.5291448974882L376.0263653483993,293.37022128382944L378.6859175559741,293.51579954248234L381.2596777568529,294.17766137161766L383.9192299644277,293.6062175787L386.4965648322522,293.75078022088235L389.156117039827,293.74168706945295L391.81566924740184,293.26610105391177L394.2178454348888,294.4049388624176L396.8738229755179,293.4868989780353L399.44758317639673,295.12379297477645L402.1071353839715,294.68581281624705L404.6808955848504,294.11847047295885L407.3404477924252,293.8716274850294L410,293.89724397527647" data-legend="ruby" style="stroke: rgb(31, 119, 180); fill: none;"></path><path class="line" d="M2.6595522075748064,300L5.233312408453652,300L7.892864616028457,300L10.470199483852968,300L13.129751691427774,299.88774849677645L15.789303899002581,299.89866165831177L18.191480086489502,299.9128583338059L20.847457627118647,300L23.421217827997488,299.86179764412356L26.080770035572296,299.93699504151175L28.65453023645114,300L31.314082444025946,299.83668699612355L33.973634651600754,299.8920966166941L36.5473948524796,299.95099264401176L39.206947060054404,299.86111239711175L41.784281927878915,299.9528506497353L44.44383413545372,300L47.10338634302853,299.9206338708353L49.50556253051545,299.96597567034706L52.16154007114459,299.9289913937647L54.73530027202343,299.96581219958824L57.394852479598235,299.93624502314117L59.96861268047709,299.9707999357765L62.62816488805189,299.9442245964L65.2877170956267,299.94194855481174L67.86147729650554,299.9721795642353L70.52102950408035,299.9745117297176L73.09836437190486,299.94897260595883L75.75791657947967,299.93346172755884L78.41746878705447,299.89305720229413L80.81964497454139,299.9472970409118L83.47562251517054,299.9444152109647L86.04938271604938,299.9823494110588L88.70893492362418,299.9285363348118L91.28269512450304,299.78899911732356L93.94224733207784,299.86797546984707L96.60179953965265,299.8960133241706L99.17555974053148,299.8953566246294L101.8351119481063,299.93509903618235L104.41244681593082,299.9659168564588L107.07199902350561,299.90871266602943L109.73155123108043,299.8715082363353L112.21951942526331,299.9471047102059L114.87549696589245,299.9314197931765L117.44925716677129,299.9210763779118L120.1088093743461,299.9458899103235L122.68256957522495,299.8876929341823L125.34212178279977,299.937347127L128.00167399037457,299.90620536381175L130.5754341912534,299.9526917040706L133.2349863988282,299.95209355171767L135.8123212666527,299.9607133066765L138.47187347422752,299.94374184257646L141.1314256818023,299.9305151836059L143.53360186928924,299.9489751141529L146.1895794099184,299.93798983722354L148.76333961079723,299.9787415568647L151.42289181837205,299.9552839969412L153.9966520192509,299.92991278815884L156.6562042268257,299.9584454872412L159.3157564344005,299.89328935907645L161.88951663527936,299.9136720734647L164.54906884285415,299.9398972844647L167.12640371067866,299.88250959506473L169.78595591825348,299.95321514857056L172.44550812582827,299.8871479014529L174.8476843133152,299.96595138084706L177.50366185394435,299.95459185342355L180.0774220548232,299.90974653820587L182.73697426239798,273.8003229481765L185.31073446327684,283.5803708407412L187.97028667085164,281.5803324414529L190.62983887842645,279.69385954102944L193.2035990793053,274.7407695106412L195.86315128688008,272.7701295543L198.44048615470462,271.59252833338235L201.10003836227943,267.3526849516412L203.75959056985423,265.8417520593706L206.16176675734113,266.3432286960353L208.81774429797028,262.35540906125294L211.39150449884914,263.56180127468826L214.05105670642396,259.0418281551706L216.62481690730277,253.17825167931176L219.2843691148776,250.15684839425293L221.94392132245238,254.4523092409588L224.51768152333125,258.8925340649118L227.17723373090607,256.9005597813L229.75456859873057,254.87652041659413L232.41412080630533,252.95294804322353L235.07367301388015,255.05904867441177L237.56164120806304,255.1769518740706L240.2176187486922,256.9083762468L242.79137894957105,258.32290362954706L245.45093115714582,253.61954451421764L248.0246913580247,250.25484418515882L250.68424356559953,251.9080613720647L253.3437957731743,249.4040599861588L255.91755597405316,251.9292606678353L258.5771081816279,255.6365099231294L261.1544430494524,256.7595600396L263.8139952570273,256.23364217687646L266.47354746460206,258.6449476962353L268.875723652089,259.17748356852354L271.5317011927182,260.8939382614588L274.10546139359695,260.8547196687706L276.7650136011718,257.9929405773706L279.33877380205064,256.8695016042353L281.99832600962543,257.9561897274353L284.6578782172003,258.487069674L287.2316384180791,259.1199949205294L289.8911906256539,261.2630677009765L292.4685254934784,260.7040373571L295.12807770105326,258.2629633222059L297.787629908628,260.2576736080059L300.1898060961149,258.1188476862L302.8457836367441,260.75848652094703L305.41954383762294,261.424172484L308.07909604519773,263.5336933118647L310.65285624607657,258.8867805186706L313.3124084536514,259.57847678509415L315.9719606612262,261.13748477823526L318.54572086210504,263.4893024616882L321.20527306967983,264.41436023398234L323.78260793750434,262.4207522749059L326.4421601450792,265.1584534495765L329.101712352654,267.13560463905884L331.5038885401409,267.15814794146473L334.15986608077003,264.0352705915059L336.73362628164887,263.19838620908826L339.3931784892237,259.27642256474115L341.9669386901025,263.91223531304115L344.62649089767734,266.7041543572059L347.28604310525213,266.5180612612059L349.85980330613097,263.6444402880529L352.5193555137058,265.2108359533765L355.0966903815303,264.0061665313059L357.7562425891051,264.7102510976647L360.4157947966799,266.0720730368118L362.9037629908628,266.6647685211706L365.55974053149197,266.33223461008237L368.1335007323708,266.3106974333647L370.7930529399456,267.0800875382294L373.36681314082443,267.8689011207L376.0263653483993,267.6409356524647L378.6859175559741,267.62916560758237L381.2596777568529,270.9979554198353L383.9192299644277,271.2992648429824L386.4965648322522,272.6778298028647L389.156117039827,270.54974170268827L391.81566924740184,269.56903046745884L394.2178454348888,271.4248722919941L396.8738229755179,272.7956920950353L399.44758317639673,275.83762886599413L402.1071353839715,275.96178307941176L404.6808955848504,273.1802253567L407.3404477924252,273.2185295605588L410,276.1806879871235" data-legend="swift" style="stroke: rgb(255, 127, 14); fill: none;"></path><path class="line" d="M2.6595522075748064,299.2377080421882L5.233312408453652,300L7.892864616028457,299.8593747802765L10.470199483852968,299.8523382242294L13.129751691427774,299.1019879741235L15.789303899002581,299.0879549247176L18.191480086489502,299.65143333518824L20.847457627118647,298.99670864698237L23.421217827997488,299.86179764412356L26.080770035572296,299.6849752075588L28.65453023645114,297.1964363591118L31.314082444025946,297.44142960575294L33.973634651600754,292.5546665515765L36.5473948524796,296.4224630117118L39.206947060054404,295.6481884427118L41.784281927878915,296.2280519774471L44.44383413545372,296.2805813372294L47.10338634302853,295.1586661199294L49.50556253051545,295.2706181767059L52.16154007114459,294.3193115005588L54.73530027202343,295.24789574089414L57.394852479598235,294.38956203518825L59.96861268047709,293.16718496781175L62.62816488805189,292.1077803899294L65.2877170956267,293.1499294675059L67.86147729650554,294.0464267432294L70.52102950408035,293.83183858789414L73.09836437190486,294.31044556270587L75.75791657947967,294.45514396295295L78.41746878705447,293.1128838266294L80.81964497454139,292.58645042057645L83.47562251517054,291.1805468061L86.04938271604938,292.4631985220647L88.70893492362418,292.06753316361176L91.28269512450304,292.0171332716824L93.94224733207784,290.32920316595295L96.60179953965265,289.3933590642706L99.17555974053148,289.16941064851767L101.8351119481063,290.15127873829414L104.41244681593082,289.5364749281647L107.07199902350561,289.5019565918647L109.73155123108043,288.3929106811059L112.21951942526331,288.24402184048233L114.87549696589245,288.4373771271353L117.44925716677129,288.47715117294706L120.1088093743461,286.8241931622L122.68256957522495,286.02400958687645L125.34212178279977,286.35420425839413L128.00167399037457,285.7968122329765L130.5754341912534,285.0269243339294L133.2349863988282,283.8914567632412L135.8123212666527,284.0888891993118L138.47187347422752,283.02128808677645L141.1314256818023,280.7874482627647L143.53360186928924,281.1309972099706L146.1895794099184,281.0042201360824L148.76333961079723,281.0587271578059L151.42289181837205,280.12373663318823L153.9966520192509,280.23540625718823L156.6562042268257,280.03305661491174L159.3157564344005,281.7097961435647L161.88951663527936,279.9143690915471L164.54906884285415,278.06250882758826L167.12640371067866,279.61007426818236L169.78595591825348,277.96433497205294L172.44550812582827,275.3606251504765L174.8476843133152,276.04679642218235L177.50366185394435,275.11633567155883L180.0774220548232,274.06717197464116L182.73697426239798,273.90903530108824L185.31073446327684,273.6587225828118L187.97028667085164,273.1929985061647L190.62983887842645,274.7611507097118L193.2035990793053,271.5360110415706L195.86315128688008,271.24083885843527L198.44048615470462,273.0972579722294L201.10003836227943,271.29214186884707L203.75959056985423,268.6540407427412L206.16176675734113,266.68885748823527L208.81774429797028,268.88034684998826L211.39150449884914,267.23142317622353L214.05105670642396,267.5716319319L216.62481690730277,263.8212092107059L219.2843691148776,265.81233378278824L221.94392132245238,266.7355058280353L224.51768152333125,264.91337264451175L227.17723373090607,264.7214244534529L229.75456859873057,267.2512460518412L232.41412080630533,265.3032896640706L235.07367301388015,266.05845027928234L237.56164120806304,264.3354861912529L240.2176187486922,262.69909549748826L242.79137894957105,264.32102628285884L245.45093115714582,262.70069487045885L248.0246913580247,262.3340864281059L250.68424356559953,262.92260350487646L253.3437957731743,265.76448594511766L255.91755597405316,261.5352850464353L258.5771081816279,263.8143458544L261.1544430494524,265.4164255886294L263.8139952570273,264.81567597787057L266.47354746460206,262.56900133175293L268.875723652089,259.32766378478823L271.5317011927182,257.5055435134765L274.10546139359695,258.7934372330118L276.7650136011718,255.56657608018236L279.33877380205064,254.58175300965883L281.99832600962543,254.12216358178233L284.6578782172003,253.6109476992L287.2316384180791,252.44271810520587L289.8911906256539,252.43479757136473L292.4685254934784,254.45880801840002L295.12807770105326,253.35403032285882L297.787629908628,247.564793604L300.1898060961149,247.3935636619412L302.8457836367441,248.0726996823706L305.41954383762294,249.67491961598824L308.07909604519773,248.14784582735294L310.65285624607657,250.75130245875883L313.3124084536514,253.5742783437L315.9719606612262,253.23428926517647L318.54572086210504,251.37448995125294L321.20527306967983,249.32785318175294L323.78260793750434,253.85924268945882L326.4421601450792,252.5883567098294L329.101712352654,248.07035451127058L331.5038885401409,250.0604134744941L334.15986608077003,246.42559738371176L336.73362628164887,249.2619599339647L339.3931784892237,248.02420103970002L341.9669386901025,250.2078712002706L344.62649089767734,248.4859186591059L347.28604310525213,248.45113918715293L349.85980330613097,248.72813990461765L352.5193555137058,248.42311154124707L355.0966903815303,249.65164295228823L357.7562425891051,249.60167565631764L360.4157947966799,242.4316526591294L362.9037629908628,241.6092477649412L365.55974053149197,240.0004469602412L368.1335007323708,242.6252884456059L370.7930529399456,243.62348638731177L373.36681314082443,247.08322689566472L376.0263653483993,246.0403028317059L378.6859175559741,240.12461705174118L381.2596777568529,238.04856261700587L383.9192299644277,237.8936709231L386.4965648322522,244.1930140654059L389.156117039827,246.33603095950588L391.81566924740184,243.75016750994118L394.2178454348888,240.18496151142352L396.8738229755179,239.57349415491177L399.44758317639673,240.94978891637646L402.1071353839715,243.9975125081294L404.6808955848504,244.9018313906647L407.3404477924252,244.6154365822059L410,247.87132543895294" data-legend="r" style="stroke: rgb(44, 160, 44); fill: none;"></path><path class="line" d="M2.6595522075748064,293.52051835854706L5.233312408453652,288.9912296796529L7.892864616028457,284.9531014892294L10.470199483852968,281.837601579L13.129751691427774,283.9480350374471L15.789303899002581,278.9216249265353L18.191480086489502,274.72891680005296L20.847457627118647,270.06847463484706L23.421217827997488,265.4494110276353L26.080770035572296,269.0645653813059L28.65453023645114,262.61915145474705L31.314082444025946,261.94807009395885L33.973634651600754,262.6114776828882L36.5473948524796,263.39150506491177L39.206947060054404,265.00032407108824L41.784281927878915,263.12920807951764L44.44383413545372,260.8273991899059L47.10338634302853,259.95978782788234L49.50556253051545,261.55250747968233L52.16154007114459,259.02803419775296L54.73530027202343,255.3507326445706L57.394852479598235,254.3514365590235L59.96861268047709,243.58547588805882L62.62816488805189,247.87788533135296L65.2877170956267,252.10755771765884L67.86147729650554,251.64808261558235L70.52102950408035,253.35646535465293L73.09836437190486,253.23339334722354L75.75791657947967,251.60449650859414L78.41746878705447,247.98302318735296L80.81964497454139,246.4362259059706L83.47562251517054,240.1166539439294L86.04938271604938,238.15233634962354L88.70893492362418,240.0598508196L91.28269512450304,234.73039362215295L93.94224733207784,236.49620099415884L96.60179953965265,242.80732828768237L99.17555974053148,242.9693604196941L101.8351119481063,241.99476357391765L104.41244681593082,243.37085698088825L107.07199902350561,242.6106960355059L109.73155123108043,244.8342027942706L112.21951942526331,249.22052178559412L114.87549696589245,246.3016980459353L117.44925716677129,249.10741768048237L120.1088093743461,248.62246984604118L122.68256957522495,246.21739403516472L125.34212178279977,247.25881150007646L128.00167399037457,254.57659761298237L130.5754341912534,251.21331980842942L133.2349863988282,253.8421370747294L135.8123212666527,251.23211800676472L138.47187347422752,254.17210495522943L141.1314256818023,254.84645013654705L143.53360186928924,254.89400090212942L146.1895794099184,258.0191198002059L148.76333961079723,259.3432274851941L151.42289181837205,262.2708724054941L153.9966520192509,262.2530301872471L156.6562042268257,263.0580381491294L159.3157564344005,257.8066125738706L161.88951663527936,257.14298046847057L164.54906884285415,259.6009580373L167.12640371067866,257.2762163817353L169.78595591825348,258.7170470899059L172.44550812582827,256.8810940133294L174.8476843133152,257.31154373034707L177.50366185394435,257.58879108984706L180.0774220548232,258.1725345345L182.73697426239798,259.13502654031765L185.31073446327684,258.2472287093118L187.97028667085164,259.9139549724706L190.62983887842645,260.0269470083647L193.2035990793053,262.20842329297056L195.86315128688008,265.18739652065295L198.44048615470462,265.3114220379176L201.10003836227943,268.003923087L203.75959056985423,266.5685232921529L206.16176675734113,269.3137680451059L208.81774429797028,268.37555223596473L211.39150449884914,270.0314211375353L214.05105670642396,270.46213022168826L216.62481690730277,269.8600886973706L219.2843691148776,270.75359635854704L221.94392132245238,271.23934457662943L224.51768152333125,272.97291289505296L227.17723373090607,276.65696060278236L229.75456859873057,276.7124547529941L232.41412080630533,276.7707633374471L235.07367301388015,277.99176334118823L237.56164120806304,279.8935353441L240.2176187486922,279.90864334861766L242.79137894957105,281.2265331664588L245.45093115714582,279.92689400532356L248.0246913580247,281.1720720409765L250.68424356559953,282.26903484218826L253.3437957731743,282.57101102661176L255.91755597405316,283.44839351258827L258.5771081816279,284.1014742454059L261.1544430494524,283.5530526514588L263.8139952570273,285.27355232742354L266.47354746460206,286.3979695225059L268.875723652089,287.1905109661059L271.5317011927182,288.6189799935353L274.10546139359695,288.69157552597056L276.7650136011718,287.7683271232059L279.33877380205064,289.04653703198824L281.99832600962543,290.1037963884706L284.6578782172003,290.2148092803L287.2316384180791,291.0202139380059L289.8911906256539,291.44563801284704L292.4685254934784,292.1628494573294L295.12807770105326,292.6254943177235L297.787629908628,293.1009368997529L300.1898060961149,293.8079772348L302.8457836367441,293.9147694940412L305.41954383762294,293.8010729212235L308.07909604519773,294.4208976463941L310.65285624607657,294.3230455296353L313.3124084536514,294.6929182315941L315.9719606612262,294.87093707733527L318.54572086210504,295.3779718052647L321.20527306967983,295.96427034008826L323.78260793750434,296.3442219666706L326.4421601450792,296.16707277444704L329.101712352654,296.4526932307059L331.5038885401409,296.64924347241174L334.15986608077003,296.30802486319413L336.73362628164887,296.72848298458234L339.3931784892237,296.6348496373765L341.9669386901025,297.1148707131L344.62649089767734,297.2242602262588L347.28604310525213,296.73410663883527L349.85980330613097,296.2475451229941L352.5193555137058,296.63524492814116L355.0966903815303,296.61297758248236L357.7562425891051,296.74771227448235L360.4157947966799,296.8978079068765L362.9037629908628,297.2666704629706L365.55974053149197,297.1919237524765L368.1335007323708,297.4085151871941L370.7930529399456,297.68329865177645L373.36681314082443,296.9281727587235L376.0263653483993,297.5347754232353L378.6859175559741,297.1404299723118L381.2596777568529,296.91887541511767L383.9192299644277,297.181471557L386.4965648322522,297.7306053396L389.156117039827,297.9351824685L391.81566924740184,297.3533432002941L394.2178454348888,297.72854284221177L396.8738229755179,297.5670068909823L399.44758317639673,298.07575686898235L402.1071353839715,297.88563190775295L404.6808955848504,298.1061474922941L407.3404477924252,298.22663236279413L410,298.30607912622355" data-legend="objective-c" style="stroke: rgb(214, 39, 40); fill: none;"></path></g></g><g transform="translate(20, 150)"><text transform="rotate(-90)" x="-50" y="0" dy="1em" class="axis-label y-axis-label" style="text-anchor: middle; font-weight: bold;">% of Stack Overflow questions that month</text></g><g class="legend" transform="translate(530, 30)" style="font-size: 12px;"><text class="legend-title" style="font-weight: bold;">Tag</text><g class="legend-items" transform="translate(0,20)"><text y="0em" x="1em">python</text><text y="1em" x="1em">c#</text><text y="2em" x="1em">javascript</text><text y="3em" x="1em">java</text><text y="4em" x="1em">php</text><text y="5em" x="1em">c++</text><text y="6em" x="1em">objective-c</text><text y="7em" x="1em">r</text><text y="8em" x="1em">swift</text><text y="9em" x="1em">c</text><text y="10em" x="1em">ruby</text><text y="11em" x="1em">vb.net</text><text y="12em" x="1em">perl</text><text y="13em" x="1em">assembly</text><circle cy="-0.25em" cx="0" r="0.4em" style="fill: rgb(214, 39, 40);"></circle><circle cy="0.75em" cx="0" r="0.4em" style="fill: rgb(148, 103, 189);"></circle><circle cy="1.75em" cx="0" r="0.4em" style="fill: rgb(227, 119, 194);"></circle><circle cy="2.75em" cx="0" r="0.4em" style="fill: rgb(31, 119, 180);"></circle><circle cy="3.75em" cx="0" r="0.4em" style="fill: rgb(188, 189, 34);"></circle><circle cy="4.75em" cx="0" r="0.4em" style="fill: rgb(44, 160, 44);"></circle><circle cy="5.75em" cx="0" r="0.4em" style="fill: rgb(214, 39, 40);"></circle><circle cy="6.75em" cx="0" r="0.4em" style="fill: rgb(44, 160, 44);"></circle><circle cy="7.75em" cx="0" r="0.4em" style="fill: rgb(255, 127, 14);"></circle><circle cy="8.75em" cx="0" r="0.4em" style="fill: rgb(255, 127, 14);"></circle><circle cy="9.75em" cx="0" r="0.4em" style="fill: rgb(31, 119, 180);"></circle><circle cy="10.75em" cx="0" r="0.4em" style="fill: rgb(140, 86, 75);"></circle><circle cy="11.75em" cx="0" r="0.4em" style="fill: rgb(23, 190, 207);"></circle><circle cy="12.75em" cx="0" r="0.4em" style="fill: rgb(127, 127, 127);"></circle></g><rect class="legend-box"></rect></g></svg>
        )

Link to generate your own version of this figure

A follow-up analysis showed that this growth is driven by the data science packages such as numpy, matplotlib, and especially pandas.

related_tags_over_time-1-2000x2000.png

The exponential growth of pandas is due to the fact that it just works. It saves you time and helps you do science more efficiently and effectively.

Pandas capabilities (from the Pandas website):

  • A fast and efficient DataFrame object for data manipulation with integrated indexing;

  • Tools for reading and writing data between in-memory data structures and different formats: CSV and text files, Microsoft Excel, SQL databases, and the fast HDF5 format;

  • Intelligent data alignment and integrated handling of missing data: gain automatic label-based alignment in computations and easily manipulate messy data into an orderly form;

  • Flexible reshaping and pivoting of data sets;

  • Intelligent label-based slicing, fancy indexing, and subsetting of large data sets;

  • Columns can be inserted and deleted from data structures for size mutability;

  • Aggregating or transforming data with a powerful group by engine allowing split-apply-combine operations on data sets;

  • High performance merging and joining of data sets;

  • Hierarchical axis indexing provides an intuitive way of working with high-dimensional data in a lower-dimensional data structure;

  • Time series-functionality: date range generation and frequency conversion, moving window statistics, moving window linear regressions, date shifting and lagging. Even create domain-specific time offsets and join time series without losing data;

  • Highly optimized for performance, with critical code paths written in Cython or C.

In this notebook, we will go over the basic capabilities of Pandas. It is a very deep library, and you will need to dig into the documentation for more advanced usage.

Pandas was created by Wes McKinney. Many of the examples here are drawn from Wes McKinney’s book Python for Data Analysis, which includes “a GitHub repo of code samples.

1.9.2. Pandas Data Structures: Series#

import pandas as pd
import numpy as np
from matplotlib import pyplot as plt
%matplotlib inline

A Series represents a one-dimensional array of data. The main difference between a Series and numpy array is that a Series has an index. The index contains the labels that we use to access the data.

There are many ways to create a Series. We will just show a few.

(Data are from the NASA Planetary Fact Sheet.)

names = ['Mercury', 'Venus', 'Earth']
values = [0.3e24, 4.87e24, 5.97e24]
masses = pd.Series(values, index=names)
masses
Mercury    3.000000e+23
Venus      4.870000e+24
Earth      5.970000e+24
dtype: float64
# Series have built in plotting methods.
masses.plot(kind='bar')
<Axes: >
../_images/84533d8027ae5f011206a50d1d358eb8f334c00e5aac8799025b61f2fbcbd73d.png
# Arithmetic operations and most `numpy` function can be applied to Series.
# An important point is that the Series keep their index during such operations.
np.log(masses) / masses**2
Mercury    6.006452e-46
Venus      2.396820e-48
Earth      1.600655e-48
dtype: float64
# We can access the underlying index object if we need to:
masses.index
Index(['Mercury', 'Venus', 'Earth'], dtype='object')

1.9.2.1. Indexing#

# We can get values back out using the index via the `.loc` attribute
masses.loc['Earth']
5.97e+24
# Or by raw position using `.iloc`
masses.iloc[2]
5.97e+24
# We can pass a list or array to loc to get multiple rows back:
masses.loc[['Venus', 'Earth']]
Venus    4.870000e+24
Earth    5.970000e+24
dtype: float64
# And we can even use slice notation
masses.loc['Mercury':'Earth']
Mercury    3.000000e+23
Venus      4.870000e+24
Earth      5.970000e+24
dtype: float64
masses.iloc[:2]
Mercury    3.000000e+23
Venus      4.870000e+24
dtype: float64
# If we need to, we can always get the raw data back out as well
masses.values # a numpy array
array([3.00e+23, 4.87e+24, 5.97e+24])
masses.index # a pandas Index object
Index(['Mercury', 'Venus', 'Earth'], dtype='object')

1.9.3. Pandas Data Structures: DataFrame#

There is a lot more to Series, but they are limit to a single “column”. A more useful Pandas data structure is the DataFrame. A DataFrame is basically a bunch of series that share the same index. It’s a lot like a table in a spreadsheet.

Below we create a DataFrame.

# first we create a dictionary
data = {'mass': [0.3e24, 4.87e24, 5.97e24],       # kg
        'diameter': [4879e3, 12_104e3, 12_756e3], # m
        'rotation_period': [1407.6, np.nan, 23.9] # h
       }
df = pd.DataFrame(data, index=['Mercury', 'Venus', 'Earth'])
df
mass diameter rotation_period
Mercury 3.000000e+23 4879000.0 1407.6
Venus 4.870000e+24 12104000.0 NaN
Earth 5.970000e+24 12756000.0 23.9

Pandas handles missing data very elegantly, keeping track of it through all calculations.

df.info()
<class 'pandas.core.frame.DataFrame'>
Index: 3 entries, Mercury to Earth
Data columns (total 3 columns):
 #   Column           Non-Null Count  Dtype  
---  ------           --------------  -----  
 0   mass             3 non-null      float64
 1   diameter         3 non-null      float64
 2   rotation_period  2 non-null      float64
dtypes: float64(3)
memory usage: 96.0+ bytes

A wide range of statistical functions are available on both Series and DataFrames.

print(df.min())
print(df.mean())
print(df.std())
print(df.describe())
mass               3.000000e+23
diameter           4.879000e+06
rotation_period    2.390000e+01
dtype: float64
mass               3.713333e+24
diameter           9.913000e+06
rotation_period    7.157500e+02
dtype: float64
mass               3.006765e+24
diameter           4.371744e+06
rotation_period    9.784237e+02
dtype: float64
               mass      diameter  rotation_period
count  3.000000e+00  3.000000e+00         2.000000
mean   3.713333e+24  9.913000e+06       715.750000
std    3.006765e+24  4.371744e+06       978.423653
min    3.000000e+23  4.879000e+06        23.900000
25%    2.585000e+24  8.491500e+06       369.825000
50%    4.870000e+24  1.210400e+07       715.750000
75%    5.420000e+24  1.243000e+07      1061.675000
max    5.970000e+24  1.275600e+07      1407.600000
# We can get a single column as a `Series` using python’s `getitem` syntax on the `DataFrame` object.
print(df['mass'])
# …or using attribute syntax.
print(df.mass)
Mercury    3.000000e+23
Venus      4.870000e+24
Earth      5.970000e+24
Name: mass, dtype: float64
Mercury    3.000000e+23
Venus      4.870000e+24
Earth      5.970000e+24
Name: mass, dtype: float64
# Indexing works very similar to series
print(df.loc['Earth'])
print(df.iloc[2])
mass               5.970000e+24
diameter           1.275600e+07
rotation_period    2.390000e+01
Name: Earth, dtype: float64
mass               5.970000e+24
diameter           1.275600e+07
rotation_period    2.390000e+01
Name: Earth, dtype: float64
# But we can also specify the column we want to access
df.loc['Earth', 'mass']
5.97e+24
df.iloc[0:2, 0]
Mercury    3.000000e+23
Venus      4.870000e+24
Name: mass, dtype: float64

If we make a calculation using columns from the DataFrame, it will keep the same index:

volume =  4/3 * np.pi * (df.diameter/2)**3
df.mass / volume
Mercury    4933.216530
Venus      5244.977070
Earth      5493.285577
dtype: float64

Which we can easily add as another column to the DataFrame:

df['density'] = df.mass / volume
df
mass diameter rotation_period density
Mercury 3.000000e+23 4879000.0 1407.6 4933.216530
Venus 4.870000e+24 12104000.0 NaN 5244.977070
Earth 5.970000e+24 12756000.0 23.9 5493.285577

1.9.4. Merging Data#

Pandas supports a wide range of methods for merging different datasets. These are described extensively in the documentation. Here we just give a few examples.

temperature = pd.Series([167, 464, 15, -65],
                     index=['Mercury', 'Venus', 'Earth', 'Mars'],
                     name='temperature')
temperature
Mercury    167
Venus      464
Earth       15
Mars       -65
Name: temperature, dtype: int64
# returns a new DataFrame
df.join(temperature)
mass diameter rotation_period density temperature
Mercury 3.000000e+23 4879000.0 1407.6 4933.216530 167
Venus 4.870000e+24 12104000.0 NaN 5244.977070 464
Earth 5.970000e+24 12756000.0 23.9 5493.285577 15
# returns a new DataFrame
df.join(temperature, how='right')
mass diameter rotation_period density temperature
Mercury 3.000000e+23 4879000.0 1407.6 4933.216530 167
Venus 4.870000e+24 12104000.0 NaN 5244.977070 464
Earth 5.970000e+24 12756000.0 23.9 5493.285577 15
Mars NaN NaN NaN NaN -65
# returns a new DataFrame
everyone = df.reindex(['Mercury', 'Venus', 'Earth', 'Mars'])
everyone
mass diameter rotation_period density
Mercury 3.000000e+23 4879000.0 1407.6 4933.216530
Venus 4.870000e+24 12104000.0 NaN 5244.977070
Earth 5.970000e+24 12756000.0 23.9 5493.285577
Mars NaN NaN NaN NaN

We can also index using a boolean series. This is very useful:

adults = df[df.mass > 4e24]
adults
mass diameter rotation_period density
Venus 4.870000e+24 12104000.0 NaN 5244.977070
Earth 5.970000e+24 12756000.0 23.9 5493.285577
df['is_big'] = df.mass > 4e24
df
mass diameter rotation_period density is_big
Mercury 3.000000e+23 4879000.0 1407.6 4933.216530 False
Venus 4.870000e+24 12104000.0 NaN 5244.977070 True
Earth 5.970000e+24 12756000.0 23.9 5493.285577 True

1.9.5. Modifying Values#

We often want to modify values in a dataframe based on some rule. To modify values, we need to use .loc or .iloc

df.loc['Earth', 'mass'] = 5.98+24
df.loc['Venus', 'diameter'] += 1
df
mass diameter rotation_period density is_big
Mercury 3.000000e+23 4879000.0 1407.6 4933.216530 False
Venus 4.870000e+24 12104001.0 NaN 5244.977070 True
Earth 2.998000e+01 12756000.0 23.9 5493.285577 True

1.9.6. Plotting#

DataFrames have all kinds of useful plotting built in.

df.plot(kind='scatter', x='mass', y='diameter', grid=True)
<Axes: xlabel='mass', ylabel='diameter'>
../_images/d49ddaa9f5db88b3118e57acb029fdccfc1b83428e20bb5a1cc44d485984430e.png
df.plot(kind='bar')
<Axes: >
../_images/dede46b38c8c37a48e7fb6b92e98df494f79b8790cfa098636e145060ee83bc3.png

1.9.7. Time Indexes#

Indexes are very powerful. They are a big part of why Pandas is so useful. There are different indexes for different types of data. Time indexes are especially great!

two_years = pd.date_range(start='2014-01-01', end='2016-01-01', freq='D')
timeseries = pd.Series(np.sin(2 *np.pi *two_years.dayofyear / 365),
                       index=two_years)
timeseries.plot()
<Axes: >
../_images/738a4e6d77fa987a8a0fea31ad6dd180893557501c49134b37e2c3a1edfad243.png

We can use python’s slicing notation inside .loc to select a date range.

timeseries.loc['2015-01-01':'2015-07-01'].plot()
<Axes: >
../_images/f914546a3131ca9e100c8b8f749c22ea3c9be73b0f3203dd45eecff29dc7ba77.png
timeseries.index.month
Index([ 1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
       ...
       12, 12, 12, 12, 12, 12, 12, 12, 12,  1],
      dtype='int32', length=731)
timeseries.index.day
Index([ 1,  2,  3,  4,  5,  6,  7,  8,  9, 10,
       ...
       23, 24, 25, 26, 27, 28, 29, 30, 31,  1],
      dtype='int32', length=731)

1.9.8. Reading Data Files: Weather Station Data#

In this example, we will use NOAA weather station data from https://www.ncei.noaa.gov/products/land-based-station.

The details of files we are going to read are described in this README file.

import pooch
POOCH = pooch.create(
    path=pooch.os_cache("noaa-data"),
    base_url="doi:10.5281/zenodo.5564850/",
    registry={
        "data.txt": "md5:5129dcfd19300eb8d4d8d1673fcfbcb4",
    },
)
datafile = POOCH.fetch("data.txt")
datafile
Downloading file 'data.txt' from 'doi:10.5281/zenodo.5564850/data.txt' to 'C:\Users\tbeucler\AppData\Local\noaa-data\noaa-data\Cache'.
'C:\\Users\\tbeucler\\AppData\\Local\\noaa-data\\noaa-data\\Cache\\data.txt'
! head '/root/.cache/noaa-data/data.txt' # Replace this value with the download path indicated above
'head' is not recognized as an internal or external command,
operable program or batch file.

We now have a text file on our hard drive called data.txt.

To read it into pandas, we will use the read_csv function. This function is incredibly complex and powerful. You can use it to extract data from almost any text file. However, you need to understand how to use its various options.

With no options, this is what we get.

df = pd.read_csv(datafile)
df.head()
WBANNO LST_DATE CRX_VN LONGITUDE LATITUDE T_DAILY_MAX T_DAILY_MIN T_DAILY_MEAN T_DAILY_AVG P_DAILY_CALC SOLARAD_DAILY SUR_TEMP_DAILY_TYPE SUR_TEMP_DAILY_MAX SUR_TEMP_DAILY_MIN SUR_TEMP_DAILY_AVG RH_DAILY_MAX RH_DAILY_MIN RH_DAILY_AVG SOIL_MOISTURE_5_DAILY SOIL_MOISTURE_10_DAILY SOIL_MOISTURE_20_DAILY SOIL_MOISTURE_50_DAILY SOIL_MOISTURE_100_DAILY SOIL_TEMP_5_DAILY SOIL_TEMP_10_DAILY SOIL_TEMP_20_DAILY SOIL_TEMP_50_DAILY SOIL_TEMP_100_DAILY
0 64756 20170101 2.422 -73.74 41.79 6.6 ...
1 64756 20170102 2.422 -73.74 41.79 4.0 ...
2 64756 20170103 2.422 -73.74 41.79 4.9 ...
3 64756 20170104 2.422 -73.74 41.79 8.7 ...
4 64756 20170105 2.422 -73.74 41.79 -0.5 ...

Pandas failed to identify the different columns. This is because it was expecting standard CSV (comma-separated values) file. In our file, instead, the values are separated by whitespace. And not a single whilespace–the amount of whitespace between values varies. We can tell pandas this using the sep keyword.

df = pd.read_csv(datafile, sep='\s+')
df.head()
WBANNO LST_DATE CRX_VN LONGITUDE LATITUDE T_DAILY_MAX T_DAILY_MIN T_DAILY_MEAN T_DAILY_AVG P_DAILY_CALC ... SOIL_MOISTURE_5_DAILY SOIL_MOISTURE_10_DAILY SOIL_MOISTURE_20_DAILY SOIL_MOISTURE_50_DAILY SOIL_MOISTURE_100_DAILY SOIL_TEMP_5_DAILY SOIL_TEMP_10_DAILY SOIL_TEMP_20_DAILY SOIL_TEMP_50_DAILY SOIL_TEMP_100_DAILY
0 64756 20170101 2.422 -73.74 41.79 6.6 -5.4 0.6 2.2 0.0 ... -99.0 -99.0 0.207 0.152 0.175 -0.1 0.0 0.6 1.5 3.4
1 64756 20170102 2.422 -73.74 41.79 4.0 -6.8 -1.4 -1.2 0.0 ... -99.0 -99.0 0.205 0.151 0.173 -0.2 0.0 0.6 1.5 3.3
2 64756 20170103 2.422 -73.74 41.79 4.9 0.7 2.8 2.7 13.1 ... -99.0 -99.0 0.205 0.150 0.173 -0.1 0.0 0.5 1.5 3.3
3 64756 20170104 2.422 -73.74 41.79 8.7 -1.6 3.6 3.5 1.3 ... -99.0 -99.0 0.215 0.153 0.174 -0.1 0.0 0.5 1.5 3.2
4 64756 20170105 2.422 -73.74 41.79 -0.5 -4.6 -2.5 -2.8 0.0 ... -99.0 -99.0 0.215 0.154 0.177 -0.1 0.0 0.5 1.4 3.1

5 rows × 28 columns

Great! It worked.

If we look closely, we will see there are lots of -99 and -9999 values in the file. The README file tells us that these are values used to represent missing data. Let’s tell this to pandas.

df = pd.read_csv(datafile, sep='\s+', na_values=[-9999.0, -99.0])
df.head()
WBANNO LST_DATE CRX_VN LONGITUDE LATITUDE T_DAILY_MAX T_DAILY_MIN T_DAILY_MEAN T_DAILY_AVG P_DAILY_CALC ... SOIL_MOISTURE_5_DAILY SOIL_MOISTURE_10_DAILY SOIL_MOISTURE_20_DAILY SOIL_MOISTURE_50_DAILY SOIL_MOISTURE_100_DAILY SOIL_TEMP_5_DAILY SOIL_TEMP_10_DAILY SOIL_TEMP_20_DAILY SOIL_TEMP_50_DAILY SOIL_TEMP_100_DAILY
0 64756 20170101 2.422 -73.74 41.79 6.6 -5.4 0.6 2.2 0.0 ... NaN NaN 0.207 0.152 0.175 -0.1 0.0 0.6 1.5 3.4
1 64756 20170102 2.422 -73.74 41.79 4.0 -6.8 -1.4 -1.2 0.0 ... NaN NaN 0.205 0.151 0.173 -0.2 0.0 0.6 1.5 3.3
2 64756 20170103 2.422 -73.74 41.79 4.9 0.7 2.8 2.7 13.1 ... NaN NaN 0.205 0.150 0.173 -0.1 0.0 0.5 1.5 3.3
3 64756 20170104 2.422 -73.74 41.79 8.7 -1.6 3.6 3.5 1.3 ... NaN NaN 0.215 0.153 0.174 -0.1 0.0 0.5 1.5 3.2
4 64756 20170105 2.422 -73.74 41.79 -0.5 -4.6 -2.5 -2.8 0.0 ... NaN NaN 0.215 0.154 0.177 -0.1 0.0 0.5 1.4 3.1

5 rows × 28 columns

Wonderful. The missing data is now represented by NaN.

What data types did pandas infer?

df.info()
<class 'pandas.core.frame.DataFrame'>
RangeIndex: 365 entries, 0 to 364
Data columns (total 28 columns):
 #   Column                   Non-Null Count  Dtype  
---  ------                   --------------  -----  
 0   WBANNO                   365 non-null    int64  
 1   LST_DATE                 365 non-null    int64  
 2   CRX_VN                   365 non-null    float64
 3   LONGITUDE                365 non-null    float64
 4   LATITUDE                 365 non-null    float64
 5   T_DAILY_MAX              364 non-null    float64
 6   T_DAILY_MIN              364 non-null    float64
 7   T_DAILY_MEAN             364 non-null    float64
 8   T_DAILY_AVG              364 non-null    float64
 9   P_DAILY_CALC             364 non-null    float64
 10  SOLARAD_DAILY            364 non-null    float64
 11  SUR_TEMP_DAILY_TYPE      365 non-null    object 
 12  SUR_TEMP_DAILY_MAX       364 non-null    float64
 13  SUR_TEMP_DAILY_MIN       364 non-null    float64
 14  SUR_TEMP_DAILY_AVG       364 non-null    float64
 15  RH_DAILY_MAX             364 non-null    float64
 16  RH_DAILY_MIN             364 non-null    float64
 17  RH_DAILY_AVG             364 non-null    float64
 18  SOIL_MOISTURE_5_DAILY    317 non-null    float64
 19  SOIL_MOISTURE_10_DAILY   317 non-null    float64
 20  SOIL_MOISTURE_20_DAILY   336 non-null    float64
 21  SOIL_MOISTURE_50_DAILY   364 non-null    float64
 22  SOIL_MOISTURE_100_DAILY  359 non-null    float64
 23  SOIL_TEMP_5_DAILY        364 non-null    float64
 24  SOIL_TEMP_10_DAILY       364 non-null    float64
 25  SOIL_TEMP_20_DAILY       364 non-null    float64
 26  SOIL_TEMP_50_DAILY       364 non-null    float64
 27  SOIL_TEMP_100_DAILY      364 non-null    float64
dtypes: float64(25), int64(2), object(1)
memory usage: 80.0+ KB

One problem here is that pandas did not recognize the LST_DATE column as a date. Let’s help it.

df = pd.read_csv(datafile, sep='\s+',
                 na_values=[-9999.0, -99.0],
                 parse_dates=[1])
df.info()
<class 'pandas.core.frame.DataFrame'>
RangeIndex: 365 entries, 0 to 364
Data columns (total 28 columns):
 #   Column                   Non-Null Count  Dtype         
---  ------                   --------------  -----         
 0   WBANNO                   365 non-null    int64         
 1   LST_DATE                 365 non-null    datetime64[ns]
 2   CRX_VN                   365 non-null    float64       
 3   LONGITUDE                365 non-null    float64       
 4   LATITUDE                 365 non-null    float64       
 5   T_DAILY_MAX              364 non-null    float64       
 6   T_DAILY_MIN              364 non-null    float64       
 7   T_DAILY_MEAN             364 non-null    float64       
 8   T_DAILY_AVG              364 non-null    float64       
 9   P_DAILY_CALC             364 non-null    float64       
 10  SOLARAD_DAILY            364 non-null    float64       
 11  SUR_TEMP_DAILY_TYPE      365 non-null    object        
 12  SUR_TEMP_DAILY_MAX       364 non-null    float64       
 13  SUR_TEMP_DAILY_MIN       364 non-null    float64       
 14  SUR_TEMP_DAILY_AVG       364 non-null    float64       
 15  RH_DAILY_MAX             364 non-null    float64       
 16  RH_DAILY_MIN             364 non-null    float64       
 17  RH_DAILY_AVG             364 non-null    float64       
 18  SOIL_MOISTURE_5_DAILY    317 non-null    float64       
 19  SOIL_MOISTURE_10_DAILY   317 non-null    float64       
 20  SOIL_MOISTURE_20_DAILY   336 non-null    float64       
 21  SOIL_MOISTURE_50_DAILY   364 non-null    float64       
 22  SOIL_MOISTURE_100_DAILY  359 non-null    float64       
 23  SOIL_TEMP_5_DAILY        364 non-null    float64       
 24  SOIL_TEMP_10_DAILY       364 non-null    float64       
 25  SOIL_TEMP_20_DAILY       364 non-null    float64       
 26  SOIL_TEMP_50_DAILY       364 non-null    float64       
 27  SOIL_TEMP_100_DAILY      364 non-null    float64       
dtypes: datetime64[ns](1), float64(25), int64(1), object(1)
memory usage: 80.0+ KB
# It worked! Finally, let’s tell pandas to use the date column as the index.
df = df.set_index('LST_DATE')
df.head()
WBANNO CRX_VN LONGITUDE LATITUDE T_DAILY_MAX T_DAILY_MIN T_DAILY_MEAN T_DAILY_AVG P_DAILY_CALC SOLARAD_DAILY ... SOIL_MOISTURE_5_DAILY SOIL_MOISTURE_10_DAILY SOIL_MOISTURE_20_DAILY SOIL_MOISTURE_50_DAILY SOIL_MOISTURE_100_DAILY SOIL_TEMP_5_DAILY SOIL_TEMP_10_DAILY SOIL_TEMP_20_DAILY SOIL_TEMP_50_DAILY SOIL_TEMP_100_DAILY
LST_DATE
2017-01-01 64756 2.422 -73.74 41.79 6.6 -5.4 0.6 2.2 0.0 8.68 ... NaN NaN 0.207 0.152 0.175 -0.1 0.0 0.6 1.5 3.4
2017-01-02 64756 2.422 -73.74 41.79 4.0 -6.8 -1.4 -1.2 0.0 2.08 ... NaN NaN 0.205 0.151 0.173 -0.2 0.0 0.6 1.5 3.3
2017-01-03 64756 2.422 -73.74 41.79 4.9 0.7 2.8 2.7 13.1 0.68 ... NaN NaN 0.205 0.150 0.173 -0.1 0.0 0.5 1.5 3.3
2017-01-04 64756 2.422 -73.74 41.79 8.7 -1.6 3.6 3.5 1.3 2.85 ... NaN NaN 0.215 0.153 0.174 -0.1 0.0 0.5 1.5 3.2
2017-01-05 64756 2.422 -73.74 41.79 -0.5 -4.6 -2.5 -2.8 0.0 4.90 ... NaN NaN 0.215 0.154 0.177 -0.1 0.0 0.5 1.4 3.1

5 rows × 27 columns

df.loc['2017-08-07']
WBANNO                     64756
CRX_VN                     2.422
LONGITUDE                 -73.74
LATITUDE                   41.79
T_DAILY_MAX                 19.3
T_DAILY_MIN                 12.3
T_DAILY_MEAN                15.8
T_DAILY_AVG                 16.3
P_DAILY_CALC                 4.9
SOLARAD_DAILY               3.93
SUR_TEMP_DAILY_TYPE            C
SUR_TEMP_DAILY_MAX          22.3
SUR_TEMP_DAILY_MIN          11.9
SUR_TEMP_DAILY_AVG          17.7
RH_DAILY_MAX                94.7
RH_DAILY_MIN                76.4
RH_DAILY_AVG                89.5
SOIL_MOISTURE_5_DAILY      0.148
SOIL_MOISTURE_10_DAILY     0.113
SOIL_MOISTURE_20_DAILY     0.094
SOIL_MOISTURE_50_DAILY     0.114
SOIL_MOISTURE_100_DAILY    0.151
SOIL_TEMP_5_DAILY           21.4
SOIL_TEMP_10_DAILY          21.7
SOIL_TEMP_20_DAILY          22.1
SOIL_TEMP_50_DAILY          22.2
SOIL_TEMP_100_DAILY         21.5
Name: 2017-08-07 00:00:00, dtype: object
df.loc['2017-07-01':'2017-07-11']
WBANNO CRX_VN LONGITUDE LATITUDE T_DAILY_MAX T_DAILY_MIN T_DAILY_MEAN T_DAILY_AVG P_DAILY_CALC SOLARAD_DAILY ... SOIL_MOISTURE_5_DAILY SOIL_MOISTURE_10_DAILY SOIL_MOISTURE_20_DAILY SOIL_MOISTURE_50_DAILY SOIL_MOISTURE_100_DAILY SOIL_TEMP_5_DAILY SOIL_TEMP_10_DAILY SOIL_TEMP_20_DAILY SOIL_TEMP_50_DAILY SOIL_TEMP_100_DAILY
LST_DATE
2017-07-01 64756 2.422 -73.74 41.79 28.0 19.7 23.9 23.8 0.2 19.28 ... 0.157 0.136 0.144 0.129 0.163 25.7 25.4 23.7 21.9 19.9
2017-07-02 64756 2.422 -73.74 41.79 29.8 18.4 24.1 23.7 4.0 27.67 ... 0.146 0.135 0.143 0.129 0.162 26.8 26.4 24.5 22.3 20.1
2017-07-03 64756 2.422 -73.74 41.79 28.3 15.0 21.7 21.4 0.0 27.08 ... 0.141 0.132 0.139 0.128 0.162 26.4 26.3 24.8 22.8 20.3
2017-07-04 64756 2.422 -73.74 41.79 26.8 12.6 19.7 20.0 0.0 29.45 ... 0.131 0.126 0.136 0.126 0.161 25.9 25.8 24.6 22.9 20.6
2017-07-05 64756 2.422 -73.74 41.79 28.0 11.9 20.0 20.7 0.0 26.90 ... 0.116 0.114 0.131 0.125 0.161 25.3 25.3 24.2 22.8 20.7
2017-07-06 64756 2.422 -73.74 41.79 25.7 14.3 20.0 20.3 0.0 19.03 ... 0.105 0.104 0.126 0.124 0.160 24.7 24.7 23.9 22.7 20.9
2017-07-07 64756 2.422 -73.74 41.79 25.8 16.8 21.3 20.0 11.5 13.88 ... 0.114 0.100 0.123 0.123 0.160 24.2 24.2 23.4 22.4 20.8
2017-07-08 64756 2.422 -73.74 41.79 29.0 15.3 22.1 21.5 0.0 21.92 ... 0.130 0.106 0.122 0.123 0.159 25.5 25.3 23.9 22.4 20.8
2017-07-09 64756 2.422 -73.74 41.79 26.3 10.9 18.6 19.4 0.0 29.72 ... 0.119 0.103 0.119 0.121 0.158 24.8 24.8 23.8 22.5 20.8
2017-07-10 64756 2.422 -73.74 41.79 27.6 11.8 19.7 21.3 0.0 23.67 ... 0.105 0.096 0.113 0.120 0.158 24.7 24.7 23.6 22.5 20.9
2017-07-11 64756 2.422 -73.74 41.79 27.4 19.2 23.3 22.6 8.5 17.79 ... 0.106 0.093 0.110 0.120 0.157 25.6 25.4 24.1 22.6 20.9

11 rows × 27 columns

1.9.9. Quick statistics#

df.describe()
WBANNO CRX_VN LONGITUDE LATITUDE T_DAILY_MAX T_DAILY_MIN T_DAILY_MEAN T_DAILY_AVG P_DAILY_CALC SOLARAD_DAILY ... SOIL_MOISTURE_5_DAILY SOIL_MOISTURE_10_DAILY SOIL_MOISTURE_20_DAILY SOIL_MOISTURE_50_DAILY SOIL_MOISTURE_100_DAILY SOIL_TEMP_5_DAILY SOIL_TEMP_10_DAILY SOIL_TEMP_20_DAILY SOIL_TEMP_50_DAILY SOIL_TEMP_100_DAILY
count 365.0 365.000000 365.00 3.650000e+02 364.000000 364.000000 364.000000 364.000000 364.000000 364.000000 ... 317.000000 317.000000 336.000000 364.000000 359.000000 364.000000 364.000000 364.000000 364.000000 364.000000
mean 64756.0 2.470767 -73.74 4.179000e+01 15.720055 4.037912 9.876374 9.990110 2.797802 13.068187 ... 0.189498 0.183991 0.165470 0.140192 0.160630 12.312637 12.320604 12.060165 11.978022 11.915659
std 0.0 0.085997 0.00 7.115181e-15 10.502087 9.460676 9.727451 9.619168 7.238628 7.953074 ... 0.052031 0.054113 0.043989 0.020495 0.016011 9.390034 9.338176 8.767752 8.078346 7.187317
min 64756.0 2.422000 -73.74 4.179000e+01 -12.300000 -21.800000 -17.000000 -16.700000 0.000000 0.100000 ... 0.075000 0.078000 0.087000 0.101000 0.117000 -0.700000 -0.400000 0.200000 0.900000 1.900000
25% 64756.0 2.422000 -73.74 4.179000e+01 6.900000 -2.775000 2.100000 2.275000 0.000000 6.225000 ... 0.152000 0.139000 0.118750 0.118000 0.154000 2.225000 2.000000 2.475000 3.300000 4.100000
50% 64756.0 2.422000 -73.74 4.179000e+01 17.450000 4.350000 10.850000 11.050000 0.000000 12.865000 ... 0.192000 0.198000 0.183000 0.147500 0.165000 13.300000 13.350000 13.100000 12.850000 11.600000
75% 64756.0 2.422000 -73.74 4.179000e+01 24.850000 11.900000 18.150000 18.450000 1.400000 19.740000 ... 0.234000 0.227000 0.203000 0.157000 0.173000 21.025000 21.125000 20.400000 19.800000 19.325000
max 64756.0 2.622000 -73.74 4.179000e+01 33.400000 20.700000 25.700000 26.700000 65.700000 29.910000 ... 0.296000 0.321000 0.235000 0.182000 0.192000 27.600000 27.400000 25.600000 24.100000 22.100000

8 rows × 26 columns

1.9.10. Plotting Values#

Pandas integrates a convenient boxplot function:

fig, ax = plt.subplots(ncols=2, nrows=2, figsize=(14,14))

df.iloc[:, 4:8].boxplot(ax=ax[0,0])
df.iloc[:, 10:14].boxplot(ax=ax[0,1])
df.iloc[:, 14:17].boxplot(ax=ax[1,0])
df.iloc[:, 18:22].boxplot(ax=ax[1,1])


ax[1, 1].set_xticklabels(ax[1, 1].get_xticklabels(), rotation=90);
../_images/756748a48c05fcf2461646dafd0a61db154d782ac972e2b8660e5fd0aa4477f6.png
# Pandas is "TIME-AWARE"
df.T_DAILY_MEAN.plot()
<Axes: xlabel='LST_DATE'>
../_images/f4de4e5ec3c8be770f2aee492d7b222ba7c9bc2552a9eac41b743dd2b2aa0ad9.png

Note: we could also manually create an axis and plot into it.

fig, ax = plt.subplots()
df.T_DAILY_MEAN.plot(ax=ax)
ax.set_title('Pandas Made This!')
Text(0.5, 1.0, 'Pandas Made This!')
../_images/895e8967247f5b5987e1e6befcac438e52ddc99cb8ab3d17a9d117637ecb2a34.png
df[['T_DAILY_MIN', 'T_DAILY_MEAN', 'T_DAILY_MAX']].plot()
<Axes: xlabel='LST_DATE'>
../_images/d53c9e74031169c20dceb7c302cf6ff8054c0a954e4760c703655a7ded06949d.png

1.9.11. Resampling#

Since pandas understands time, we can use it to do resampling. The frequency string of each date offset is listed in the time series documentation.

# monthly reampler object
rs_obj = df.resample('MS')
rs_obj
<pandas.core.resample.DatetimeIndexResampler object at 0x0000021835BC4700>
rs_obj.mean()
---------------------------------------------------------------------------
NotImplementedError                       Traceback (most recent call last)
File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\groupby.py:1490, in GroupBy._cython_agg_general.<locals>.array_func(values)
   1489 try:
-> 1490     result = self.grouper._cython_operation(
   1491         "aggregate",
   1492         values,
   1493         how,
   1494         axis=data.ndim - 1,
   1495         min_count=min_count,
   1496         **kwargs,
   1497     )
   1498 except NotImplementedError:
   1499     # generally if we have numeric_only=False
   1500     # and non-applicable functions
   1501     # try to python agg
   1502     # TODO: shouldn't min_count matter?

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\ops.py:959, in BaseGrouper._cython_operation(self, kind, values, how, axis, min_count, **kwargs)
    958 ngroups = self.ngroups
--> 959 return cy_op.cython_operation(
    960     values=values,
    961     axis=axis,
    962     min_count=min_count,
    963     comp_ids=ids,
    964     ngroups=ngroups,
    965     **kwargs,
    966 )

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\ops.py:657, in WrappedCythonOp.cython_operation(self, values, axis, min_count, comp_ids, ngroups, **kwargs)
    649     return self._ea_wrap_cython_operation(
    650         values,
    651         min_count=min_count,
   (...)
    654         **kwargs,
    655     )
--> 657 return self._cython_op_ndim_compat(
    658     values,
    659     min_count=min_count,
    660     ngroups=ngroups,
    661     comp_ids=comp_ids,
    662     mask=None,
    663     **kwargs,
    664 )

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\ops.py:497, in WrappedCythonOp._cython_op_ndim_compat(self, values, min_count, ngroups, comp_ids, mask, result_mask, **kwargs)
    495     return res.T
--> 497 return self._call_cython_op(
    498     values,
    499     min_count=min_count,
    500     ngroups=ngroups,
    501     comp_ids=comp_ids,
    502     mask=mask,
    503     result_mask=result_mask,
    504     **kwargs,
    505 )

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\ops.py:541, in WrappedCythonOp._call_cython_op(self, values, min_count, ngroups, comp_ids, mask, result_mask, **kwargs)
    540 out_shape = self._get_output_shape(ngroups, values)
--> 541 func = self._get_cython_function(self.kind, self.how, values.dtype, is_numeric)
    542 values = self._get_cython_vals(values)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\ops.py:173, in WrappedCythonOp._get_cython_function(cls, kind, how, dtype, is_numeric)
    171 if "object" not in f.__signatures__:
    172     # raise NotImplementedError here rather than TypeError later
--> 173     raise NotImplementedError(
    174         f"function is not implemented for this dtype: "
    175         f"[how->{how},dtype->{dtype_str}]"
    176     )
    177 return f

NotImplementedError: function is not implemented for this dtype: [how->mean,dtype->object]

During handling of the above exception, another exception occurred:

ValueError                                Traceback (most recent call last)
File ~\.conda\envs\JB\lib\site-packages\pandas\core\nanops.py:1692, in _ensure_numeric(x)
   1691 try:
-> 1692     x = float(x)
   1693 except (TypeError, ValueError):
   1694     # e.g. "1+1j" or "foo"

ValueError: could not convert string to float: 'CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC'

During handling of the above exception, another exception occurred:

ValueError                                Traceback (most recent call last)
File ~\.conda\envs\JB\lib\site-packages\pandas\core\nanops.py:1696, in _ensure_numeric(x)
   1695 try:
-> 1696     x = complex(x)
   1697 except ValueError as err:
   1698     # e.g. "foo"

ValueError: complex() arg is a malformed string

The above exception was the direct cause of the following exception:

TypeError                                 Traceback (most recent call last)
Cell In[51], line 1
----> 1 rs_obj.mean()

File ~\.conda\envs\JB\lib\site-packages\pandas\core\resample.py:979, in Resampler.mean(self, numeric_only, *args, **kwargs)
    977 maybe_warn_args_and_kwargs(type(self), "mean", args, kwargs)
    978 nv.validate_resampler_func("mean", args, kwargs)
--> 979 return self._downsample("mean", numeric_only=numeric_only)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\resample.py:1297, in DatetimeIndexResampler._downsample(self, how, **kwargs)
   1293     return self.asfreq()
   1295 # we are downsampling
   1296 # we want to call the actual grouper method here
-> 1297 result = obj.groupby(self.grouper, axis=self.axis).aggregate(how, **kwargs)
   1299 return self._wrap_result(result)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\generic.py:1269, in DataFrameGroupBy.aggregate(self, func, engine, engine_kwargs, *args, **kwargs)
   1266 func = maybe_mangle_lambdas(func)
   1268 op = GroupByApply(self, func, args, kwargs)
-> 1269 result = op.agg()
   1270 if not is_dict_like(func) and result is not None:
   1271     return result

File ~\.conda\envs\JB\lib\site-packages\pandas\core\apply.py:160, in Apply.agg(self)
    157 kwargs = self.kwargs
    159 if isinstance(arg, str):
--> 160     return self.apply_str()
    162 if is_dict_like(arg):
    163     return self.agg_dict_like()

File ~\.conda\envs\JB\lib\site-packages\pandas\core\apply.py:496, in Apply.apply_str(self)
    494     if "axis" in arg_names:
    495         self.kwargs["axis"] = self.axis
--> 496 return self._try_aggregate_string_function(obj, f, *self.args, **self.kwargs)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\apply.py:565, in Apply._try_aggregate_string_function(self, obj, arg, *args, **kwargs)
    563 if f is not None:
    564     if callable(f):
--> 565         return f(*args, **kwargs)
    567     # people may try to aggregate on a non-callable attribute
    568     # but don't let them think they can pass args to it
    569     assert len(args) == 0

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\groupby.py:1855, in GroupBy.mean(self, numeric_only, engine, engine_kwargs)
   1853     return self._numba_agg_general(sliding_mean, engine_kwargs)
   1854 else:
-> 1855     result = self._cython_agg_general(
   1856         "mean",
   1857         alt=lambda x: Series(x).mean(numeric_only=numeric_only),
   1858         numeric_only=numeric_only,
   1859     )
   1860     return result.__finalize__(self.obj, method="groupby")

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\groupby.py:1507, in GroupBy._cython_agg_general(self, how, alt, numeric_only, min_count, **kwargs)
   1503         result = self._agg_py_fallback(values, ndim=data.ndim, alt=alt)
   1505     return result
-> 1507 new_mgr = data.grouped_reduce(array_func)
   1508 res = self._wrap_agged_manager(new_mgr)
   1509 out = self._wrap_aggregated_output(res)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\internals\managers.py:1503, in BlockManager.grouped_reduce(self, func)
   1499 if blk.is_object:
   1500     # split on object-dtype blocks bc some columns may raise
   1501     #  while others do not.
   1502     for sb in blk._split():
-> 1503         applied = sb.apply(func)
   1504         result_blocks = extend_blocks(applied, result_blocks)
   1505 else:

File ~\.conda\envs\JB\lib\site-packages\pandas\core\internals\blocks.py:329, in Block.apply(self, func, **kwargs)
    323 @final
    324 def apply(self, func, **kwargs) -> list[Block]:
    325     """
    326     apply the function to my values; return a block if we are not
    327     one
    328     """
--> 329     result = func(self.values, **kwargs)
    331     return self._split_op_result(result)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\groupby.py:1503, in GroupBy._cython_agg_general.<locals>.array_func(values)
   1490     result = self.grouper._cython_operation(
   1491         "aggregate",
   1492         values,
   (...)
   1496         **kwargs,
   1497     )
   1498 except NotImplementedError:
   1499     # generally if we have numeric_only=False
   1500     # and non-applicable functions
   1501     # try to python agg
   1502     # TODO: shouldn't min_count matter?
-> 1503     result = self._agg_py_fallback(values, ndim=data.ndim, alt=alt)
   1505 return result

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\groupby.py:1457, in GroupBy._agg_py_fallback(self, values, ndim, alt)
   1452     ser = df.iloc[:, 0]
   1454 # We do not get here with UDFs, so we know that our dtype
   1455 #  should always be preserved by the implemented aggregations
   1456 # TODO: Is this exactly right; see WrappedCythonOp get_result_dtype?
-> 1457 res_values = self.grouper.agg_series(ser, alt, preserve_dtype=True)
   1459 if isinstance(values, Categorical):
   1460     # Because we only get here with known dtype-preserving
   1461     #  reductions, we cast back to Categorical.
   1462     # TODO: if we ever get "rank" working, exclude it here.
   1463     res_values = type(values)._from_sequence(res_values, dtype=values.dtype)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\ops.py:994, in BaseGrouper.agg_series(self, obj, func, preserve_dtype)
    987 if len(obj) > 0 and not isinstance(obj._values, np.ndarray):
    988     # we can preserve a little bit more aggressively with EA dtype
    989     #  because maybe_cast_pointwise_result will do a try/except
    990     #  with _from_sequence.  NB we are assuming here that _from_sequence
    991     #  is sufficiently strict that it casts appropriately.
    992     preserve_dtype = True
--> 994 result = self._aggregate_series_pure_python(obj, func)
    996 npvalues = lib.maybe_convert_objects(result, try_float=False)
    997 if preserve_dtype:

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\ops.py:1015, in BaseGrouper._aggregate_series_pure_python(self, obj, func)
   1012 splitter = self._get_splitter(obj, axis=0)
   1014 for i, group in enumerate(splitter):
-> 1015     res = func(group)
   1016     res = libreduction.extract_result(res)
   1018     if not initialized:
   1019         # We only do this validation on the first iteration

File ~\.conda\envs\JB\lib\site-packages\pandas\core\groupby\groupby.py:1857, in GroupBy.mean.<locals>.<lambda>(x)
   1853     return self._numba_agg_general(sliding_mean, engine_kwargs)
   1854 else:
   1855     result = self._cython_agg_general(
   1856         "mean",
-> 1857         alt=lambda x: Series(x).mean(numeric_only=numeric_only),
   1858         numeric_only=numeric_only,
   1859     )
   1860     return result.__finalize__(self.obj, method="groupby")

File ~\.conda\envs\JB\lib\site-packages\pandas\core\generic.py:11556, in NDFrame._add_numeric_operations.<locals>.mean(self, axis, skipna, numeric_only, **kwargs)
  11539 @doc(
  11540     _num_doc,
  11541     desc="Return the mean of the values over the requested axis.",
   (...)
  11554     **kwargs,
  11555 ):
> 11556     return NDFrame.mean(self, axis, skipna, numeric_only, **kwargs)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\generic.py:11201, in NDFrame.mean(self, axis, skipna, numeric_only, **kwargs)
  11194 def mean(
  11195     self,
  11196     axis: Axis | None = 0,
   (...)
  11199     **kwargs,
  11200 ) -> Series | float:
> 11201     return self._stat_function(
  11202         "mean", nanops.nanmean, axis, skipna, numeric_only, **kwargs
  11203     )

File ~\.conda\envs\JB\lib\site-packages\pandas\core\generic.py:11158, in NDFrame._stat_function(self, name, func, axis, skipna, numeric_only, **kwargs)
  11154     nv.validate_stat_func((), kwargs, fname=name)
  11156 validate_bool_kwarg(skipna, "skipna", none_allowed=False)
> 11158 return self._reduce(
  11159     func, name=name, axis=axis, skipna=skipna, numeric_only=numeric_only
  11160 )

File ~\.conda\envs\JB\lib\site-packages\pandas\core\series.py:4670, in Series._reduce(self, op, name, axis, skipna, numeric_only, filter_type, **kwds)
   4665     raise TypeError(
   4666         f"Series.{name} does not allow {kwd_name}={numeric_only} "
   4667         "with non-numeric dtypes."
   4668     )
   4669 with np.errstate(all="ignore"):
-> 4670     return op(delegate, skipna=skipna, **kwds)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\nanops.py:96, in disallow.__call__.<locals>._f(*args, **kwargs)
     94 try:
     95     with np.errstate(invalid="ignore"):
---> 96         return f(*args, **kwargs)
     97 except ValueError as e:
     98     # we want to transform an object array
     99     # ValueError message to the more typical TypeError
    100     # e.g. this is normally a disallowed function on
    101     # object arrays that contain strings
    102     if is_object_dtype(args[0]):

File ~\.conda\envs\JB\lib\site-packages\pandas\core\nanops.py:158, in bottleneck_switch.__call__.<locals>.f(values, axis, skipna, **kwds)
    156         result = alt(values, axis=axis, skipna=skipna, **kwds)
    157 else:
--> 158     result = alt(values, axis=axis, skipna=skipna, **kwds)
    160 return result

File ~\.conda\envs\JB\lib\site-packages\pandas\core\nanops.py:421, in _datetimelike_compat.<locals>.new_func(values, axis, skipna, mask, **kwargs)
    418 if datetimelike and mask is None:
    419     mask = isna(values)
--> 421 result = func(values, axis=axis, skipna=skipna, mask=mask, **kwargs)
    423 if datetimelike:
    424     result = _wrap_results(result, orig_values.dtype, fill_value=iNaT)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\nanops.py:727, in nanmean(values, axis, skipna, mask)
    724     dtype_count = dtype
    726 count = _get_counts(values.shape, mask, axis, dtype=dtype_count)
--> 727 the_sum = _ensure_numeric(values.sum(axis, dtype=dtype_sum))
    729 if axis is not None and getattr(the_sum, "ndim", False):
    730     count = cast(np.ndarray, count)

File ~\.conda\envs\JB\lib\site-packages\pandas\core\nanops.py:1699, in _ensure_numeric(x)
   1696             x = complex(x)
   1697         except ValueError as err:
   1698             # e.g. "foo"
-> 1699             raise TypeError(f"Could not convert {x} to numeric") from err
   1700 return x

TypeError: Could not convert CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC to numeric
# We can chain all of that together
df_mm = df.resample('MS').mean()
df_mm[['T_DAILY_MIN', 'T_DAILY_MEAN', 'T_DAILY_MAX']].plot()

And this concludes this notebook’s tutorial 😀

If you would like to learn more about pandas, check out the groupby tutorial from the Earth and Environmental Data Science book, the Github repository of the Python for Data Analysis, or the pandas community tutorials.