1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 // Histogram-collected metrics.
9 option optimize_for = LITE_RUNTIME;
14 message HistogramEventProto {
15 // The name of the histogram, hashed.
16 optional fixed64 name_hash = 1;
18 // The sum of all the sample values.
19 // Together with the total count of the sample values, this allows us to
20 // compute the average value. The count of all sample values is just the sum
21 // of the counts of all the buckets.
22 optional int64 sum = 2;
24 // The per-bucket data.
26 // Each bucket's range is bounded by min <= x < max.
27 // It is valid to omit one of these two fields in a bucket, but not both.
28 // If the min field is omitted, its value is assumed to be equal to max - 1.
29 // If the max field is omitted, its value is assumed to be equal to the next
30 // bucket's min value (possibly computed per above). The last bucket in a
31 // histogram should always include the max field.
32 optional int64 min = 1;
33 optional int64 max = 2;
35 // The bucket's index in the list of buckets, sorted in ascending order.
36 // This field was intended to provide extra redundancy to detect corrupted
37 // records, but was never used. As of M31, it is no longer sent by Chrome
38 // clients to reduce the UMA upload size.
39 optional int32 bucket_index = 3 [deprecated = true];
41 // The number of entries in this bucket.
42 optional int64 count = 4;
44 repeated Bucket bucket = 3;