Private
Public Access
1
0

adding better rscore calc from power zone

This commit is contained in:
2023-08-15 09:05:10 +02:00
parent cd9fba9121
commit aa40c6e725
7 changed files with 39 additions and 10 deletions

View File

@@ -991,7 +991,9 @@ class SessionDateShiftForm(forms.Form):
class DeltaDaysForm(forms.Form):
deltadays = forms.IntegerField(initial=7, required=False, label='')
class PlanByRscoreForm(forms.Form):
byrscore = forms.BooleanField(initial=False, required=False, label='plan by rScore')
class RegistrationForm(UserCreationForm):
"""
Form for registering a new user account.

View File

@@ -2813,7 +2813,7 @@ class PlannedSession(models.Model):
self.sessionvalue = self.approximate_duration
elif self.sessionmode == 'distance': # pragma: no cover
self.sessionvalue = self.approximate_distance
elif self.sessionmode == 'rscore': # pragma: no cover
elif self.sessionmode == 'rScore': # pragma: no cover
self.sessionvalue = self.approximate_rscore
super(PlannedSession, self).save(*args, **kwargs)

View File

@@ -1063,7 +1063,7 @@ def get_workouts_session(r, ps):
return ws
def create_sessions_from_json(plansteps, rower, startdate, manager):
def create_sessions_from_json(plansteps, rower, startdate, manager, planbyrscore=False):
trainingdays = plansteps['trainingDays']
planstartdate = startdate
for day in trainingdays:
@@ -1076,6 +1076,10 @@ def create_sessions_from_json(plansteps, rower, startdate, manager):
preferreddate = planstartdate+timedelta(days=day['order'])
sessionmode = 'time'
if planbyrscore:
sessionmode = 'rScore'
ps = PlannedSession(
startdate=preferreddate -
timedelta(days=preferreddate.weekday()),
@@ -1086,7 +1090,7 @@ def create_sessions_from_json(plansteps, rower, startdate, manager):
name=workout['workoutName'],
steps=workout,
manager=manager,
sessionmode='time',
sessionmode=sessionmode,
comment=workout['description']
)

View File

@@ -58,6 +58,9 @@
{% endif %}
<table>
{{ form.as_table }}
{% if byrscoreform %}
{{ byrscoreform.as_table }}
{% endif %}
</table>
{% csrf_token %}
{% if plan.price|discounted:rower == 0 %}

View File

@@ -690,7 +690,7 @@ def steps_write_fit(steps):
return filename
def step_to_time_dist(step, avgspeed=3.2, ftp=200, ftspm=25, ftv=3.7):
def step_to_time_dist(step, avgspeed=3.2, ftp=200, ftspm=25, ftv=3.7, powerzones=None):
seconds = 0
distance = 0
rscore = 0
@@ -732,7 +732,9 @@ def step_to_time_dist(step, avgspeed=3.2, ftp=200, ftspm=25, ftv=3.7):
if value != 0:
if value < 10 and value > 0: # pragma: no cover
targetpower = ftp*0.6
targetpower = ftp*0.6 # dit is niet correct
if powerzones is not None and value < len(powerzones)-1 and value>1:
targetpower = (powerzones[int(value)-1]+powerzones[int(value)])/(2.)
elif value > 10 and value < 1000: # pragma: no cover
targetpower = value*ftp/100.
elif value > 1000:
@@ -890,15 +892,17 @@ def ps_dict_order(d, short=False, rower=None, html=True):
steps = d['steps']
ftp = 200
powerzones = None
if rower is not None:
ftp = rower.ftp
powerzones = [rower.pw_ut2, rower.pw_ut1, rower.pw_at, rower.pw_tr, rower.pw_an]
# ftv = rower.ftv
# ftspm = rower.ftspm
for step in steps:
sstring, type, stepID, repeatID, repeatValue = step_to_string(
step, short=short)
seconds, meters, rscore = step_to_time_dist(step, ftp=ftp)
seconds, meters, rscore = step_to_time_dist(step, ftp=ftp, powerzones=powerzones)
sdict[stepID] = {
'string': sstring,

View File

@@ -1417,7 +1417,6 @@ def save_plan_yaml(request, userid=0):
elif ps.sessionmode == 'time':
ps.interval_string = '{d}min'.format(d=ps.sessionvalue)
elif ps.sessionmode == 'rScore':
print('aap')
ps.approximate_duration = ps.sessionvalue
ps.interval_string = '{d}min'.format(d=ps.sessionvalue)
elif ps.sessionmode == 'TRIMP':
@@ -2670,6 +2669,14 @@ def rower_view_instantplan(request, id='', userid=0):
return HttpResponseRedirect(url)
form = InstantPlanSelectForm(request.POST, targets=targets)
byrscoreform = PlanByRscoreForm(request.POST)
if byrscoreform.is_valid():
try:
byrscore = byrscoreform.cleaned_data['byrscore']
except KeyError:
byrscore = False
else:
byrscore = False
if form.is_valid():
if plan.price > 0: # pragma: no cover
@@ -2718,7 +2725,7 @@ def rower_view_instantplan(request, id='', userid=0):
p.save()
p.rowers.add(r)
create_sessions_from_json(plansteps, r, startdate, r.user)
create_sessions_from_json(plansteps, r, startdate, r.user, planbyrscore=byrscore)
messages.info(request, 'Your Sessions have been added')
@@ -2739,6 +2746,13 @@ def rower_view_instantplan(request, id='', userid=0):
}
form = InstantPlanSelectForm(
targets=targets, instantplan=plan, initial=initial)
if request.user.is_superuser:
byrscoreform = PlanByRscoreForm()
else:
byrscoreform = None
else: # pragma: no cover
form = None
@@ -2771,6 +2785,7 @@ def rower_view_instantplan(request, id='', userid=0):
'rower': r,
'active': 'nav-plan',
'plan': plan,
'byrscoreform': byrscoreform,
'trainingdays': trainingdays2,
'breadcrumbs': breadcrumbs,
'form': form,
@@ -2983,6 +2998,7 @@ def rower_create_trainingplan(request, id=0):
initial={'status': False, 'rowers': [therower]},
user=request.user)
breadcrumbs = [
{
'url': reverse(plannedsessions_view,

View File

@@ -113,7 +113,7 @@ from rowers.forms import (
StravaChartForm, FitnessFitForm, PerformanceManagerForm,
TrainingPlanBillingForm, InstantPlanSelectForm,
TrainingZonesForm, InstrokeForm, InStrokeMultipleCompareForm,
ForceCurveMultipleCompareForm
ForceCurveMultipleCompareForm, PlanByRscoreForm
)
from django.urls import reverse, reverse_lazy