mirror of
https://github.com/grafana/grafana.git
synced 2024-11-24 18:00:31 -06:00
This reverts commit 906484b809
.
This commit is contained in:
parent
3d922a4e67
commit
a2ebdf2bc2
@ -6,27 +6,23 @@ weight = 1100
|
||||
|
||||
# Reference: Calculation types
|
||||
|
||||
You can perform the following calculations in Grafana. Navigate to the **Transform** tab and in the bar gauge, gauge, and stat visualizations.
|
||||
Refer to the following list of calculations you can perform in Grafana. You can find these calculations in the **Transform** tab and in the bar gauge, gauge, and stat visualizations.
|
||||
|
||||
| Calculation | Description |
|
||||
| :------------------------------ | :---------------------------------------------------------------- |
|
||||
| All nulls | True when all values are null |
|
||||
| All zeros | True when all values are 0 |
|
||||
| Change count | Number of times the field's value changes |
|
||||
| Count | Number of values in a field |
|
||||
| Delta | Cumulative change in value, only counts increments |
|
||||
| Difference | Difference between first and last value of a field |
|
||||
| Difference percent | Percentage change between first and last value of a field |
|
||||
| Distinct count | Number of unique values in a field |
|
||||
| First (not null) | First, not null value in a field |
|
||||
| Max | Maximum value of a field |
|
||||
| Mean | Mean value of all values in a field |
|
||||
| Variance (Population) | Variance (based on population) of all values in a field |
|
||||
| Standard deviation (Population) | Standard deviation (based on population) of all values in a field |
|
||||
| Variance (Sample) | Variance (based on sample) of all values in a field |
|
||||
| Standard deviation (Sample) | Standard deviation (based on sample) of all values in a field |
|
||||
| Min | Minimum value of a field |
|
||||
| Min (above zero) | Minimum, positive value of a field |
|
||||
| Range | Difference between maximum and minimum values of a field |
|
||||
| Step | Minimal interval between values of a field |
|
||||
| Total | Sum of all values in a field |
|
||||
| Calculation | Description |
|
||||
| :----------------- | :-------------------------------------------------------- |
|
||||
| All nulls | True when all values are null |
|
||||
| All zeros | True when all values are 0 |
|
||||
| Change count | Number of times the field's value changes |
|
||||
| Count | Number of values in a field |
|
||||
| Delta | Cumulative change in value, only counts increments |
|
||||
| Difference | Difference between first and last value of a field |
|
||||
| Difference percent | Percentage change between first and last value of a field |
|
||||
| Distinct count | Number of unique values in a field |
|
||||
| First (not null) | First, not null value in a field |
|
||||
| Max | Maximum value of a field |
|
||||
| Mean | Mean value of all values in a field |
|
||||
| Min | Minimum value of a field |
|
||||
| Min (above zero) | Minimum, positive value of a field |
|
||||
| Range | Difference between maximum and minimum values of a field |
|
||||
| Step | Minimal interval between values of a field |
|
||||
| Total | Sum of all values in a field |
|
||||
|
@ -56,26 +56,13 @@ describe('Stats Calculators', () => {
|
||||
it('should calculate basic stats', () => {
|
||||
const stats = reduceField({
|
||||
field: basicTable.fields[0],
|
||||
reducers: [
|
||||
'first',
|
||||
'last',
|
||||
'mean',
|
||||
'count',
|
||||
'Variance (Population)',
|
||||
'Variance (Sample)',
|
||||
'Standard deviation (Population)',
|
||||
'Standard deviation (Sample)',
|
||||
],
|
||||
reducers: ['first', 'last', 'mean', 'count'],
|
||||
});
|
||||
|
||||
expect(stats.first).toEqual(10);
|
||||
expect(stats.last).toEqual(20);
|
||||
expect(stats.mean).toEqual(15);
|
||||
expect(stats.count).toEqual(2);
|
||||
expect(stats.variancePopulation).toEqual(25);
|
||||
expect(stats.varianceSample).toEqual(50);
|
||||
expect(stats.stddevPopulation).toEqual(5);
|
||||
expect(stats.stddevSample).toBeCloseTo(7.0710678, 5);
|
||||
});
|
||||
|
||||
it('should support a single stat also', () => {
|
||||
|
@ -10,10 +10,6 @@ export enum ReducerID {
|
||||
min = 'min',
|
||||
logmin = 'logmin',
|
||||
mean = 'mean',
|
||||
variancePopulation = 'variancePopulation',
|
||||
stddevPopulation = 'stddevPopulation',
|
||||
varianceSample = 'varianceSample',
|
||||
stddevSample = 'stddevSample',
|
||||
last = 'last',
|
||||
first = 'first',
|
||||
count = 'count',
|
||||
@ -156,30 +152,6 @@ export const fieldReducers = new Registry<FieldReducerInfo>(() => [
|
||||
{ id: ReducerID.min, name: 'Min', description: 'Minimum Value', standard: true },
|
||||
{ id: ReducerID.max, name: 'Max', description: 'Maximum Value', standard: true },
|
||||
{ id: ReducerID.mean, name: 'Mean', description: 'Average Value', standard: true, aliasIds: ['avg'] },
|
||||
{
|
||||
id: ReducerID.variancePopulation,
|
||||
name: 'Variance (Population)',
|
||||
description: 'Variance (based on population) of all values in a field',
|
||||
standard: true,
|
||||
},
|
||||
{
|
||||
id: ReducerID.stddevPopulation,
|
||||
name: 'Standard deviation (Population)',
|
||||
description: 'Standard deviation (based on population) of all values in a field',
|
||||
standard: true,
|
||||
},
|
||||
{
|
||||
id: ReducerID.varianceSample,
|
||||
name: 'Variance (Sample)',
|
||||
description: 'Variance (based on sample) of all values in a field',
|
||||
standard: true,
|
||||
},
|
||||
{
|
||||
id: ReducerID.stddevSample,
|
||||
name: 'Standard deviation (Sample)',
|
||||
description: 'Standard deviation (based on sample) of all values in a field',
|
||||
standard: true,
|
||||
},
|
||||
{
|
||||
id: ReducerID.sum,
|
||||
name: 'Total',
|
||||
@ -284,10 +256,6 @@ export function doStandardCalcs(field: Field, ignoreNulls: boolean, nullAsZero:
|
||||
min: Number.MAX_VALUE,
|
||||
logmin: Number.MAX_VALUE,
|
||||
mean: null,
|
||||
variancePopulation: null,
|
||||
stddevPopulation: null,
|
||||
varianceSample: null,
|
||||
stddevSample: null,
|
||||
last: null,
|
||||
first: null,
|
||||
lastNotNull: null,
|
||||
@ -306,8 +274,6 @@ export function doStandardCalcs(field: Field, ignoreNulls: boolean, nullAsZero:
|
||||
previousDeltaUp: true,
|
||||
} as FieldCalcs;
|
||||
|
||||
let squareSum = 0;
|
||||
|
||||
const data = field.values;
|
||||
calcs.count = data.length;
|
||||
|
||||
@ -377,10 +343,6 @@ export function doStandardCalcs(field: Field, ignoreNulls: boolean, nullAsZero:
|
||||
if (currentValue < calcs.logmin && currentValue > 0) {
|
||||
calcs.logmin = currentValue;
|
||||
}
|
||||
|
||||
let _oldMean = calcs.mean;
|
||||
calcs.mean += (currentValue - _oldMean) / calcs.nonNullCount;
|
||||
squareSum += (currentValue - _oldMean) * (currentValue - calcs.mean);
|
||||
}
|
||||
|
||||
if (currentValue !== 0) {
|
||||
@ -404,19 +366,7 @@ export function doStandardCalcs(field: Field, ignoreNulls: boolean, nullAsZero:
|
||||
}
|
||||
|
||||
if (calcs.nonNullCount > 0) {
|
||||
calcs.variancePopulation = squareSum / calcs.nonNullCount;
|
||||
}
|
||||
|
||||
if (calcs.nonNullCount > 0) {
|
||||
calcs.stddevPopulation = Math.sqrt(calcs.variancePopulation);
|
||||
}
|
||||
|
||||
if (calcs.nonNullCount > 0) {
|
||||
calcs.varianceSample = squareSum / (calcs.nonNullCount - 1);
|
||||
}
|
||||
|
||||
if (calcs.nonNullCount > 0) {
|
||||
calcs.stddevSample = Math.sqrt(calcs.varianceSample);
|
||||
calcs.mean = calcs.sum! / calcs.nonNullCount;
|
||||
}
|
||||
|
||||
if (calcs.allIsNull) {
|
||||
|
Loading…
Reference in New Issue
Block a user