Private
Public Access
1
0

adding drive energy

This commit is contained in:
Sander Roosendaal
2018-06-21 18:52:23 +02:00
parent 9661bb2124
commit e17e5f5a86
3 changed files with 44 additions and 9 deletions

View File

@@ -2332,8 +2332,16 @@ def workout_normv(w,pp=4.0):
v4mean = wavg(df,'v4','deltat') v4mean = wavg(df,'v4','deltat')
normv = v4mean**(1./pp) normv = v4mean**(1./pp)
df['w4'] = df['driveenergy']**(pp)
w4mean = wavg(df,'w4','deltat')
normw = w4mean**(1./pp)
if np.isnan(normv): if np.isnan(normv):
return 500./120. normv = 500./120.
return normv if np.isnan(normw):
normw = 0
return normv,normw

View File

@@ -485,11 +485,13 @@ class MyTimeField(forms.TimeField):
class PowerIntervalUpdateForm(forms.Form): class PowerIntervalUpdateForm(forms.Form):
selectorchoices = ( selectorchoices = (
('power','Power'), ('power','Power'),
('pace','Pace') ('pace','Pace'),
('work','Work per Stroke'),
) )
pace = forms.DurationField(required=False,label='Pace (/500m)') pace = forms.DurationField(required=False,label='Pace (/500m)')
power = forms.IntegerField(required=False,label='Power (W)') power = forms.IntegerField(required=False,label='Power (W)')
work = forms.IntegerField(required=False,label='Work per Stroke (J)')
selector = forms.ChoiceField(choices=selectorchoices, selector = forms.ChoiceField(choices=selectorchoices,
required=True, required=True,
initial='power', initial='power',

View File

@@ -11293,7 +11293,7 @@ def workout_summary_edit_view(request,id,message="",successmessage=""
tss,normp = dataprep.workout_rscore(row) tss,normp = dataprep.workout_rscore(row)
normv = dataprep.workout_normv(row,pp=8.0) normv,normw = dataprep.workout_normv(row,pp=8.0)
try: try:
avpace = datetime.timedelta(seconds=int(500./normv)) avpace = datetime.timedelta(seconds=int(500./normv))
@@ -11304,6 +11304,7 @@ def workout_summary_edit_view(request,id,message="",successmessage=""
'power': int(normp), 'power': int(normp),
'pace': avpace, 'pace': avpace,
'selector': 'power', 'selector': 'power',
'work': int(normw)
} }
powerorpace = 'power' powerorpace = 'power'
@@ -11337,15 +11338,21 @@ def workout_summary_edit_view(request,id,message="",successmessage=""
powerorpace = request.POST['powerorpace'] powerorpace = request.POST['powerorpace']
value_pace = request.POST['value_pace'] value_pace = request.POST['value_pace']
value_power = request.POST['value_power'] value_power = request.POST['value_power']
value_work = request.POST['value_work']
if powerorpace == 'power': if powerorpace == 'power':
power = int(value_power) power = int(value_power)
pace_secs = 120.0 pace_secs = 120.0
else: work = 400.
elif powerorpace == 'pace':
power = 0 power = 0
try: try:
pace_secs = float(value_pace) pace_secs = float(value_pace)
except ValueError: except ValueError:
pace_secs = float(value_pace.replace(',','.')) pace_secs = float(value_pace.replace(',','.'))
elif powerorpace == 'work':
power = 0
work = int(value_work)
pace_secs = 120.0
if powerorpace == 'power' and power is not None: if powerorpace == 'power' and power is not None:
try: try:
@@ -11362,6 +11369,13 @@ def workout_summary_edit_view(request,id,message="",successmessage=""
debug=False,smoothwindow=15.) debug=False,smoothwindow=15.)
except: except:
messages.error(request,'Error updating pace') messages.error(request,'Error updating pace')
elif powerorpace == 'work':
try:
rowdata.updateinterval_metric(
' WorkPerStroke (joules)',work,mode='larger',
debug=False,smoothwindow=15.)
except:
messages.error(request,'Error updating Work per Stroke')
intervalstats = rowdata.allstats() intervalstats = rowdata.allstats()
itime,idist,itype = rowdata.intervalstats_values() itime,idist,itype = rowdata.intervalstats_values()
@@ -11386,7 +11400,8 @@ def workout_summary_edit_view(request,id,message="",successmessage=""
formvalues = { formvalues = {
'powerorpace': powerorpace, 'powerorpace': powerorpace,
'value_power': power, 'value_power': power,
'value_pace': pace_secs 'value_pace': pace_secs,
'value_work':work,
} }
@@ -11429,6 +11444,7 @@ def workout_summary_edit_view(request,id,message="",successmessage=""
powerorpace = cd['selector'] powerorpace = cd['selector']
power = cd['power'] power = cd['power']
pace = cd['pace'] pace = cd['pace']
work = cd['work']
try: try:
pace_secs = pace.seconds+pace.microseconds/1.0e6 pace_secs = pace.seconds+pace.microseconds/1.0e6
except AttributeError: except AttributeError:
@@ -11447,6 +11463,14 @@ def workout_summary_edit_view(request,id,message="",successmessage=""
debug=False,smoothwindow=15) debug=False,smoothwindow=15)
except: except:
messages.error(request,'Error updating pace') messages.error(request,'Error updating pace')
elif powerorpace == 'work':
try:
rowdata.updateinterval_metric(
'driveenergy',work,mode='larger',
debug=False,smoothwindow=15.)
except:
messages.error(request,'Error updating Work per Stroke')
intervalstats = rowdata.allstats() intervalstats = rowdata.allstats()
itime,idist,itype = rowdata.intervalstats_values() itime,idist,itype = rowdata.intervalstats_values()
@@ -11455,7 +11479,8 @@ def workout_summary_edit_view(request,id,message="",successmessage=""
formvalues = { formvalues = {
'powerorpace': powerorpace, 'powerorpace': powerorpace,
'value_power': power, 'value_power': power,
'value_pace': pace_secs 'value_pace': pace_secs,
'value_work': work,
} }
powerupdateform = PowerIntervalUpdateForm(initial=cd) powerupdateform = PowerIntervalUpdateForm(initial=cd)
form = SummaryStringForm() form = SummaryStringForm()