| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // Histogram is an object that aggregates statistics, and can summarize them in | 5 // Histogram is an object that aggregates statistics, and can summarize them in |
| 6 // various forms, including ASCII graphical, HTML, and numerically (as a | 6 // various forms, including ASCII graphical, HTML, and numerically (as a |
| 7 // vector of numbers corresponding to each of the aggregating buckets). | 7 // vector of numbers corresponding to each of the aggregating buckets). |
| 8 | 8 |
| 9 // It supports calls to accumulate either time intervals (which are processed | 9 // It supports calls to accumulate either time intervals (which are processed |
| 10 // as integral number of milliseconds), or arbitrary integral units. | 10 // as integral number of milliseconds), or arbitrary integral units. |
| (...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 156 HISTOGRAM_ENUMERATION(name, under_one_hundred, 101) | 156 HISTOGRAM_ENUMERATION(name, under_one_hundred, 101) |
| 157 | 157 |
| 158 // For folks that need real specific times, use this to select a precise range | 158 // For folks that need real specific times, use this to select a precise range |
| 159 // of times you want plotted, and the number of buckets you want used. | 159 // of times you want plotted, and the number of buckets you want used. |
| 160 #define HISTOGRAM_CUSTOM_TIMES(name, sample, min, max, bucket_count) \ | 160 #define HISTOGRAM_CUSTOM_TIMES(name, sample, min, max, bucket_count) \ |
| 161 STATIC_HISTOGRAM_POINTER_BLOCK(name, AddTime(sample), \ | 161 STATIC_HISTOGRAM_POINTER_BLOCK(name, AddTime(sample), \ |
| 162 base::Histogram::FactoryTimeGet(name, min, max, bucket_count, \ | 162 base::Histogram::FactoryTimeGet(name, min, max, bucket_count, \ |
| 163 base::Histogram::kNoFlags)) | 163 base::Histogram::kNoFlags)) |
| 164 | 164 |
| 165 // Support histograming of an enumerated value. The samples should always be | 165 // Support histograming of an enumerated value. The samples should always be |
| 166 // less than boundary_value. | 166 // strictly less than |boundary_value| -- this prevents you from running into |
| 167 // problems down the line if you add additional buckets to the histogram. Note |
| 168 // also that, despite explicitly setting the minimum bucket value to |1| below, |
| 169 // it is fine for enumerated histograms to be 0-indexed -- this is because |
| 170 // enumerated histograms should never have underflow. |
| 167 #define HISTOGRAM_ENUMERATION(name, sample, boundary_value) \ | 171 #define HISTOGRAM_ENUMERATION(name, sample, boundary_value) \ |
| 168 STATIC_HISTOGRAM_POINTER_BLOCK(name, Add(sample), \ | 172 STATIC_HISTOGRAM_POINTER_BLOCK(name, Add(sample), \ |
| 169 base::LinearHistogram::FactoryGet(name, 1, boundary_value, \ | 173 base::LinearHistogram::FactoryGet(name, 1, boundary_value, \ |
| 170 boundary_value + 1, base::Histogram::kNoFlags)) | 174 boundary_value + 1, base::Histogram::kNoFlags)) |
| 171 | 175 |
| 172 // Support histograming of an enumerated value. Samples should be one of the | 176 // Support histograming of an enumerated value. Samples should be one of the |
| 173 // std::vector<int> list provided via |custom_ranges|. You can use the helper | 177 // std::vector<int> list provided via |custom_ranges|. You can use the helper |
| 174 // function |base::CustomHistogram::ArrayToCustomRanges(samples, num_samples)| | 178 // function |base::CustomHistogram::ArrayToCustomRanges(samples, num_samples)| |
| 175 // to transform a C-style array of valid sample values to a std::vector<int>. | 179 // to transform a C-style array of valid sample values to a std::vector<int>. |
| 176 #define HISTOGRAM_CUSTOM_ENUMERATION(name, sample, custom_ranges) \ | 180 #define HISTOGRAM_CUSTOM_ENUMERATION(name, sample, custom_ranges) \ |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 259 name, sample, 1, 1000, 50) | 263 name, sample, 1, 1000, 50) |
| 260 | 264 |
| 261 #define UMA_HISTOGRAM_PERCENTAGE(name, under_one_hundred) \ | 265 #define UMA_HISTOGRAM_PERCENTAGE(name, under_one_hundred) \ |
| 262 UMA_HISTOGRAM_ENUMERATION(name, under_one_hundred, 101) | 266 UMA_HISTOGRAM_ENUMERATION(name, under_one_hundred, 101) |
| 263 | 267 |
| 264 #define UMA_HISTOGRAM_BOOLEAN(name, sample) \ | 268 #define UMA_HISTOGRAM_BOOLEAN(name, sample) \ |
| 265 STATIC_HISTOGRAM_POINTER_BLOCK(name, AddBoolean(sample), \ | 269 STATIC_HISTOGRAM_POINTER_BLOCK(name, AddBoolean(sample), \ |
| 266 base::BooleanHistogram::FactoryGet(name, \ | 270 base::BooleanHistogram::FactoryGet(name, \ |
| 267 base::Histogram::kUmaTargetedHistogramFlag)) | 271 base::Histogram::kUmaTargetedHistogramFlag)) |
| 268 | 272 |
| 273 // The samples should always be strictly less than |boundary_value|. For more |
| 274 // details, see the comment for the |HISTOGRAM_ENUMERATION| macro, above. |
| 269 #define UMA_HISTOGRAM_ENUMERATION(name, sample, boundary_value) \ | 275 #define UMA_HISTOGRAM_ENUMERATION(name, sample, boundary_value) \ |
| 270 STATIC_HISTOGRAM_POINTER_BLOCK(name, Add(sample), \ | 276 STATIC_HISTOGRAM_POINTER_BLOCK(name, Add(sample), \ |
| 271 base::LinearHistogram::FactoryGet(name, 1, boundary_value, \ | 277 base::LinearHistogram::FactoryGet(name, 1, boundary_value, \ |
| 272 boundary_value + 1, base::Histogram::kUmaTargetedHistogramFlag)) | 278 boundary_value + 1, base::Histogram::kUmaTargetedHistogramFlag)) |
| 273 | 279 |
| 274 #define UMA_HISTOGRAM_CUSTOM_ENUMERATION(name, sample, custom_ranges) \ | 280 #define UMA_HISTOGRAM_CUSTOM_ENUMERATION(name, sample, custom_ranges) \ |
| 275 STATIC_HISTOGRAM_POINTER_BLOCK(name, Add(sample), \ | 281 STATIC_HISTOGRAM_POINTER_BLOCK(name, Add(sample), \ |
| 276 base::CustomHistogram::FactoryGet(name, custom_ranges, \ | 282 base::CustomHistogram::FactoryGet(name, custom_ranges, \ |
| 277 base::Histogram::kUmaTargetedHistogramFlag)) | 283 base::Histogram::kUmaTargetedHistogramFlag)) |
| 278 | 284 |
| (...skipping 482 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 761 | 767 |
| 762 // Dump all known histograms to log. | 768 // Dump all known histograms to log. |
| 763 static bool dump_on_exit_; | 769 static bool dump_on_exit_; |
| 764 | 770 |
| 765 DISALLOW_COPY_AND_ASSIGN(StatisticsRecorder); | 771 DISALLOW_COPY_AND_ASSIGN(StatisticsRecorder); |
| 766 }; | 772 }; |
| 767 | 773 |
| 768 } // namespace base | 774 } // namespace base |
| 769 | 775 |
| 770 #endif // BASE_METRICS_HISTOGRAM_H_ | 776 #endif // BASE_METRICS_HISTOGRAM_H_ |
| OLD | NEW |