. */ 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() { $min = $this->conn->fetchAssoc('SELECT value, timestamp FROM data WHERE channel_id = ?' . parent::buildDateTimeFilterSQL($this->from, $this->to) . ' ORDER BY value ASC LIMIT 1', array($this->channel->getId())); return ($min) ? array_map('floatval', $min) : NULL; } /** * Fetch the greatest value from the database * @internal doesn't fits the SQL standard * @return array (0 => timestamp, 1 => value) */ public function getMax() { $max = $this->conn->fetchAssoc('SELECT value, timestamp FROM data WHERE channel_id = ?' . parent::buildDateTimeFilterSQL($this->from, $this->to) . ' ORDER BY value DESC LIMIT 1', array($this->channel->getId())); return ($max) ? array_map('floatval', $max) : NULL; } /** * 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 = ?' . parent::buildDateTimeFilterSQL($this->from, $this->to), array($this->channel->getId()), 0); } /** * @todo possible and/or required? * @return float */ public function getConsumption() { } } ?>