Private
Public Access
1
0
This commit is contained in:
2024-05-21 08:51:50 +02:00
parent 7733298f5c
commit 59ab7aaae4
10 changed files with 91 additions and 26 deletions

View File

@@ -1554,19 +1554,22 @@ def read_data(columns, ids=[], doclean=True, workstrokesonly=True, debug=False,
_ = dataplep(rowdata.df, id=id, _ = dataplep(rowdata.df, id=id,
bands=True, otwpower=True, barchart=True, bands=True, otwpower=True, barchart=True,
polars=True) polars=True)
df = pl.scan_parquet(f) try:
if startenddict: df = pl.scan_parquet(f)
try: if startenddict:
startsecond, endsecond = startenddict[id] try:
df = df.filter(pl.col("time") >= 1.0e3*startsecond, startsecond, endsecond = startenddict[id]
pl.col("time") <= 1.0e3*endsecond) df = df.filter(pl.col("time") >= 1.0e3*startsecond,
df = df.with_columns(time = pl.col("time")-1.0e3*startsecond) pl.col("time") <= 1.0e3*endsecond)
if 'cumdist' in columns: df = df.with_columns(time = pl.col("time")-1.0e3*startsecond)
df = df.collect() if 'cumdist' in columns:
df = df.with_columns(cumdist = pl.col("cumdist")-df[0, "cumdist"]).lazy() df = df.collect()
except KeyError: df = df.with_columns(cumdist = pl.col("cumdist")-df[0, "cumdist"]).lazy()
pass except KeyError:
data.append(df) pass
data.append(df)
except ComputeError:
pass
try: try:
data = pl.collect_all(data) data = pl.collect_all(data)
@@ -2169,14 +2172,16 @@ def dataplep(rowdatadf, id=0, inboard=0.88, forceunit='lbs', bands=True, barchar
df = df.with_columns((pl.col(" AverageDriveForce (lbs)")/pl.col(" PeakDriveForce (lbs)")).alias("forceratio")) df = df.with_columns((pl.col(" AverageDriveForce (lbs)")/pl.col(" PeakDriveForce (lbs)")).alias("forceratio"))
else: else:
df = df.with_columns((pl.lit(0)).alias("forceratio")) df = df.with_columns((pl.lit(0)).alias("forceratio"))
f = df['TimeStamp (sec)'].diff().mean() try:
f = df['TimeStamp (sec)'].diff().mean()
except TypeError:
f = 0
windowsize = 1
if f != 0 and not np.isinf(f): if f != 0 and not np.isinf(f):
try: try:
windowsize = 2 * (int(10. / (f))) + 1 windowsize = 2 * (int(10. / (f))) + 1
except ValueError: except ValueError:
windowsize = 1 windowsize = 1
else:
windowsize = 1
if windowsize <= 3: if windowsize <= 3:
windowsize = 5 windowsize = 5

View File

@@ -22,7 +22,7 @@ import polars as pl
import pytz import pytz
from rowers.rower_rules import ispromember from rowers.rower_rules import ispromember
from polars.exceptions import ColumnNotFoundError from polars.exceptions import ColumnNotFoundError, ComputeError
from scipy.interpolate import griddata from scipy.interpolate import griddata
from scipy.signal import savgol_filter from scipy.signal import savgol_filter
@@ -758,16 +758,28 @@ def performance_chart(user, startdate=None, enddate=None, kfitness=42, kfatigue=
df = df.filter(pl.col("date") > startdate) df = df.filter(pl.col("date") > startdate)
df2 = pl.DataFrame({ try:
"testpower" :df['testpower'], df2 = pl.DataFrame({
"testduration":df['testduration'].apply( "testpower" :df['testpower'],
lambda x: totaltime_sec_to_string(x, shorten=True)), "testduration":df['testduration'].apply(
"fitness":df['fitness'], lambda x: totaltime_sec_to_string(x, shorten=True)),
"fatigue":df['fatigue'], "fitness":df['fitness'],
"form":df['form'], "fatigue":df['fatigue'],
"impulse":df['impulse'], "form":df['form'],
"date": df['date'].dt.strftime('%Y-%m-%d'), "impulse":df['impulse'],
"date": df['date'].dt.strftime('%Y-%m-%d'),
}) })
except ComputeError:
df2 = pl.DataFrame({
"testpower" :df['testpower'],
"fitness":df['fitness'],
"fatigue":df['fatigue'],
"form":df['form'],
"impulse":df['impulse'],
"date": df['date'].dt.strftime('%Y-%m-%d'),
})
df2 = df2.with_columns((pl.lit("--")).alias("testduration"))
df2 = df2.fill_nan(0) df2 = df2.fill_nan(0)

View File

@@ -0,0 +1,22 @@
{% load rowerfilters %}
{% load tz %}
<ul class="main-content">
<li class="grid_2">
<table width=100%>
<tr>
{% localtime on %}
<th>Seat Number:</th><td>{{ workout.seatnumber}}</td>
{% endlocaltime %}
</tr><tr>
<th>Empower side:</th><td>{{ workout.empowerside }}</td>
</tr><tr>
<th>Boat name:</th><td>{{ workout.boatname }}</td>
</tr><tr>
<th>Oar length:</th><td>{{ workout.oarlength }}</td>
</tr><tr>
<th>Oar inboard:</th><td>{{ workout.inboard }}</td>
</tr>
</table>
</li>
</ul>

View File

@@ -95,6 +95,9 @@ class CPChartTest(TestCase):
'distance': 500, 'distance': 500,
'workouttype': 'rower', 'workouttype': 'rower',
'boattype': '1x', 'boattype': '1x',
'boatname': 'CatchUp',
'empowerside': 'starboard',
'seatnumber': 1,
'weightcategory': 'hwt', 'weightcategory': 'hwt',
'adaptiveclass': 'None', 'adaptiveclass': 'None',
'notes': faker.text(), 'notes': faker.text(),

View File

@@ -1121,6 +1121,9 @@ class IndoorChallengesTest(TestCase):
'adaptiveclass': 'None', 'adaptiveclass': 'None',
'notes': faker.text(), 'notes': faker.text(),
'rankingpiece': True, 'rankingpiece': True,
'empowerside': 'port',
'boatname': 'Dolfijn',
'seatnumber': 1,
'duplicate': False, 'duplicate': False,
'avghr': '160', 'avghr': '160',
'avgpwr': 0, 'avgpwr': 0,

View File

@@ -34,6 +34,9 @@ class DataTest(TestCase):
'workouttype':'water', 'workouttype':'water',
'rpe':1, 'rpe':1,
'boattype':'1x', 'boattype':'1x',
'boatname': 'BOAT1',
'empowerside': 'port',
'seatnumber': 4,
'private':False, 'private':False,
} }
form = WorkoutForm(data=form_data) form = WorkoutForm(data=form_data)

View File

@@ -101,6 +101,9 @@ class ViewTest(TestCase):
'rpe':4, 'rpe':4,
'dragfactor':'112', 'dragfactor':'112',
'raceid':0, 'raceid':0,
'seatnumber': 1,
'boatname': '',
'empowerside': 'port',
'landingpage':'workout_edit_view', 'landingpage':'workout_edit_view',
'private':True, 'private':True,
'notes':'noot mies', 'notes':'noot mies',

Binary file not shown.

View File

@@ -64,6 +64,7 @@ workflowmiddlepanel = (
('panel_summary.html', 'Summary'), ('panel_summary.html', 'Summary'),
('panel_map.html', 'Map'), ('panel_map.html', 'Map'),
('panel_comments.html', 'Basic Info and Links'), ('panel_comments.html', 'Basic Info and Links'),
('panel_empower.html', 'Empower Oarlock Info'),
('panel_notes.html', 'Workout Notes'), ('panel_notes.html', 'Workout Notes'),
('panel_shortcomment.html', 'Comment Link'), ('panel_shortcomment.html', 'Comment Link'),
('panel_middlesocial.html', 'Social Media Share Buttons'), ('panel_middlesocial.html', 'Social Media Share Buttons'),

View File

@@ -680,6 +680,9 @@ def addmanual_view(request, raceid=0):
privacy = form.cleaned_data.get('privacy', 'visible') privacy = form.cleaned_data.get('privacy', 'visible')
rankingpiece = form.cleaned_data.get('rankingpiece', False) rankingpiece = form.cleaned_data.get('rankingpiece', False)
duplicate = form.cleaned_data.get('duplicate', False) duplicate = form.cleaned_data.get('duplicate', False)
seatnumber = form.cleaned_data.get('seatnumber', 1)
boatname = form.cleaned_data.get('boatname', '')
empowerside = form.cleaned_data.get('empowerside','port')
if private: # pragma: no cover if private: # pragma: no cover
privacy = 'private' privacy = 'private'
@@ -723,6 +726,9 @@ def addmanual_view(request, raceid=0):
w.rpe = rpe w.rpe = rpe
w.workouttype = workouttype w.workouttype = workouttype
w.boattype = boattype w.boattype = boattype
w.boatname = boatname
w.empowerside = empowerside
w.seatnumber = seatnumber
w.distance = distance w.distance = distance
w.duration = duration w.duration = duration
w.save() w.save()
@@ -4385,6 +4391,10 @@ def workout_edit_view(request, id=0, message="", successmessage=""):
'rankingpiece', Workout.objects.get(id=row.id).rankingpiece) 'rankingpiece', Workout.objects.get(id=row.id).rankingpiece)
duplicate = form.cleaned_data.get( duplicate = form.cleaned_data.get(
'duplicate', Workout.objects.get(id=row.id).duplicate) 'duplicate', Workout.objects.get(id=row.id).duplicate)
seatnumber = form.cleaned_data.get('seatnumber', 1)
boatname = form.cleaned_data.get('boatname', '')
empowerside = form.cleaned_data.get('empowerside','port')
if private: if private:
privacy = 'private' privacy = 'private'
@@ -4438,6 +4448,9 @@ def workout_edit_view(request, id=0, message="", successmessage=""):
row.rankingpiece = rankingpiece row.rankingpiece = rankingpiece
row.timezone = thetimezone row.timezone = thetimezone
row.plannedsession = ps row.plannedsession = ps
row.boatname = boatname
row.empowerside = empowerside
row.seatnumber = seatnumber
dragchanged = False dragchanged = False
if newdragfactor != row.dragfactor: # pragma: no cover if newdragfactor != row.dragfactor: # pragma: no cover