diff --git a/rowers/dataprep.py b/rowers/dataprep.py index 71f154b3..0cb791c5 100644 --- a/rowers/dataprep.py +++ b/rowers/dataprep.py @@ -272,7 +272,7 @@ def getstatsfields(): fielddict = {field.name:field.verbose_name for field in fields} - fielddict.pop('workoutid') + #fielddict.pop('workoutid') fielddict.pop('ergpace') fielddict.pop('hr_an') fielddict.pop('hr_tr') diff --git a/rowers/interactiveplots.py b/rowers/interactiveplots.py index f79b9ce2..14d42578 100644 --- a/rowers/interactiveplots.py +++ b/rowers/interactiveplots.py @@ -11,7 +11,7 @@ from bokeh.palettes import Dark2_8 as palette import itertools from bokeh.plotting import figure, ColumnDataSource, Figure,curdoc from bokeh.models import CustomJS,Slider, TextInput -from bokeh.charts import Histogram,HeatMap +from bokeh.charts import Histogram,HeatMap,Area,BoxPlot from bokeh.resources import CDN,INLINE from bokeh.embed import components from bokeh.layouts import layout,widgetbox @@ -87,6 +87,22 @@ def tailwind(bearing,vwind,winddir): from rowers.dataprep import nicepaceformat,niceformat from rowers.dataprep import timedeltaconv +def interactive_boxchart(datadf,fieldname): + + plot = BoxPlot(datadf, values=fieldname, label='date', + legend=False, + title=axlabels[fieldname], + outliers=False) + + yrange1 = Range1d(start=yaxminima[fieldname],end=yaxmaxima[fieldname]) + plot.y_range = yrange1 + + + script, div = components(plot) + + + return script,div + def interactive_forcecurve(theworkouts,workstrokesonly=False): TOOLS = 'save,pan,box_zoom,wheel_zoom,reset,tap,hover,resize,crosshair' diff --git a/rowers/templates/cumstats.html b/rowers/templates/cumstats.html index eb0b9654..484e89ff 100644 --- a/rowers/templates/cumstats.html +++ b/rowers/templates/cumstats.html @@ -5,6 +5,35 @@ {% block title %}Workout Statistics{% endblock %} {% block content %} + + + + + {{ plotscript |safe }} + + + + +

Workout Statistics

@@ -97,6 +126,7 @@

{% if cordict %} +

Correlation Matrix

This matrix indicates a positive (+) or negative (-) correlation between two parameters. The Spearman correlation coefficient has values between +1 and -1. Positive correlation between two metrics means that if one metric increases, the other value is also likely to increase. Negative is the opposite. The further from zero, the higher the likelyhood.

@@ -132,8 +162,13 @@ {% endfor %} +
{% endif %} -
+ +
+ {{ plotdiv|safe }} +
+
{% endblock %} diff --git a/rowers/templates/histoall.html b/rowers/templates/histoall.html index 11f7b63e..6b1ee9c6 100644 --- a/rowers/templates/histoall.html +++ b/rowers/templates/histoall.html @@ -51,4 +51,4 @@ -{% endblock %} \ No newline at end of file +{% endblock %} diff --git a/rowers/views.py b/rowers/views.py index 1e6b24c8..b0cb9fcd 100644 --- a/rowers/views.py +++ b/rowers/views.py @@ -3834,7 +3834,7 @@ def workout_geeky_view(request,id=0,message="",successmessage=""): # Cumulative stats page @login_required() def cumstats(request,theuser=0, - startdate=timezone.now()-datetime.timedelta(days=365), + startdate=timezone.now()-datetime.timedelta(days=30), enddate=timezone.now(), deltadays=-1, startdatestring="", @@ -3957,6 +3957,12 @@ def cumstats(request,theuser=0, ids = [int(workout.id) for workout in allergworkouts] + datemapping = { + w.id:w.date for w in allergworkouts + } + + + fieldlist,fielddict = dataprep.getstatsfields() # prepare data frame @@ -3972,6 +3978,7 @@ def cumstats(request,theuser=0, # Create stats stats = {} fielddict.pop('workoutstate') + fielddict.pop('workoutid') for field,verbosename in fielddict.iteritems(): thedict = { @@ -3998,8 +4005,13 @@ def cumstats(request,theuser=0, except KeyError: thedict[field2] = 0 - cordict[field1] = thedict + cordict[field1] = thedict + # interactive box plot + datadf['workoutid'].replace(datemapping,inplace=True) + datadf.rename(columns={"workoutid":"date"},inplace=True) + script,div = interactive_boxchart(datadf,'wash') + # set options form correctly initial = {} initial['includereststrokes'] = includereststrokes @@ -4027,6 +4039,8 @@ def cumstats(request,theuser=0, 'deltaform':deltaform, 'optionsform':optionsform, 'cordict':cordict, + 'plotscript':script, + 'plotdiv':div, }) request.session['options'] = options