IMPORTANT: No additional bug fixes or documentation updates
will be released for this version. For the latest information, see the
current release documentation.
Extended Stats Bucket Aggregation Usage
edit
IMPORTANT: This documentation is no longer updated. Refer to Elastic's version policy and the latest documentation.
Extended Stats Bucket Aggregation Usage
editFluent DSL example
edita => a
.DateHistogram("projects_started_per_month", dh => dh
.Field(p => p.StartedOn)
.Interval(DateInterval.Month)
.Aggregations(aa => aa
.Sum("commits", sm => sm
.Field(p => p.NumberOfCommits)
)
)
)
.ExtendedStatsBucket("extended_stats_commits_per_month", aaa => aaa
.BucketsPath("projects_started_per_month>commits")
.Sigma(2.0)
)
Object Initializer syntax example
editnew DateHistogramAggregation("projects_started_per_month")
{
Field = "startedOn",
Interval = DateInterval.Month,
Aggregations = new SumAggregation("commits", "numberOfCommits")
}
&& new ExtendedStatsBucketAggregation("extended_stats_commits_per_month", "projects_started_per_month>commits")
{
Sigma = 2.0
}
Example json output.
{
"projects_started_per_month": {
"date_histogram": {
"field": "startedOn",
"interval": "month"
},
"aggs": {
"commits": {
"sum": {
"field": "numberOfCommits"
}
}
}
},
"extended_stats_commits_per_month": {
"extended_stats_bucket": {
"buckets_path": "projects_started_per_month>commits",
"sigma": 2.0
}
}
}
Handling Responses
editresponse.ShouldBeValid();
var projectsPerMonth = response.Aggregations.DateHistogram("projects_started_per_month");
projectsPerMonth.Should().NotBeNull();
projectsPerMonth.Buckets.Should().NotBeNull();
projectsPerMonth.Buckets.Count.Should().BeGreaterThan(0);
var commitsStats = response.Aggregations.ExtendedStatsBucket("extended_stats_commits_per_month");
commitsStats.Should().NotBeNull();
commitsStats.Average.Should().BeGreaterThan(0);
commitsStats.Max.Should().BeGreaterThan(0);
commitsStats.Min.Should().BeGreaterThan(0);
commitsStats.Count.Should().BeGreaterThan(0);
commitsStats.Sum.Should().BeGreaterThan(0);
commitsStats.SumOfSquares.Should().BeGreaterThan(0);
commitsStats.StdDeviation.Should().BeGreaterThan(0);
commitsStats.StdDeviationBounds.Should().NotBeNull();
commitsStats.StdDeviationBounds.Upper.Should().BeGreaterThan(0);
commitsStats.StdDeviationBounds.Lower.Should().NotBe(0);