/* *************************************************************************************** * Copyright (C) 2006 EsperTech, Inc. All rights reserved. * * http://www.espertech.com/esper * * http://www.espertech.com * * ---------------------------------------------------------------------------------- * * The software in this package is published under the terms of the GPL license * * a copy of which has been included with this distribution in the license.txt file. * *************************************************************************************** */ package com.espertech.esper.client.soda; import java.io.StringWriter; /** * Standard deviation of the (distinct) values returned by an expression. */ public class StddevProjectionExpression extends ExpressionBase { private boolean distinct; private static final long serialVersionUID = -3145467730712717532L; /** * Ctor. */ public StddevProjectionExpression() { } /** * Ctor - for use to create an expression tree, without inner expression * * @param isDistinct true if distinct */ public StddevProjectionExpression(boolean isDistinct) { this.distinct = isDistinct; } /** * Ctor - adds the expression to project. * * @param expression returning values to project * @param isDistinct true if distinct */ public StddevProjectionExpression(Expression expression, boolean isDistinct) { this.distinct = isDistinct; this.getChildren().add(expression); } public ExpressionPrecedenceEnum getPrecedence() { return ExpressionPrecedenceEnum.UNARY; } public void toPrecedenceFreeEPL(StringWriter writer) { ExpressionBase.renderAggregation(writer, "stddev", distinct, this.getChildren()); } /** * Returns true if the projection considers distinct values only. * * @return true if distinct */ public boolean isDistinct() { return distinct; } /** * Set the distinct flag indicating the projection considers distinct values only. * * @param distinct true for distinct, false for not distinct */ public void setDistinct(boolean distinct) { this.distinct = distinct; } }