return ret_val;
}
-Data *DeviceData::get_daily_summary(Date *date) {
+Data *DeviceData::get_day_summary(Date *date) {
Data *ret_val;
W1Store *store;
+ bool suc_flg;
+
+ ret_val = NULL;
+ store = new W1Store(device_id, date);
+ if (store != NULL) {
+ suc_flg = store->load();
+ if (suc_flg == true) {
+ switch(summary_calc_type) {
+ case SUM:
+ ret_val = store->get_sum();
+ break;
+ case DELTA:
+ ret_val = store->get_delta();
+ break;
+ case MEAN:
+ default:
+ ret_val = store->get_mean();
+ break;
+ case MAX:
+ ret_val = store->get_max();
+ break;
+ case MIN:
+ ret_val = store->get_min();
+ break;
+ }
+ if (ret_val != NULL) {
+ ret_val->printout();
+ }
+ else {
+ log_error("Could not read data log for device: %s\n", device_id.c_str());
+ }
+ }
+ else {
+ log_error("Could not read data log for device: %s. Data file open load failed.\n", device_id.c_str());
+ }
+ }
+ else {
+ log_error("Could not read data log for device: %s\n", device_id.c_str());
+ }
+ delete(store);
+ return ret_val;
+}
+
+DataRange *DeviceData::get_daily_summary(Date *start_date,
+ Date *end_date) {
+ DataRange *ret_val;
+ Data *data;
+ Date *date;
+
+ ret_val = NULL;
+ date = start_date->clone();
+ while(date->before(*end_date)) {
+ data = get_day_summary(date);
+ if (data != NULL) {
+ if (ret_val == NULL) {
+ ret_val = new DataRange(*data);
+ }
+ else {
+ ret_val->add_data(*data);
+ }
+ delete(data);
+ }
+ date->tomorrow();
+ }
+ delete(date);
+ return ret_val;
+}
+
+vector<Data *> DeviceData::get_hourly_summary(Date *date) {
+ vector<Data *> ret_val;
+ W1Store * store;
store = new W1Store(device_id, date);
store->load();
switch(summary_calc_type) {
+/*
case SUM:
ret_val = store->get_sum();
break;
+*/
case DELTA:
- ret_val = store->get_delta();
+ ret_val = store->get_delta(3600);
break;
case MEAN:
default:
- ret_val = store->get_mean();
+ ret_val = store->get_mean(3600);
break;
+/*
case MAX:
ret_val = store->get_max();
break;
case MIN:
ret_val = store->get_min();
break;
+*/
}
- ret_val->printout();
delete(store);
-
return ret_val;
}
-DataRange *DeviceData::get_daily_summary(Date *start_date,
+DataRange *DeviceData::get_hourly_summary(Date *start_date,
Date *end_date) {
DataRange *ret_val;
+ vector<Data *> dta_list;
Data *data;
Date *date;
ret_val = NULL;
date = start_date->clone();
while(date->before(*end_date)) {
- data = get_daily_summary(date);
- if (ret_val == NULL) {
- ret_val = new DataRange(*data);
- }
- else {
- ret_val->add_data(*data);
+ dta_list = get_hourly_summary(date);
+ for(vector<Data *>::iterator list_iter = dta_list.begin(); list_iter != dta_list.end(); list_iter++) {
+ data = (Data *)*list_iter;
+ if (data != NULL) {
+ if (ret_val == NULL) {
+ ret_val = new DataRange(*data);
+ }
+ else {
+ ret_val->add_data(*data);
+ }
+ delete(data);
+ }
}
- delete(data);
date->tomorrow();
}
delete(date);
return ret_val;
}
-
DataRange *DeviceData::get_data(Date *start_date,
Date *end_date) {
DataRange *ret_val;
break;
case 1:
log_debug("get monthly summary\n");
+ ret_val = get_daily_summary(start_date, end_date);
break;
case 2:
log_debug("get daily summary\n");
break;
case 3:
log_debug("get hourly summary\n");
+ ret_val = get_hourly_summary(start_date, end_date);
break;
case 4:
log_debug("get minute summary data\n");