mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-06 03:00:43 +00:00
Report pressure when IPAP is missing. This is a preliminary change and will be improved later.
This commit is contained in:
parent
dcf68dac37
commit
d990ce560a
@ -109,7 +109,7 @@ void Day::addSession(Session *s)
|
|||||||
if (mi != machines.end()) {
|
if (mi != machines.end()) {
|
||||||
if (mi.value() != s->machine()) {
|
if (mi.value() != s->machine()) {
|
||||||
qDebug() << "OSCAR can't add session" << s->session()
|
qDebug() << "OSCAR can't add session" << s->session()
|
||||||
<< "["+QDateTime::fromTime_t(s->first()).toString("MMM dd, yyyy hh:mm:ss")+"]"
|
<< "["+QDateTime::fromTime_t(s->session()).toString("MMM dd, yyyy hh:mm:ss")+"]"
|
||||||
<< "from machine" << mi.value()->serial() << "to machine" << s->machine()->serial()
|
<< "from machine" << mi.value()->serial() << "to machine" << s->machine()->serial()
|
||||||
<< "to this day record, as it already contains a different machine of the same MachineType" << s->type();
|
<< "to this day record, as it already contains a different machine of the same MachineType" << s->type();
|
||||||
return;
|
return;
|
||||||
@ -803,6 +803,23 @@ qint64 Day::total_time(MachineType type)
|
|||||||
return total; //d_totaltime;
|
return total; //d_totaltime;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ChannelID Day::getPressureChannelID() {
|
||||||
|
// Determined the preferred pressure channel (CPAP_IPAP or CPAP_Pressure)
|
||||||
|
CPAPMode cpapmode = (CPAPMode)(int)settings_max(CPAP_Mode);
|
||||||
|
ChannelID preferredID = CPAP_Pressure;
|
||||||
|
if (cpapmode == MODE_ASV || cpapmode == MODE_ASV_VARIABLE_EPAP || cpapmode == MODE_AVAPS)
|
||||||
|
preferredID = CPAP_IPAP;
|
||||||
|
|
||||||
|
// If preferred channel has data, return it
|
||||||
|
if (channelHasData(preferredID))
|
||||||
|
return preferredID;
|
||||||
|
|
||||||
|
// Otherwise return the other pressure channel
|
||||||
|
if (preferredID == CPAP_IPAP)
|
||||||
|
return CPAP_Pressure;
|
||||||
|
else
|
||||||
|
return CPAP_IPAP;
|
||||||
|
}
|
||||||
|
|
||||||
bool Day::hasEnabledSessions()
|
bool Day::hasEnabledSessions()
|
||||||
{
|
{
|
||||||
@ -1479,7 +1496,7 @@ QString Day::getPressureSettings()
|
|||||||
} else if (mode == MODE_BILEVEL_AUTO_VARIABLE_PS) {
|
} else if (mode == MODE_BILEVEL_AUTO_VARIABLE_PS) {
|
||||||
return QObject::tr("Min EPAP %1 Max IPAP %2 PS %3-%4 (%5)").arg(settings_min(CPAP_EPAPLo),0,'f',1).arg(settings_max(CPAP_IPAPHi),0,'f',1).arg(settings_min(CPAP_PSMin),0,'f',1).arg(settings_max(CPAP_PSMax),0,'f',1).arg(units);
|
return QObject::tr("Min EPAP %1 Max IPAP %2 PS %3-%4 (%5)").arg(settings_min(CPAP_EPAPLo),0,'f',1).arg(settings_max(CPAP_IPAPHi),0,'f',1).arg(settings_min(CPAP_PSMin),0,'f',1).arg(settings_max(CPAP_PSMax),0,'f',1).arg(units);
|
||||||
} else if (mode == MODE_ASV) {
|
} else if (mode == MODE_ASV) {
|
||||||
return QObject::tr("EPAP %1 PS %2-%3 (%6)").arg(settings_min(CPAP_EPAP),0,'f',1).arg(settings_min(CPAP_PSMin),0,'f',1).arg(settings_max(CPAP_PSMax),0,'f',1).arg(units);
|
return QObject::tr("EPAP %1 PS %2-%3 (%4)").arg(settings_min(CPAP_EPAP),0,'f',1).arg(settings_min(CPAP_PSMin),0,'f',1).arg(settings_max(CPAP_PSMax),0,'f',1).arg(units);
|
||||||
} else if (mode == MODE_ASV_VARIABLE_EPAP) {
|
} else if (mode == MODE_ASV_VARIABLE_EPAP) {
|
||||||
return QObject::tr("Min EPAP %1 Max IPAP %2 PS %3-%4 (%5)").
|
return QObject::tr("Min EPAP %1 Max IPAP %2 PS %3-%4 (%5)").
|
||||||
arg(settings_min(CPAP_EPAPLo),0,'f',1).
|
arg(settings_min(CPAP_EPAPLo),0,'f',1).
|
||||||
|
@ -213,6 +213,9 @@ class Day
|
|||||||
//! \brief Closes all Events files for this Days Sessions
|
//! \brief Closes all Events files for this Days Sessions
|
||||||
void CloseEvents();
|
void CloseEvents();
|
||||||
|
|
||||||
|
//! \brief Get the ChannelID to be used for reporting pressure
|
||||||
|
ChannelID getPressureChannelID();
|
||||||
|
|
||||||
//! \brief Returns true if this Day contains loaded Event Data for this channel.
|
//! \brief Returns true if this Day contains loaded Event Data for this channel.
|
||||||
bool channelExists(ChannelID id);
|
bool channelExists(ChannelID id);
|
||||||
|
|
||||||
|
@ -227,34 +227,35 @@ QString Welcome::GenerateCPAPHTML()
|
|||||||
html += "<br/>";
|
html += "<br/>";
|
||||||
|
|
||||||
CPAPMode cpapmode = (CPAPMode)(int)day->settings_max(CPAP_Mode);
|
CPAPMode cpapmode = (CPAPMode)(int)day->settings_max(CPAP_Mode);
|
||||||
|
ChannelID pressChanID = day->getPressureChannelID(); // Get channel id for pressure that we should report
|
||||||
double perc= p_profile->general->prefCalcPercentile();
|
double perc= p_profile->general->prefCalcPercentile();
|
||||||
|
|
||||||
if (cpapmode == MODE_CPAP) {
|
if (cpapmode == MODE_CPAP) {
|
||||||
EventDataType pressure = day->settings_max(CPAP_Pressure);
|
EventDataType pressure = day->settings_max(pressChanID);
|
||||||
html += tr("Your CPAP machine used a constant %1 %2 of air").arg(pressure).arg(schema::channel[CPAP_Pressure].units());
|
html += tr("Your CPAP machine used a constant %1 %2 of air").arg(pressure).arg(schema::channel[pressChanID].units());
|
||||||
} else if (cpapmode == MODE_APAP) {
|
} else if (cpapmode == MODE_APAP) {
|
||||||
EventDataType pressure = day->percentile(CPAP_Pressure, perc/100.0);
|
EventDataType pressure = day->percentile(pressChanID, perc/100.0);
|
||||||
html += tr("Your pressure was under %1 %2 for %3% of the time.").arg(pressure).arg(schema::channel[CPAP_Pressure].units()).arg(perc);
|
html += tr("Your pressure was under %1 %2 for %3% of the time.").arg(pressure).arg(schema::channel[pressChanID].units()).arg(perc);
|
||||||
} else if (cpapmode == MODE_BILEVEL_FIXED) {
|
} else if (cpapmode == MODE_BILEVEL_FIXED) {
|
||||||
EventDataType ipap = day->settings_max(CPAP_IPAP);
|
EventDataType ipap = day->settings_max(pressChanID);
|
||||||
EventDataType epap = day->settings_min(CPAP_EPAP);
|
EventDataType epap = day->settings_min(CPAP_EPAP);
|
||||||
html += tr("Your machine used a constant %1-%2 %3 of air.").arg(epap).arg(ipap).arg(schema::channel[CPAP_Pressure].units());
|
html += tr("Your machine used a constant %1-%2 %3 of air.").arg(epap).arg(ipap).arg(schema::channel[pressChanID].units());
|
||||||
} else if (cpapmode == MODE_BILEVEL_AUTO_FIXED_PS) {
|
} else if (cpapmode == MODE_BILEVEL_AUTO_FIXED_PS) {
|
||||||
EventDataType ipap = day->percentile(CPAP_IPAP, perc/100.0);
|
EventDataType ipap = day->percentile(pressChanID, perc/100.0);
|
||||||
EventDataType epap = day->percentile(CPAP_EPAP, perc/100.0);
|
EventDataType epap = day->percentile(CPAP_EPAP, perc/100.0);
|
||||||
html += tr("Your machine was under %1-%2 %3 for %4% of the time.").arg(epap).arg(ipap).arg(schema::channel[CPAP_Pressure].units()).arg(perc);
|
html += tr("Your machine was under %1-%2 %3 for %4% of the time.").arg(epap).arg(ipap).arg(schema::channel[pressChanID].units()).arg(perc);
|
||||||
} else if (cpapmode == MODE_ASV){
|
} else if (cpapmode == MODE_ASV){
|
||||||
EventDataType ipap = day->percentile(CPAP_IPAP, perc/100.0);
|
EventDataType ipap = day->percentile(pressChanID, perc/100.0);
|
||||||
EventDataType epap = qRound(day->settings_wavg(CPAP_EPAP));
|
EventDataType epap = qRound(day->settings_wavg(CPAP_EPAP));
|
||||||
|
|
||||||
html += tr("Your EPAP pressure fixed at %1 %2.").arg(epap).arg(schema::channel[CPAP_EPAP].units())+"<br/>";
|
html += tr("Your EPAP pressure fixed at %1 %2.").arg(epap).arg(schema::channel[CPAP_EPAP].units())+"<br/>";
|
||||||
html += tr("Your IPAP pressure was under %1 %2 for %3% of the time.").arg(ipap).arg(schema::channel[CPAP_IPAP].units()).arg(perc);
|
html += tr("Your IPAP pressure was under %1 %2 for %3% of the time.").arg(ipap).arg(schema::channel[pressChanID].units()).arg(perc);
|
||||||
} else if (cpapmode == MODE_ASV_VARIABLE_EPAP){
|
} else if (cpapmode == MODE_ASV_VARIABLE_EPAP){
|
||||||
EventDataType ipap = day->percentile(CPAP_IPAP, perc/100.0);
|
EventDataType ipap = day->percentile(pressChanID, perc/100.0);
|
||||||
EventDataType epap = day->percentile(CPAP_EPAP, perc/100.0);
|
EventDataType epap = day->percentile(CPAP_EPAP, perc/100.0);
|
||||||
|
|
||||||
html += tr("Your EPAP pressure was under %1 %2 for %3% of the time.").arg(epap).arg(schema::channel[CPAP_EPAP].units()).arg(perc)+"<br/>";
|
html += tr("Your EPAP pressure was under %1 %2 for %3% of the time.").arg(epap).arg(schema::channel[CPAP_EPAP].units()).arg(perc)+"<br/>";
|
||||||
html += tr("Your IPAP pressure was under %1 %2 for %3% of the time.").arg(ipap).arg(schema::channel[CPAP_IPAP].units()).arg(perc);
|
html += tr("Your IPAP pressure was under %1 %2 for %3% of the time.").arg(ipap).arg(schema::channel[pressChanID].units()).arg(perc);
|
||||||
}
|
}
|
||||||
html += "<br/>";
|
html += "<br/>";
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user