diff --git a/Htmldocs/release_notes.html b/Htmldocs/release_notes.html
index 96ccb727..1113ce31 100644
--- a/Htmldocs/release_notes.html
+++ b/Htmldocs/release_notes.html
@@ -30,6 +30,7 @@
[fix] Add support for rise time mode on DreamStation BiPAP devices (600X-700X).
[fix] Remove the ramp time and pressure settings when the ramp is disabled on pre-DreamStation devices.
[fix] Improve import of Philips Respironics oximetry data.
+ [fix] Fix VS2 index shown on the Daily page for Philips Respironics machines.
[fix] Fix occasional failure to save imported Viatom data.
[fix] Fix a recurring database upgrade prompt.
[fix] Fix an occasional crash when importing Resmed data.
diff --git a/oscar/SleepLib/loader_plugins/prs1_loader.cpp b/oscar/SleepLib/loader_plugins/prs1_loader.cpp
index 352aad4e..8bc9a3b9 100644
--- a/oscar/SleepLib/loader_plugins/prs1_loader.cpp
+++ b/oscar/SleepLib/loader_plugins/prs1_loader.cpp
@@ -3131,14 +3131,16 @@ void PRS1Import::ImportEvent(qint64 t, PRS1ParsedEvent* e)
// TODO: The numeric snore graph is the right way to present this information,
// but it needs to be shifted left 2 minutes, since it's not a starting value
// but a past statistic.
- AddEvent(channel, t, e->m_value, e->m_gain); // Snore count
+ AddEvent(channel, t, e->m_value, e->m_gain); // Snore count, continuous data
if (e->m_value > 0) {
// TODO: currently these get drawn on our waveforms, but they probably shouldn't,
// since they don't have a precise timestamp. They should continue to be drawn
// on the flags overview. See the comment in ImportEventChunk regarding flags
// for numeric channels.
+ //
+ // We need to pass the count along so that the VS2 index will tabulate correctly.
VS2 = *channels.at(1);
- AddEvent(VS2, t, 0, 1);
+ AddEvent(VS2, t, e->m_value, 1);
}
break;
case PRS1VibratorySnoreEvent::TYPE: // real VS marker on waveform
diff --git a/oscar/SleepLib/loader_plugins/prs1_loader.h b/oscar/SleepLib/loader_plugins/prs1_loader.h
index d44d7f4a..073b341b 100644
--- a/oscar/SleepLib/loader_plugins/prs1_loader.h
+++ b/oscar/SleepLib/loader_plugins/prs1_loader.h
@@ -25,7 +25,7 @@
//********************************************************************************************
// Please INCREMENT the following value when making changes to this loaders implementation
// BEFORE making a release
-const int prs1_data_version = 18;
+const int prs1_data_version = 19;
//
//********************************************************************************************
#if 0 // Apparently unused
diff --git a/oscar/daily.cpp b/oscar/daily.cpp
index 401703d2..4c99105f 100644
--- a/oscar/daily.cpp
+++ b/oscar/daily.cpp
@@ -1672,6 +1672,9 @@ void Daily::Load(QDate date)
if (chan.type() == schema::SPAN) {
val = (100.0 / hours)*(day->sum(code)/3600.0);
data = QString("%1%").arg(val,0,'f',2);
+ } else if (code == CPAP_VSnore2) { // TODO: This should be generalized rather than special-casing a single channel here.
+ val = day->sum(code) / hours;
+ data = QString("%1").arg(val,0,'f',2);
} else {
val = day->count(code) / hours;
data = QString("%1").arg(val,0,'f',2);
diff --git a/oscar/reports.cpp b/oscar/reports.cpp
index 484ea1b1..1449b797 100644
--- a/oscar/reports.cpp
+++ b/oscar/reports.cpp
@@ -223,6 +223,9 @@ void Report::PrintReport(gGraphView *gv, QString name, QDate date)
float cai = day->count(CPAP_ClearAirway) / hours;
float rei = day->count(CPAP_RERA) / hours;
float vsi = day->count(CPAP_VSnore) / hours;
+ if (day->channelHasData(CPAP_VSnore2)) { // PRS1 puts its 2-minute VS count in a different channel rather than reporting each incident.
+ vsi = day->sum(CPAP_VSnore2) / hours;
+ }
float fli = day->count(CPAP_FlowLimit) / hours;
// float sai = day->count(CPAP_SensAwake) / hours;
float nri = day->count(CPAP_NRI) / hours;