chromium/tools/metrics/histograms/metadata/image/histograms.xml

<!--
Copyright 2020 The Chromium Authors
Use of this source code is governed by a BSD-style license that can be
found in the LICENSE file.
-->

<!--
This file is used to generate a comprehensive list of Image histograms
along with a detailed description for each histogram.

For best practices on writing histogram descriptions, see
https://chromium.googlesource.com/chromium/src.git/+/HEAD/tools/metrics/histograms/README.md

Please follow the instructions in the OWNERS file in this directory to find a
reviewer. If no OWNERS file exists, please consider signing up at
go/reviewing-metrics (Googlers only), as all subdirectories are expected to
have an OWNERS file. As a last resort you can send the CL to
[email protected].
-->

<histogram-configuration>

<histograms>

<variants name="ImageAnnotationServiceAnnotationType">
  <variant name="DescCaption."
      summary="Caption annotations from the description engine"/>
  <variant name="DescLabel."
      summary="Label annotations from the description engine"/>
  <variant name="DescOcr."
      summary="OCR (text extraction) annotations from the description engine"/>
  <variant name="DescUnknown."
      summary="Annotations of an unknown type from the description engine"/>
  <variant name="Ocr."
      summary="OCR (text extraction) annotations from the specialized OCR
               engine"/>
</variants>

<variants name="ImageFetcherCacheStrategy">
  <variant name=".BestEffort" summary="LRU cache strategy."/>
  <variant name=".HoldUntilExpired"
      summary="Hold the cache file until expired."/>
</variants>

<variants name="ImageFetcherClients">
  <variant name=".AlmanacIcons"
      summary="Downloads app icons for clients of the Almanac Server to
               display."/>
  <variant name=".AnswerSuggestions"
      summary="Showing cache patterns only for AnswerSuggestions (valid until
               M117)."/>
  <variant name=".AssistantDetails"
      summary="Showing cache patterns only for AssistantDetails."/>
  <variant name=".AutofillCardArt"
      summary="Show customized card-art image for credit card suggestions on
               Android."/>
  <variant name=".AutofillImageFetcher"
      summary="Show customized card art image for credit card."/>
  <variant name=".AutofillPasswordFavicon"
      summary="Requesting favicons associated with credentials directly from
               websites."/>
  <variant name=".ContextualSuggestions"
      summary="Showing cache patterns only for ContextualSuggestions."/>
  <variant name=".Cryptids" summary="Asset fetcher for cryptid rendering."/>
  <variant name=".EduAccountLoginProfileImageFetcher"
      summary="Profile image fetcher for EDU account login flow"/>
  <variant name=".EntitySuggestions"
      summary="Showing cache patterns only for EntitySuggestions (valid until
               M117)."/>
  <variant name=".FedCMAccountChooser"
      summary="Profile image fetcher for FedCM Account chooser."/>
  <variant name=".Feed" summary="Showing cache patterns only for Feed."/>
  <variant name=".Internal"
      summary="Showing cache patterns only for Internal."/>
  <variant name=".NewTabPageAnimatedLogo"
      summary="Showing cache patterns only for NewTabPageAnimatedLogo."/>
  <variant name=".OfflinePages"
      summary="Showing cache patterns only for OfflinePages."/>
  <variant name=".Omnibox"
      summary="Showing cache patterns only for Omnibox (valid since M117)."/>
  <variant name=".PasswordBottomSheet"
      summary="Profile image fetcher for Password Manager sign-in bottom
               sheet."/>
  <variant name=".PasswordSharing"
      summary="Profile image fetcher of potential password recipients in the
               Password Sharing flow."/>
  <variant name=".PriceChangeModule"
      summary="Images fetched and used to render price change module on NTP
               or StartSurface."/>
  <variant name=".PriceDropNotification"
      summary="Images fetched for the icon of price drop notification."/>
  <variant name=".QueryTiles" summary="Showing Query tiles images."/>
  <variant name=".SharePreview" summary="Images fetched for Share previews."/>
  <variant name=".TabResumptionModule"
      summary="Images fetched and used to render tab resumption module on NTP
               or StartSurface."/>
  <variant name=".VideoTutorialsIPH"
      summary="Showing thumbnails for video tutorials IPH."/>
  <variant name=".VideoTutorialsList"
      summary="Showing thumbnails for video tutorials list view."/>
  <variant name=".WebNotes"
      summary="Images fetched and used to render Web Notes templates."/>
</variants>

<histogram name="ImageAnnotationService.AccessibilityV1.CacheHit"
    enum="BooleanCacheHit" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each image processed by the image annotation service, records whether or
    not results for the image already existed in the client-side cache. A hit
    means that image data was not transmitted to the image annotation server.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.ClientResult"
    enum="ImageAnnotationServiceClientResult" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each request made by a client feature to the image annotation service,
    reports the final status of the service response.

    Warning: This histogram was expired from 2022-10-30 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.DescFailure"
    enum="DescFailureReason" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each failed request made by a client feature to the image annotation
    service, reports the reason for the failure.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.DescType"
    enum="ImageAnnotationServiceDescType" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each annotation backend run by the image annotation server, records the
    gRPC status reported.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.EncodedJpegSizeKB"
    units="KB" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each image sent from a client feature to the image annotation service,
    reports the image's final size (in kilobytes) after resizing and reencoding.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.EngineKnown"
    enum="BooleanKnown" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each annotation backend run by the image annotation server, records
    whether or not the backend is recognised by this version of Chrome.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram
    name="ImageAnnotationService.AccessibilityV1.ImageRequestIncludesDesc"
    enum="BooleanIncluded" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each image request sent to the image annotation server, records whether
    or not the description backend is included among the requested backends.

    The description backend will not be included when the image is known to
    violate the description model policy (i.e. be too small or have too-high an
    aspect ratio).

    Warning: This histogram was expired from M105 to M117; data may be missing.
    Use data from M117+ only.
  </summary>
</histogram>

<histogram
    name="ImageAnnotationService.AccessibilityV1.ImageRequestIncludesIcon"
    enum="BooleanIncluded" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each image request sent to the image annotation server, records whether
    or not the icon backend is included among the requested backends.

    The icon backend will not be included when the image is known to violate the
    icon model policy (i.e. be too large or have too-high an aspect ratio).

    Warning: This histogram was expired from M105 to M117; data may be missing.
    Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.JsonParseSuccess"
    enum="BooleanSuccess" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each non-empty response sent from the image annotation server, records
    whether or not JSON data were successfully parsed from the response body.

    Warning: This histogram was expired from 2022-10-31 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.PixelFetchSuccess"
    enum="BooleanSuccess" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each pixel fetch request sent from the image annotation service to a
    client feature, records whether or not encoded pixel data were successfully
    returned to the service.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.ServerHttpResponseCode"
    enum="HttpResponseCode" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each HTTP response from the image annotation server, reports the
    associated HTTP code.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.ServerLatencyMs"
    units="ms" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each HTTP response from the image annotation server, reports the time
    elapsed (in milliseconds) since the corresponding request was sent.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.ServerNetError"
    enum="NetErrorCodes" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each HTTP request sent to the image annotation server, reports the net
    error (or OK status) of the request.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.ServerRequestSizeKB"
    units="KB" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each HTTP request sent to the image annotation server, reports the size
    of the request. Measured in kilobytes, since a request can contain the pixel
    data of multiple images.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram
    name="ImageAnnotationService.AccessibilityV1.ServerResponseSizeBytes"
    units="bytes" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each HTTP response from the image annotation server, reports the
    response size in bytes.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram name="ImageAnnotationService.AccessibilityV1.SourcePixelCount"
    units="pixels" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each image sent from a client feature to the image annotation service,
    reports the image's original (i.e. pre-scaling) area in pixels. Images with
    pixel count above a certain threshold will be resized prior to transmission.

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
</histogram>

<histogram
    name="ImageAnnotationService.{ImageAnnotationServiceAnnotationType}AccessibilityV1.Confidence"
    units="%" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each annotation of the given type returned by the image annotation
    server, records the confidence (as a percentage) produced by the ML model
    for the annotation. {ImageAnnotationServiceAnnotationType}

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
  <token key="ImageAnnotationServiceAnnotationType"
      variants="ImageAnnotationServiceAnnotationType"/>
</histogram>

<histogram
    name="ImageAnnotationService.{ImageAnnotationServiceAnnotationType}AccessibilityV1.Empty"
    enum="BooleanEmpty" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each annotation of the given type returned by the image annotation
    server, records whether or not the text of the annotation was empty. This is
    sometimes valid, e.g. for text extraction (OCR) on an image that does not
    contain any text. {ImageAnnotationServiceAnnotationType}

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
  <token key="ImageAnnotationServiceAnnotationType"
      variants="ImageAnnotationServiceAnnotationType"/>
</histogram>

<histogram
    name="ImageAnnotationService.{ImageAnnotationServiceAnnotationType}AccessibilityV1.Status"
    enum="GoogleRpcCode" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    For each annotation backend run by the image annotation server, records the
    gRPC status reported. {ImageAnnotationServiceAnnotationType}

    Warning: This histogram was expired from 2022-04-24 to 2023-06-23; data may
    be missing. Use data from M117+ only.
  </summary>
  <token key="ImageAnnotationServiceAnnotationType"
      variants="ImageAnnotationServiceAnnotationType"/>
</histogram>

<histogram name="ImageDecoder.Png.UiGfxIntoSkBitmap" units="microseconds"
    expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    Measures the runtime of the `gfx::PNGCodec::Decode(..., SkBitmap* bitmap)`
    API. Logged every time the API is called. Primarily used to evaluate the
    go/rusty-png-ui-gfx-decoder project.

    The metric is reported for only clients with high-resolution clocks (i.e.
    excludes a small percentage of Windows users population - see the
    Windows.HasHighResolutionTimeTicks metric). This is okay, because we are
    mostly interested in comparing C++ vs Rust and it seems okay to assume that
    such comparison would give similar results for the filtered and non-filtered
    population.
  </summary>
</histogram>

<histogram name="ImageDecoder.Png.UiGfxIntoVector" units="microseconds"
    expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    Measures the runtime of the `gfx::PNGCodec::Decode(...,
    std::vector&lt;unsigned char&gt;* output, ...)` API. Logged every time the
    API is called. Primarily used to evaluate the go/rusty-png-ui-gfx-decoder
    project.

    The metric is reported for only clients with high-resolution clocks (i.e.
    excludes a small percentage of Windows users population - see the
    Windows.HasHighResolutionTimeTicks metric). This is okay, because we are
    mostly interested in comparing C++ vs Rust and it seems okay to assume that
    such comparison would give similar results for the filtered and non-filtered
    population.
  </summary>
</histogram>

<histogram name="ImageFetcher.CacheMetadataCount{ImageFetcherCacheStrategy}"
    units="records" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The total number of metadata entries in the image fetcher cache metadata
    database for a given cache strategy. Recorded during cache eviction process.
    {ImageFetcherCacheStrategy}
  </summary>
  <token key="ImageFetcherCacheStrategy" variants="ImageFetcherCacheStrategy"/>
</histogram>

<histogram name="ImageFetcher.CacheSize{ImageFetcherCacheStrategy}" units="KB"
    expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The total size of the cache for a given cache strategy. Recorded during
    cache eviction process. {ImageFetcherCacheStrategy}
  </summary>
  <token key="ImageFetcherCacheStrategy" variants="ImageFetcherCacheStrategy"/>
</histogram>

<histogram name="ImageFetcher.Events{ImageFetcherClients}"
    enum="ImageFetcherEvent" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    Events that track the lifecycle and performance of the cached_image_fetcher.
    The events reported include: success/failure conditions, various recoverable
    errors and a couple of dead-end errors. {ImageFetcherClients}
  </summary>
  <token key="ImageFetcherClients" variants="ImageFetcherClients">
    <variant name=""/>
  </token>
</histogram>

<histogram name="ImageFetcher.ImageLoadFromCacheTimeJava{ImageFetcherClients}"
    units="ms" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The time it takes for cached_image_fetcher to load an image from the cache
    in Java. {ImageFetcherClients}
  </summary>
  <token key="ImageFetcherClients" variants="ImageFetcherClients">
    <variant name=""/>
  </token>
</histogram>

<histogram name="ImageFetcher.ImageLoadFromCacheTime{ImageFetcherClients}"
    units="ms" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The time it takes for cached_image_fetcher to load an image from the cache
    in native. {ImageFetcherClients}
  </summary>
  <token key="ImageFetcherClients" variants="ImageFetcherClients">
    <variant name=""/>
  </token>
</histogram>

<histogram name="ImageFetcher.ImageLoadFromNativeTimeJava{ImageFetcherClients}"
    units="ms" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The time it takes for cached_image_fetcher to load an image from native
    code. Only recorded on successful loads. {ImageFetcherClients}
  </summary>
  <token key="ImageFetcherClients" variants="ImageFetcherClients">
    <variant name=""/>
  </token>
</histogram>

<histogram
    name="ImageFetcher.ImageLoadFromNetworkAfterCacheHit{ImageFetcherClients}"
    units="ms" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The time it takes for cached_image_fetcher to load an image from the network
    after a cache hit. {ImageFetcherClients}
  </summary>
  <token key="ImageFetcherClients" variants="ImageFetcherClients">
    <variant name=""/>
  </token>
</histogram>

<histogram name="ImageFetcher.ImageLoadFromNetworkTime{ImageFetcherClients}"
    units="ms" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The time it takes for cached_image_fetcher to load an image from the
    network. {ImageFetcherClients}
  </summary>
  <token key="ImageFetcherClients" variants="ImageFetcherClients">
    <variant name=""/>
  </token>
</histogram>

<histogram name="ImageFetcher.LoadImageMetadata" units="ms"
    expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The time it takes to load an image's metadata from the metadata store.
  </summary>
</histogram>

<histogram name="ImageFetcher.RequestStatusCode{ImageFetcherClients}"
    enum="CombinedHttpResponseAndNetErrorCode" expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    Android: The integer status code of network requests made by the image data
    fetcher. This code includes both protocol(1xx-5xx) and non-protocol(-xxx)
    errors. Recorded when a request completes. {ImageFetcherClients}
  </summary>
  <token key="ImageFetcherClients" variants="ImageFetcherClients">
    <variant name=""/>
  </token>
</histogram>

<histogram name="ImageFetcher.TimeSinceLastCacheLRUEviction" units="ms"
    expires_after="2025-01-20">
  <owner>[email protected]</owner>
  <owner>[email protected]</owner>
  <summary>
    The time since the last LRU eviction from the image cache. Recorded when two
    LRU evictions occur within closure proximity to one another. Will be used to
    determine if LRU eviction is happening too frequently.
  </summary>
</histogram>

</histograms>

</histogram-configuration>