2021-12-14 08:12:26 +00:00
|
|
|
// Copyright © 2016 SurrealDB Ltd.
|
2017-11-16 20:31:20 +00:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package fncs
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2021-12-14 08:12:26 +00:00
|
|
|
"github.com/surrealdb/surrealdb/util/math"
|
2017-11-16 20:31:20 +00:00
|
|
|
)
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathAbs(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
if val, ok := ensureFloat(args[0]); ok {
|
|
|
|
return outputFloat(math.Abs(val))
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathBottom(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
if take, ok := ensureInt(args[1]); ok {
|
|
|
|
return math.Bottom(vals, int(take)), nil
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathCeil(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
if val, ok := ensureFloat(args[0]); ok {
|
|
|
|
return outputFloat(math.Ceil(val))
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathCorrelation(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
a := ensureFloats(args[0])
|
|
|
|
b := ensureFloats(args[1])
|
|
|
|
return outputFloat(math.Correlation(a, b))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathCovariance(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
a := ensureFloats(args[0])
|
|
|
|
b := ensureFloats(args[1])
|
|
|
|
return outputFloat(math.Covariance(a, b))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathFixed(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2018-04-13 19:48:48 +00:00
|
|
|
if val, ok := ensureFloat(args[0]); ok {
|
|
|
|
if pre, ok := ensureInt(args[1]); ok {
|
|
|
|
return outputFixed(val, pre)
|
|
|
|
}
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2018-04-13 19:48:48 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathFloor(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
if val, ok := ensureFloat(args[0]); ok {
|
|
|
|
return outputFloat(math.Floor(val))
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathGeometricmean(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.GeometricMean(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathHarmonicmean(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.HarmonicMean(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathInterquartile(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.InterQuartileRange(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathMax(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.Max(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathMean(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.Mean(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathMedian(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.Median(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathMidhinge(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.Midhinge(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathMin(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.Min(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathMode(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return math.Mode(vals), nil
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathNearestRank(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2018-04-29 13:02:58 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
if perc, ok := ensureFloat(args[1]); ok {
|
|
|
|
return outputFloat(math.NearestRankPercentile(vals, perc))
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2018-04-29 13:02:58 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathPercentile(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
if perc, ok := ensureFloat(args[1]); ok {
|
|
|
|
return outputFloat(math.Percentile(vals, perc))
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathRound(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
if val, ok := ensureFloat(args[0]); ok {
|
|
|
|
return outputFloat(math.Round(val))
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathSample(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
if take, ok := ensureInt(args[1]); ok {
|
|
|
|
return math.Sample(vals, int(take)), nil
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathSpread(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.Spread(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathSqrt(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2018-04-29 13:02:19 +00:00
|
|
|
if val, ok := ensureFloat(args[0]); ok {
|
|
|
|
return outputFloat(math.Sqrt(val))
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2018-04-29 13:02:19 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathStddev(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
2018-04-29 13:02:58 +00:00
|
|
|
return outputFloat(math.SampleStandardDeviation(vals))
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathSum(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.Sum(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathTop(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
if take, ok := ensureInt(args[1]); ok {
|
|
|
|
return math.Top(vals, int(take)), nil
|
|
|
|
}
|
2018-08-08 07:35:46 +00:00
|
|
|
return nil, nil
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathTrimean(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
|
|
|
return outputFloat(math.Trimean(vals))
|
|
|
|
}
|
|
|
|
|
2018-08-08 07:35:46 +00:00
|
|
|
func mathVariance(ctx context.Context, args ...interface{}) (interface{}, error) {
|
2017-11-16 20:31:20 +00:00
|
|
|
vals := ensureFloats(args[0])
|
2018-04-29 13:02:58 +00:00
|
|
|
return outputFloat(math.SampleVariance(vals))
|
2017-11-16 20:31:20 +00:00
|
|
|
}
|