Merge pull request #9632 from Ahmah2009/master

Implement floor, ceil, and round functions
pull/9399/head
Jonathan A. Sternberg 2018-04-04 16:12:25 -05:00 committed by GitHub
commit 733f2862f5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 44 additions and 1 deletions

View File

@ -1,6 +1,7 @@
package query
import (
"fmt"
"math"
"github.com/influxdata/influxql"
@ -8,7 +9,7 @@ import (
func isMathFunction(call *influxql.Call) bool {
switch call.Name {
case "sin", "cos", "tan":
case "sin", "cos", "tan", "floor", "ceil", "round":
return true
}
return false
@ -24,6 +25,13 @@ func (MathTypeMapper) CallType(name string, args []influxql.DataType) (influxql.
switch name {
case "sin", "cos", "tan":
return influxql.Float, nil
case "floor", "ceil", "round":
switch args[0] {
case influxql.Float, influxql.Integer, influxql.Unsigned, influxql.Unknown:
return args[0], nil
default:
return influxql.Unknown, fmt.Errorf("invalid argument type for first argument in %s(): %s", name, args[0])
}
}
return influxql.Unknown, nil
}
@ -46,6 +54,33 @@ func (v MathValuer) Call(name string, args []interface{}) (interface{}, bool) {
return v.callTrigFunction(math.Cos, arg0)
case "tan":
return v.callTrigFunction(math.Tan, arg0)
case "floor":
switch arg0 := arg0.(type) {
case float64:
return math.Floor(arg0), true
case int64, uint64:
return arg0, true
default:
return nil, true
}
case "ceil":
switch arg0 := arg0.(type) {
case float64:
return math.Ceil(arg0), true
case int64, uint64:
return arg0, true
default:
return nil, true
}
case "round":
switch arg0 := arg0.(type) {
case float64:
return round(arg0), true
case int64, uint64:
return arg0, true
default:
return nil, true
}
}
}
return nil, false
@ -63,3 +98,11 @@ func (MathValuer) callTrigFunction(fn func(x float64) float64, arg0 interface{})
}
return fn(value), true
}
func round(x float64) float64 {
t := math.Trunc(x)
if math.Abs(x-t) >= 0.5 {
return t + math.Copysign(1, x)
}
return t
}