mirror of
https://github.com/GoldenCheetah/GoldenCheetah.git
synced 2026-02-13 16:18:42 +00:00
This patch introduces new functionality for working with Heartrate based data. * HR Zones can be defined, from Resting, Maximum and Lactate HR * TRIMP metrics are calculated; TRIMP, TRIMP100 and Zonal TRIMP * TRIMP metrics can be used to drive the PMC * Time In Zone metrics for HR have been added * Histogram window will now work with Power/HR zones * User Settings have been added to record gender, weight and others * RideFile has a new tag "Athlete" which is set to the athlete name Fixes #140
174 lines
4.5 KiB
C++
174 lines
4.5 KiB
C++
|
|
/*
|
|
* Copyright (c) 2010 Damien Grauser (Damien.Grauser@pev-geneve.ch), Mark Liversedge (liversedge@gmail.com)
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the Free
|
|
* Software Foundation; either version 2 of the License, or (at your option)
|
|
* any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
* more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc., 51
|
|
* Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include "RideMetric.h"
|
|
#include "BestIntervalDialog.h"
|
|
#include "HrZones.h"
|
|
#include <math.h>
|
|
|
|
#define tr(s) QObject::tr(s)
|
|
|
|
class HrZoneTime : public RideMetric {
|
|
int level;
|
|
double seconds;
|
|
|
|
QList<int> lo;
|
|
QList<int> hi;
|
|
|
|
public:
|
|
|
|
HrZoneTime() : level(0), seconds(0.0)
|
|
{
|
|
setType(RideMetric::Total);
|
|
setMetricUnits("seconds");
|
|
setImperialUnits("seconds");
|
|
setPrecision(0);
|
|
setConversion(1.0);
|
|
}
|
|
void setLevel(int level) { this->level=level-1; } // zones start from zero not 1
|
|
void compute(const RideFile *ride, const Zones *, int, const HrZones *hrZone, int hrZoneRange,
|
|
const QHash<QString,RideMetric*> &)
|
|
{
|
|
seconds = 0;
|
|
// get zone ranges
|
|
if (hrZone && hrZoneRange >= 0) {
|
|
// iterate and compute
|
|
foreach(const RideFilePoint *point, ride->dataPoints()) {
|
|
if (hrZone->whichZone(hrZoneRange, point->hr) == level)
|
|
seconds += ride->recIntSecs();
|
|
}
|
|
}
|
|
setValue(seconds);
|
|
}
|
|
|
|
bool canAggregate() const { return false; }
|
|
void aggregateWith(const RideMetric &) {}
|
|
RideMetric *clone() const { return new HrZoneTime(*this); }
|
|
};
|
|
|
|
class HrZoneTime1 : public HrZoneTime {
|
|
|
|
public:
|
|
HrZoneTime1()
|
|
{
|
|
setLevel(1);
|
|
setSymbol("time_in_zone_H1");
|
|
setName(tr("H1 Time in Zone"));
|
|
}
|
|
RideMetric *clone() const { return new HrZoneTime1(*this); }
|
|
};
|
|
|
|
class HrZoneTime2 : public HrZoneTime {
|
|
|
|
public:
|
|
HrZoneTime2()
|
|
{
|
|
setLevel(2);
|
|
setSymbol("time_in_zone_H2");
|
|
setName(tr("H2 Time in Zone"));
|
|
}
|
|
RideMetric *clone() const { return new HrZoneTime2(*this); }
|
|
};
|
|
|
|
class HrZoneTime3 : public HrZoneTime {
|
|
|
|
public:
|
|
HrZoneTime3()
|
|
{
|
|
setLevel(3);
|
|
setSymbol("time_in_zone_H3");
|
|
setName(tr("H3 Time in Zone"));
|
|
}
|
|
RideMetric *clone() const { return new HrZoneTime3(*this); }
|
|
};
|
|
|
|
class HrZoneTime4 : public HrZoneTime {
|
|
|
|
public:
|
|
HrZoneTime4()
|
|
{
|
|
setLevel(4);
|
|
setSymbol("time_in_zone_H4");
|
|
setName(tr("H4 Time in Zone"));
|
|
}
|
|
RideMetric *clone() const { return new HrZoneTime4(*this); }
|
|
};
|
|
|
|
class HrZoneTime5 : public HrZoneTime {
|
|
|
|
public:
|
|
HrZoneTime5()
|
|
{
|
|
setLevel(5);
|
|
setSymbol("time_in_zone_H5");
|
|
setName(tr("H5 Time in Zone"));
|
|
}
|
|
RideMetric *clone() const { return new HrZoneTime5(*this); }
|
|
};
|
|
|
|
class HrZoneTime6 : public HrZoneTime {
|
|
|
|
public:
|
|
HrZoneTime6()
|
|
{
|
|
setLevel(6);
|
|
setSymbol("time_in_zone_H6");
|
|
setName(tr("H6 Time in Zone"));
|
|
}
|
|
RideMetric *clone() const { return new HrZoneTime6(*this); }
|
|
};
|
|
|
|
class HrZoneTime7 : public HrZoneTime {
|
|
|
|
public:
|
|
HrZoneTime7()
|
|
{
|
|
setLevel(7);
|
|
setSymbol("time_in_zone_H7");
|
|
setName(tr("H7 Time in Zone"));
|
|
}
|
|
RideMetric *clone() const { return new HrZoneTime7(*this); }
|
|
};
|
|
|
|
class HrZoneTime8 : public HrZoneTime {
|
|
|
|
public:
|
|
HrZoneTime8()
|
|
{
|
|
setLevel(8);
|
|
setSymbol("time_in_zone_H8");
|
|
setName(tr("H8 Time in Zone"));
|
|
}
|
|
RideMetric *clone() const { return new HrZoneTime8(*this); }
|
|
};
|
|
|
|
static bool addAllHrZones() {
|
|
RideMetricFactory::instance().addMetric(HrZoneTime1());
|
|
RideMetricFactory::instance().addMetric(HrZoneTime2());
|
|
RideMetricFactory::instance().addMetric(HrZoneTime3());
|
|
RideMetricFactory::instance().addMetric(HrZoneTime4());
|
|
RideMetricFactory::instance().addMetric(HrZoneTime5());
|
|
RideMetricFactory::instance().addMetric(HrZoneTime6());
|
|
RideMetricFactory::instance().addMetric(HrZoneTime7());
|
|
RideMetricFactory::instance().addMetric(HrZoneTime8());
|
|
return true;
|
|
}
|
|
|
|
static bool allHrZonesAdded = addAllHrZones();
|