Get overall buckets API

Get overall buckets API

New API reference

For the most up-to-date API details, refer to Machine learning anomaly detection APIs.

Retrieves overall bucket results that summarize the bucket results of multiple anomaly detection jobs.

Request

GET _ml/anomaly_detectors/<job_id>/results/overall_buckets

GET _ml/anomaly_detectors/<job_id>,<job_id>/results/overall_buckets

GET _ml/anomaly_detectors/_all/results/overall_buckets

Prerequisites

Requires the monitor_ml cluster privilege. This privilege is included in the machine_learning_user built-in role.

Description

By default, an overall bucket has a span equal to the largest bucket span of the specified anomaly detection jobs. To override that behavior, use the optional bucket_span parameter. To learn more about the concept of buckets, see Buckets.

The overall_score is calculated by combining the scores of all the buckets within the overall bucket span. First, the maximum anomaly_score per anomaly detection job in the overall bucket is calculated. Then the top_n of those scores are averaged to result in the overall_score. This means that you can fine-tune the overall_score so that it is more or less sensitive to the number of jobs that detect an anomaly at the same time. For example, if you set top_n to 1, the overall_score is the maximum bucket score in the overall bucket. Alternatively, if you set top_n to the number of jobs, the overall_score is high only when all jobs detect anomalies in that overall bucket. If you set the bucket_span parameter (to a value greater than its default), the overall_score is the maximum overall_score of the overall buckets that have a span equal to the jobs’ largest bucket span.

Path parameters

<job_id>

(Required, string) Identifier for the anomaly detection job. It can be a job identifier, a group name, a comma-separated list of jobs or groups, or a wildcard expression.

You can summarize the bucket results for all anomaly detection jobs by using _all or by specifying * as the job identifier.

Query parameters

allow_no_match

(Optional, Boolean) Specifies what to do when the request:

  • Contains wildcard expressions and there are no jobs that match.
  • Contains the _all string or no identifiers and there are no matches.
  • Contains wildcard expressions and there are only partial matches.

The default value is true, which returns an empty jobs array when there are no matches and the subset of results when there are partial matches. If this parameter is false, the request returns a 404 status code when there are no matches or only partial matches.

bucket_span

(Optional, string) The span of the overall buckets. Must be greater or equal to the largest bucket span of the specified anomaly detection jobs, which is the default value.

end

(Optional, string) Returns overall buckets with timestamps earlier than this time. Defaults to -1, which means it is unset and results are not limited to specific timestamps.

exclude_interim

(Optional, Boolean) If true, the output excludes interim overall buckets. Overall buckets are interim if any of the job buckets within the overall bucket interval are interim. Defaults to false, which means interim results are included.

overall_score

(Optional, double) Returns overall buckets with overall scores greater or equal than this value. Defaults to 0.0.

start

(Optional, string) Returns overall buckets with timestamps after this time. Defaults to -1, which means it is unset and results are not limited to specific timestamps.

top_n

(Optional, integer) The number of top anomaly detection job bucket scores to be used in the overall_score calculation. Defaults to 1.

Request body

You can also specify the query parameters (such as allow_no_match and bucket_span) in the request body.

Response body

The API returns an array of overall bucket objects, which have the following properties:

bucket_span

(number) The length of the bucket in seconds. Matches the bucket_span of the job with the longest one.

is_interim

(Boolean) If true, this is an interim result. In other words, the results are calculated based on partial input data.

jobs

(array) An array of objects that contain the max_anomaly_score per job_id.

overall_score

(number) The top_n average of the max bucket anomaly_score per job.

result_type

(string) Internal. This is always set to overall_bucket.

timestamp

(date) The start time of the bucket for which these results were calculated.

Examples

  1. resp = client.ml.get_overall_buckets(
  2. job_id="job-*",
  3. overall_score=80,
  4. start="1403532000000",
  5. )
  6. print(resp)
  1. response = client.ml.get_overall_buckets(
  2. job_id: 'job-*',
  3. body: {
  4. overall_score: 80,
  5. start: '1403532000000'
  6. }
  7. )
  8. puts response
  1. const response = await client.ml.getOverallBuckets({
  2. job_id: "job-*",
  3. overall_score: 80,
  4. start: 1403532000000,
  5. });
  6. console.log(response);
  1. GET _ml/anomaly_detectors/job-*/results/overall_buckets
  2. {
  3. "overall_score": 80,
  4. "start": "1403532000000"
  5. }

In this example, the API returns a single result that matches the specified score and time constraints. The overall_score is the max job score as top_n defaults to 1 when not specified:

  1. {
  2. "count": 1,
  3. "overall_buckets": [
  4. {
  5. "timestamp" : 1403532000000,
  6. "bucket_span" : 3600,
  7. "overall_score" : 80.0,
  8. "jobs" : [
  9. {
  10. "job_id" : "job-1",
  11. "max_anomaly_score" : 30.0
  12. },
  13. {
  14. "job_id" : "job-2",
  15. "max_anomaly_score" : 10.0
  16. },
  17. {
  18. "job_id" : "job-3",
  19. "max_anomaly_score" : 80.0
  20. }
  21. ],
  22. "is_interim" : false,
  23. "result_type" : "overall_bucket"
  24. }
  25. ]
  26. }

The next example is similar but this time top_n is set to 2:

  1. resp = client.ml.get_overall_buckets(
  2. job_id="job-*",
  3. top_n=2,
  4. overall_score=50,
  5. start="1403532000000",
  6. )
  7. print(resp)
  1. response = client.ml.get_overall_buckets(
  2. job_id: 'job-*',
  3. body: {
  4. top_n: 2,
  5. overall_score: 50,
  6. start: '1403532000000'
  7. }
  8. )
  9. puts response
  1. const response = await client.ml.getOverallBuckets({
  2. job_id: "job-*",
  3. top_n: 2,
  4. overall_score: 50,
  5. start: 1403532000000,
  6. });
  7. console.log(response);
  1. GET _ml/anomaly_detectors/job-*/results/overall_buckets
  2. {
  3. "top_n": 2,
  4. "overall_score": 50.0,
  5. "start": "1403532000000"
  6. }

Note how the overall_score is now the average of the top 2 job scores:

  1. {
  2. "count": 1,
  3. "overall_buckets": [
  4. {
  5. "timestamp" : 1403532000000,
  6. "bucket_span" : 3600,
  7. "overall_score" : 55.0,
  8. "jobs" : [
  9. {
  10. "job_id" : "job-1",
  11. "max_anomaly_score" : 30.0
  12. },
  13. {
  14. "job_id" : "job-2",
  15. "max_anomaly_score" : 10.0
  16. },
  17. {
  18. "job_id" : "job-3",
  19. "max_anomaly_score" : 80.0
  20. }
  21. ],
  22. "is_interim" : false,
  23. "result_type" : "overall_bucket"
  24. }
  25. ]
  26. }