mirror of
https://github.com/beestat/app.git
synced 2025-05-31 04:06:32 -04:00
Added degree days to the runtime_thermostat_summary table.
This commit is contained in:
parent
4b61e50906
commit
267dbe7ea8
@ -178,6 +178,8 @@ class runtime_thermostat_summary extends cora\crud {
|
|||||||
* @param string $populate_end Local date to end populating, inclusive.
|
* @param string $populate_end Local date to end populating, inclusive.
|
||||||
*/
|
*/
|
||||||
private function populate($thermostat_id, $populate_begin, $populate_end) {
|
private function populate($thermostat_id, $populate_begin, $populate_end) {
|
||||||
|
$degree_days_base_temperature = 65;
|
||||||
|
|
||||||
$thermostat = $this->api('thermostat', 'get', $thermostat_id);
|
$thermostat = $this->api('thermostat', 'get', $thermostat_id);
|
||||||
|
|
||||||
// Convert date strings to timestamps to make them easier to work with.
|
// Convert date strings to timestamps to make them easier to work with.
|
||||||
@ -245,6 +247,7 @@ class runtime_thermostat_summary extends cora\crud {
|
|||||||
'sum_dehumidifier' => 0,
|
'sum_dehumidifier' => 0,
|
||||||
'sum_ventilator' => 0,
|
'sum_ventilator' => 0,
|
||||||
'sum_economizer' => 0,
|
'sum_economizer' => 0,
|
||||||
|
'sum_degree_days' => [],
|
||||||
'avg_outdoor_temperature' => [],
|
'avg_outdoor_temperature' => [],
|
||||||
'avg_outdoor_humidity' => [],
|
'avg_outdoor_humidity' => [],
|
||||||
'avg_indoor_temperature' => [],
|
'avg_indoor_temperature' => [],
|
||||||
@ -282,6 +285,7 @@ class runtime_thermostat_summary extends cora\crud {
|
|||||||
|
|
||||||
if ($runtime_thermostat['outdoor_temperature'] !== null) {
|
if ($runtime_thermostat['outdoor_temperature'] !== null) {
|
||||||
$data[$date]['avg_outdoor_temperature'][] = $runtime_thermostat['outdoor_temperature'];
|
$data[$date]['avg_outdoor_temperature'][] = $runtime_thermostat['outdoor_temperature'];
|
||||||
|
$data[$date]['sum_degree_days'][] = $runtime_thermostat['outdoor_temperature'];
|
||||||
}
|
}
|
||||||
if ($runtime_thermostat['outdoor_humidity'] !== null) {
|
if ($runtime_thermostat['outdoor_humidity'] !== null) {
|
||||||
$data[$date]['avg_outdoor_humidity'][] = $runtime_thermostat['outdoor_humidity'];
|
$data[$date]['avg_outdoor_humidity'][] = $runtime_thermostat['outdoor_humidity'];
|
||||||
@ -296,6 +300,7 @@ class runtime_thermostat_summary extends cora\crud {
|
|||||||
|
|
||||||
// Write to the database.
|
// Write to the database.
|
||||||
foreach($data as $date => &$row) {
|
foreach($data as $date => &$row) {
|
||||||
|
$row['sum_degree_days'] = (array_mean($row['sum_degree_days']) / 10) - $degree_days_base_temperature;
|
||||||
$row['avg_outdoor_temperature'] = round(array_sum($row['avg_outdoor_temperature']) / count($row['avg_outdoor_temperature']));
|
$row['avg_outdoor_temperature'] = round(array_sum($row['avg_outdoor_temperature']) / count($row['avg_outdoor_temperature']));
|
||||||
$row['avg_outdoor_humidity'] = round(array_sum($row['avg_outdoor_humidity']) / count($row['avg_outdoor_humidity']));
|
$row['avg_outdoor_humidity'] = round(array_sum($row['avg_outdoor_humidity']) / count($row['avg_outdoor_humidity']));
|
||||||
$row['avg_indoor_temperature'] = round(array_sum($row['avg_indoor_temperature']) / count($row['avg_indoor_temperature']));
|
$row['avg_indoor_temperature'] = round(array_sum($row['avg_indoor_temperature']) / count($row['avg_indoor_temperature']));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user