. */ namespace Volkszaehler\Interpreter; /** * Sensor interpreter * * @package default * @author Steffen Vogel */ use Volkszaehler\Util; class SensorInterpreter extends Interpreter { /** * @todo untested * @param string|integer $groupBy */ public function getValues($tuples = NULL, $groupBy = NULL) { $data = parent::getData($tuples, $groupBy); $values = array(); foreach ($data as $reading) { $values[] = array( (float) $reading[0], (float) $reading[1] / $reading[2], (int) $reading[2] ); } return $values; } /** * Fetch the smallest value from database * @internal doesn't fits the SQL standard * @return array (0 => timestamp, 1 => value) */ public function getMin() { return array_map('floatval', $this->conn->fetchAssoc('SELECT value, timestamp FROM data WHERE channel_id = ' . (int) $this->channel->getId() . parent::buildDateTimeFilterSQL($this->from, $this->to) . ' ORDER BY value ASC LIMIT 1')); } /** * Fetch the greatest value from the database * @internal doesn't fits the SQL standard * @return array (0 => timestamp, 1 => value) */ public function getMax() { return array_map('floatval', $this->conn->fetchAssoc('SELECT value, timestamp FROM data WHERE channel_id = ' . (int) $this->channel->getId() . parent::buildDateTimeFilterSQL($this->from, $this->to) . ' ORDER BY value DESC LIMIT 1')); } /** * Fetch the average value from the database * @internal doesn't fits the SQL standard * @return float */ public function getAverage() { return (float) $this->conn->fetchColumn('SELECT AVG(value) FROM data WHERE channel_id = ' . (int) $this->channel->getId() . parent::buildDateTimeFilterSQL($this->from, $this->to)); } /** * @todo possible and/or required? * @return float */ public function getConsumption() { } } ?>