vzlogger/content/javascript/smartmeter.js
Steffen Vogel 29c9157cc1 first commit to project repository, lets work together!
import of my reworked version of justins code
merged f10's frontend (some work nescessary)
2010-06-06 16:05:46 +02:00

249 lines
No EOL
6.6 KiB
JavaScript

/*
* Copyright (c) 2010 by Florian Ziegler <fz@f10-home.de>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License (either version 2 or
* version 3) as published by the Free Software Foundation.
*
* 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., 675 Mass Ave, Cambridge, MA 02139, USA.
*
* For more information on the GPL, please go to:
* http://www.gnu.org/copyleft/gpl.html
*/
// return an array with timestamps of e.g.
// 2010-05-01 00:00:00, 2010-05-01 01:00, 2010-05-01 02:00 for grouping=hour
// between windowStart and windowEnd of json response
function getEmptyGroupArray() {
var empty_array = new Object();
var iterator = getGroupedTimestamp(myWindowStart);
if(myWindowStart < myWindowEnd && iterator < myWindowEnd) {
while(iterator < myWindowEnd) {
empty_array[iterator] = 0;
var iteratorDate = new Date(iterator);
switch(f.grouping.value) {
case 'year':
iteratorDate.setYear(iteratorDate.getYear()+1);
break;
case 'month':
iteratorDate.setMonth(iteratorDate.getMonth()+1);
break;
case 'day':
iteratorDate.setDate(iteratorDate.getDate()+1);
break;
case 'hour':
iteratorDate.setHours(iteratorDate.getHours()+1);
break;
case 'minute':
iteratorDate.setMinutes(iteratorDate.getMinutes()+1);
break;
default:
return empty_array;
}
iterator = iteratorDate.getTime();
}
}
return empty_array
}
function calcMyWindowStart() {
var myWindowStart = new Date(myWindowEnd);
var year = myWindowStart.getFullYear();
var month = myWindowStart.getMonth();// 0 is january
var day = myWindowStart.getDate(); // getDay() returns day of week
var hours = myWindowStart.getHours();
var minutes = myWindowStart.getMinutes();
var windowSize = f.window.value.substring(0,1);
var windowInterval = f.window.value.substring(1);
switch(windowInterval) {
case 'YEAR':
myWindowStart.setYear(myWindowStart.getYear()-windowSize);
break;
case 'MONTH':
myWindowStart.setMonth(myWindowStart.getMonth()-windowSize);
break;
case 'DAY':
myWindowStart.setDate(myWindowStart.getDate()-windowSize);
break;
case 'HOUR':
myWindowStart.setHours(myWindowStart.getHours()-windowSize);
break;
case 'MINUTE':
myWindowStart.setMinutes(myWindowStart.getMinutes()-windowSize);
break;
}
return myWindowStart.getTime();
}
// groups a timestamp depending on grouping value
// e.g. 2010-05-01 23:23:23 will become 2010-05-01 23:00:00 vor grouping=hour
function getGroupedTimestamp(timestamp) {
time = new Date(timestamp);
var year = time.getFullYear();
var month = time.getMonth();// 0 is january
var day = time.getDate(); // getDay() returns day of week
var hours = time.getHours();
var minutes = time.getMinutes();
// hint: its correct without break;
switch(f.grouping.value) {
case 'year':
month = 0;
case 'month':
day = 0;
case 'day':
hours = 0;
case 'hour':
minutes = 0;
}
return (new Date(year,month,day,hours,minutes)).getTime();
}
function raw2Energy(raw) {
var data_grouped_time = getEmptyGroupArray();
var data_grouped = new Array();
if(f.grouping.value == '')
return;
if(typeof raw == 'undefined') {
return [[]];
}
// for each timestamp in json response
for(var i=0;i<raw.pulses.length;i++) {
time = new Date(raw.pulses[i][0]);
var year = time.getFullYear();
var month = time.getMonth();// 0 is january
var day = time.getDate(); // getDay() returns day of week
var hours = time.getHours();
var minutes = time.getMinutes();
// hint: its correct without 'break;'
switch(f.grouping.value) {
case 'year':
month = 0;
case 'month':
day = 0;
case 'day':
hours = 0;
case 'hour':
minutes = 0;
}
// this is a date with e.g. YYYY-MM-DD HH:00 for hour grouping or YYYY-MM-00 00:00 for month grouping
time_grouped = new Date(year,month,day,hours,minutes);
if(!data_grouped_time[time_grouped.getTime()]) {
//alert(time_grouped.getTime());
//return;
}
// add pulse count to this group time
/*
if(data_grouped_time[time_grouped.getTime()] > 0)
data_grouped_time[time_grouped.getTime()] += raw.pulses[i][1];
else
data_grouped_time[time_grouped.getTime()] = raw.pulses[i][1];
*/
data_grouped_time[raw.pulses[i][0]] = raw.pulses[i][1];
}
t = 1;
switch(f.grouping.value) {
case 'year':
t *= 365;
case 'day':
t *= 24;
case 'hour':
t *= 60;
case 'minute':
t *= 60;
}
// transform to proper array and energy instead of pulse count
for(var timestamp in data_grouped_time) {
if(data_grouped_time[timestamp] == 0 && typeof data_grouped_time[(timestamp*1)+(t*1)] != 'undefined')
data_grouped_time[timestamp] = data_grouped_time[(timestamp*1)+(t*1)];
if(f.info.value == 'energy')
data_grouped.push([timestamp/1000,data_grouped_time[timestamp]/raw.resolution]);
else {
data_grouped.push([timestamp/1000, 3600 * 1000 * data_grouped_time[timestamp] / raw.resolution / t ]);
}
}
for(var i=data_grouped.length-1;i>=0;i--) {
if(data_grouped[i][1]==0 && i>0)
data_grouped[i][1] = data_grouped[i-1][1];
}
//$('#debug').append(data_grouped.toSource())
return data_grouped;
}
function raw2Power(raw,moving_average) {
var last_timestamp = 0;
var last_power = 0;
var power = 0;
var data_line = new Array();
if(typeof raw == 'undefined' || raw.pulses.length == 0) {
return [[0,0]];
}
// for each timestamp in json response
for(var i=0;i<raw.pulses.length;i++) {
if(last_timestamp>0) {
// difference between this and last timestamp
difference = raw.pulses[i][0] - last_timestamp;
// power = 3600*1000/difference/resolution*count
power = Math.round(3600 * 1000/difference/raw.resolution*raw.pulses[i][1]);
// average with last power value
if(moving_average && last_power>0 && Math.abs(last_power-power)<0.25*power)
power = (power + last_power)/2;
// additional value for last_power > power*1.25
if(last_power > power*1.25 && last_timestamp) {
data_line.push([last_timestamp,power]);
}
// array with timestamp and power
data_line.push([raw.pulses[i][0]/1000,power]);
}
last_timestamp = raw.pulses[i][0];
last_power = power;
}
// return array with power@timestamps
return data_line;
}