Made Overview AHI SummaryChart show weighted average to match Statistics

This commit is contained in:
Mark Watkins 2012-01-03 14:36:47 +10:00
parent 60aa9a851f
commit ab09192ceb
4 changed files with 21 additions and 19 deletions

View File

@ -359,6 +359,7 @@ void SummaryChart::paint(gGraph & w,int left, int top, int width, int height)
//QHash<short, EventDataType> lastvalues; //QHash<short, EventDataType> lastvalues;
int total_days=0; int total_days=0;
double total_val=0; double total_val=0;
double total_hours=0;
//qint64 lastQ=0; //qint64 lastQ=0;
bool lastdaygood=false; bool lastdaygood=false;
QVector<double> totalcounts; QVector<double> totalcounts;
@ -481,7 +482,9 @@ void SummaryChart::paint(gGraph & w,int left, int top, int width, int height)
total=d.value()[0]; total=d.value()[0];
//if (total>0) { //if (total>0) {
if (day) { if (day) {
total_val+=total; EventDataType hours=m_hours[zd];
total_val+=total*hours;
total_hours+=hours;
total_days++; total_days++;
} }
py=top+height; py=top+height;
@ -640,12 +643,11 @@ jumpnext:
} }
if (m_graphtype==GT_BAR) { if (m_graphtype==GT_BAR) {
if (m_type.size()>1) { if (m_type.size()>1) {
float val=total_val/float(total_days); float val=total_val/float(total_hours);
a=m_label+"="+QString::number(val,'f',2)+" "; a=m_label+"="+QString::number(val,'f',2)+" ";
GetTextExtent(a,x,y); GetTextExtent(a,x,y);
px-=20+x; px-=20+x;
w.renderText(a,px+24,py+1); w.renderText(a,px+24,py+1);
//
} }
} }

View File

@ -442,12 +442,12 @@ EventDataType Day::Max(ChannelID code)
} }
EventDataType Day::cph(ChannelID code) EventDataType Day::cph(ChannelID code)
{ {
EventDataType sum=0; double sum=0;
//EventDataType h=0; //EventDataType h=0;
for (int i=0;i<sessions.size();i++) { for (int i=0;i<sessions.size();i++) {
if (!sessions[i]->enabled()) continue; if (!sessions[i]->enabled()) continue;
if (!sessions[i]->m_cph.contains(code)) continue; if (!sessions[i]->m_cnt.contains(code)) continue;
sum+=sessions[i]->cph(code)*sessions[i]->hours(); sum+=sessions[i]->count(code);
//h+=sessions[i]->hours(); //h+=sessions[i]->hours();
} }
sum/=hours(); sum/=hours();

View File

@ -253,7 +253,6 @@ void Profile::AddDay(QDate date,Day *day,MachineType mt) {
Day * Profile::GetGoodDay(QDate date,MachineType type) Day * Profile::GetGoodDay(QDate date,MachineType type)
{ {
Day *day=NULL; Day *day=NULL;
// profile-> why did I d that??
if (daylist.find(date)!=daylist.end()) { if (daylist.find(date)!=daylist.end()) {
for (QList<Day *>::iterator di=daylist[date].begin();di!=daylist[date].end();di++) { for (QList<Day *>::iterator di=daylist[date].begin();di!=daylist[date].end();di++) {
@ -613,7 +612,7 @@ EventDataType Profile::calcCount(ChannelID code, MachineType mt, QDate start, QD
val+=day->count(code); val+=day->count(code);
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
return val; return val;
} }
double Profile::calcSum(ChannelID code, MachineType mt, QDate start, QDate end) double Profile::calcSum(ChannelID code, MachineType mt, QDate start, QDate end)
@ -629,13 +628,15 @@ double Profile::calcSum(ChannelID code, MachineType mt, QDate start, QDate end)
val+=day->sum(code); val+=day->sum(code);
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
return val; return val;
} }
EventDataType Profile::calcHours(MachineType mt, QDate start, QDate end) EventDataType Profile::calcHours(MachineType mt, QDate start, QDate end)
{ {
if (!start.isValid()) start=LastGoodDay(mt); if (!start.isValid())
if (!end.isValid()) end=LastGoodDay(mt); start=LastGoodDay(mt);
if (!end.isValid())
end=LastGoodDay(mt);
QDate date=start; QDate date=start;
double val=0; double val=0;
@ -645,7 +646,7 @@ EventDataType Profile::calcHours(MachineType mt, QDate start, QDate end)
val+=day->hours(); val+=day->hours();
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
return val; return val;
} }
EventDataType Profile::calcAvg(ChannelID code, MachineType mt, QDate start, QDate end) EventDataType Profile::calcAvg(ChannelID code, MachineType mt, QDate start, QDate end)
@ -663,7 +664,7 @@ EventDataType Profile::calcAvg(ChannelID code, MachineType mt, QDate start, QDat
cnt++; cnt++;
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
if (!cnt) return 0; if (!cnt) return 0;
return val/float(cnt); return val/float(cnt);
} }
@ -685,7 +686,7 @@ EventDataType Profile::calcWavg(ChannelID code, MachineType mt, QDate start, QDa
hours+=tmph; hours+=tmph;
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
if (!hours) return 0; if (!hours) return 0;
val=val/hours; val=val/hours;
return val; return val;
@ -704,7 +705,7 @@ EventDataType Profile::calcMin(ChannelID code, MachineType mt, QDate start, QDat
if (min>tmp) min=tmp; if (min>tmp) min=tmp;
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
if (min>=99999999) min=0; if (min>=99999999) min=0;
return min; return min;
} }
@ -722,7 +723,7 @@ EventDataType Profile::calcMax(ChannelID code, MachineType mt, QDate start, QDat
if (max<tmp) max=tmp; if (max<tmp) max=tmp;
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
if (max<=-99999999) max=0; if (max<=-99999999) max=0;
return max; return max;
} }
@ -740,7 +741,7 @@ EventDataType Profile::calcSettingsMin(ChannelID code, MachineType mt, QDate sta
if (min>tmp) min=tmp; if (min>tmp) min=tmp;
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
if (min>=99999999) min=0; if (min>=99999999) min=0;
return min; return min;
} }
@ -758,7 +759,7 @@ EventDataType Profile::calcSettingsMax(ChannelID code, MachineType mt, QDate sta
if (max<tmp) max=tmp; if (max<tmp) max=tmp;
} }
date=date.addDays(1); date=date.addDays(1);
} while (date<end); } while (date<=end);
if (max<=-99999999) max=0; if (max<=-99999999) max=0;
return max; return max;
} }

View File

@ -714,7 +714,6 @@ void MainWindow::on_summaryButton_clicked()
.arg(p_profile->calcPercentile(leak,percentile,MT_CPAP,cpapmonth,lastcpap),0,'f',3) .arg(p_profile->calcPercentile(leak,percentile,MT_CPAP,cpapmonth,lastcpap),0,'f',3)
.arg(p_profile->calcPercentile(leak,percentile,MT_CPAP,cpap6month,lastcpap),0,'f',3) .arg(p_profile->calcPercentile(leak,percentile,MT_CPAP,cpap6month,lastcpap),0,'f',3)
.arg(p_profile->calcPercentile(leak,percentile,MT_CPAP,cpapyear,lastcpap),0,'f',3); .arg(p_profile->calcPercentile(leak,percentile,MT_CPAP,cpapyear,lastcpap),0,'f',3);
html+="<tr><td colspan=6>Note, AHI calcs here are different to overview calcs.. Overview shows a average of the dialy AHI's, this shows combined counts divide by combined hours</td></tr>";
} }
} }
int oxisize=oximeters.size(); int oxisize=oximeters.size();