CPU Performance API

Unofficial Proposal Draft,

More details about this document
This version:
https://wicg.github.io/cpu-performance/
Issue Tracking:
GitHub
Editor:
(Google)

Abstract

This document defines a simple web API which exposes some information about how powerful the user device is. It targets web applications that will use this static information to provide an improved user experience, possibly in combination with the Compute Pressure API, which provides dynamic information about the user device’s CPU pressure/utilization and allows applications to react to changes in CPU pressure.

Status of this document

1. Introduction

This section is non-normative.

There has always been developer interest for adapting web content, based on how powerful the user device is. E.g., video-conferencing applications or video games may use this information to decide if advanced video effects can be rendered; all types of applications may use it to decide whether to attempt running AI tasks locally or delegate to the server, etc.

In particular, web applications may want to use performance information to:

  1. Control non-essential tasks and requests; e.g., allow or block 3rd party scripts, use or avoid heavy libraries.

  2. Adjust the complexity of web content; e.g., the resolution and format for images and video, the compression level for uploading data, enable or disable computationally heavy operations such as animations, improve resource management (lazy loading, prefetching, prerendering).

  3. Improve real user monitoring; e.g., better understand if users have faster or slower devices, focus development effort more appropriately.

  4. Run computations on the client side vs. on the server side; e.g., use server-side rendering, run AI applications and LLMs on the client side.

  5. Select ads that are better suited for the user device.

2. CPU Performance

Modern computing devices often integrate multiple, heterogeneous processing units, differing in their nature and capabilities. The Central Processing Unit (CPU) is the central component in every computing device. Modern computing devices contain a number of integrated circuits (multi-core processors), each containing a number of physical cores that operate as independent CPUs. Furthermore, technologies for simultaneous multi-threading (or hyper-threading) allow physical cores to handle multiple instruction threads, thus appearing as multiple separate logical cores to the operating system.

Beyond CPU, modern computers may comprise other types of processing units, such as:

This specification currently addresses the Central Processing Unit only, aiming to expose a measure of its performance to web applications. Future versions of this specification may also address other types of processing units.

We will use the term CPU for the collection of central processing units that are contained in a computing device. We will use the term core to refer to a CPU part that can execute instruction threads, physical or logical, as reported by the operating system. We will use the term frequency to refer to the clock speed of the CPU, expressed in cycles per second (Hz) and determining how fast a physical core can execute instructions.

We will use the term performance to refer to how fast the CPU is perceived to be, from the point of view of a web application. A fast CPU handles tasks quicker, e.g., leading to faster application loading, better multitasking, smoother gaming, etc.

3. Performance Tiers

The CPU Performance API classifies user devices according to their CPU performance in a small number of performance tiers. Each performance tier is represented by a small positive integer number. Higher values correspond to higher performance tiers, i.e., to more powerful user devices.

There are four distinct performance tiers, numbered 1–4. Applications using the API should handle additional tiers (numbered 5 and above) which are likely to be added in the future as devices improve over time.

The special value 0 (zero) corresponds to an unknown performance tier, returned in case the API’s implementation is unable to classify the user device.

3.1. Computing Performance Tier Value

Classification of user devices to performance tiers is implementation-defined and should be interpreted by web applications according to their particular needs. However, implementations of this API should adhere to the following rules:

  1. Consistency: The mapping of devices to performance tiers should reflect the CPU performance that can be measured with specific benchmarks, ideally using programming tools provided by a browser (JavaScript, WebAssembly, etc.) and measured in ideal conditions. More powerful devices should not be classified in lower performance tiers than less powerful devices.

  2. Reproducibility: An implementation should always report the same performance tier for the same user device. In particular:

    • The reported performance tier should not depend on the user device’s current load or utilization; and

    • Implementations should not redefine tiers; that is, tier 4 devices should not be reclassified as tier 3 to accommodate newer, higher-powered devices as technology improves. Instead, a new tier 5 will be added to this specification for those newer devices, when the need arises, and then a tier 6 and so on.

    NOTE: The intention of this rule is not to make it impossible to fix classification mistakes in implementations of this API. Such mistakes will inevitably have to be fixed. Rather, the intention of the rule is not to reclassify CPU models with new technology emerging, so as not to break the behavior of obsolete machines running obsolete applications.

  3. User privacy: To avoid user fingerprinting, implementations should classify a fairly large number of user devices in each performance tier (see also § 5 Security and Privacy Considerations). In particular, implementations that are based on some CPU model database should not return the special value 0 for new user devices that are not contained in the database. The special value should be returned only when the implementation cannot obtain information about the CPU from the operating system.

Implementations may (but are not required to) compute the performance tier value for a given user device based on the following characteristics:

4. Javascript API

[
    SecureContext,
    Exposed=Window
] partial interface Navigator {
    readonly attribute unsigned short cpuPerformance;
};
The cpuPerformance getter steps are:
  1. Let tier be an unsigned short representing the performance tier of the device’s CPU, generated in an implementation-defined way, considering the recommendations and constraints described in § 3.1 Computing Performance Tier Value.

  2. Assert: 0 ≤ tier ≤ 4.

  3. Return tier.

5. Security and Privacy Considerations

The CPU Performance API will only be available to HTTPS secure contexts.

To reduce fingerprinting risk, the CPU Performance API does not reveal CPU characteristics directly. The reported value is a small integer number that represents the performance tier corresponding to the CPU. For each possible value (tier), implementations should ensure that a fairly large number of computing devices existing on the internet at any given time, both as an absolute number and as distinct CPU models, are classified as having this performance tier. In particular, the intention of this specification is that each performance tier should contain no less than 10% of the existing CPU models, and no less than 10% of the existing user devices at any given time.

See also the TAG Security/Privacy Questionnaire.

6. Example

This section is non-normative.

A video conferencing application could interpret the four performance tiers as follows. This interpretation is application specific and, even then, it may have to be updated in the future if the application itself is updated and its hardware requirements change.

Such an application could use the value of navigator.cpuPerformance for pre-selecting a number of features that are best supported by the user device’s performance tier.

function getPresetFeatures() {
  switch (navigator.cpuPerformance) {
    case 1:
      return {
        videoQuality: "QVGA",
        frameRate: 15,
        effects: [],
      };
    case 2:
      return {
        videoQuality: "VGA",
        frameRate: 15,
        effects: ['voice-detection', 'animated-reactions'],
      };
    case 3:
      return {
        videoQuality: "720p",
        frameRate: 30,
        effects: ['voice-detection', 'animated-reactions',
                  'noise-reduction'],
      };
    case 4:
    case 0:    // Assuming high performance settings for unknown devices
    default:   // and for performance tiers higher than 4.
      return {
        videoQuality: "1080p",
        frameRate: 30,
        effects: ['voice-detection', 'animated-reactions',
                  'noise-reduction', 'virtual-background'],
      };
  }
}

7. Acknowledgements

Many thanks for valuable feedback and advice from: Dominic Farolino, Deepti Gandluri, Reilly Grant, Tomas Gunnarsson, Markus Handell, Michael Lippautz, Thomas Nattestad, Nicola Tommasi, Guido Urdaneta, Måns Vestin, and Chen Xing.

Thanks to the W3C Web Performance Working Group (WebPerf) and especially Yoav Weiss.

Conformance

Document conventions

Conformance requirements are expressed with a combination of descriptive assertions and RFC 2119 terminology. The key words “MUST”, “MUST NOT”, “REQUIRED”, “SHALL”, “SHALL NOT”, “SHOULD”, “SHOULD NOT”, “RECOMMENDED”, “MAY”, and “OPTIONAL” in the normative parts of this document are to be interpreted as described in RFC 2119. However, for readability, these words do not appear in all uppercase letters in this specification.

All of the text of this specification is normative except sections explicitly marked as non-normative, examples, and notes. [RFC2119]

Examples in this specification are introduced with the words “for example” or are set apart from the normative text with class="example", like this:

This is an example of an informative example.

Informative notes begin with the word “Note” and are set apart from the normative text with class="note", like this:

Note, this is an informative note.

Tests

Tests relating to the content of this specification may be documented in “Tests” blocks like this one. Any such block is non-normative.


Index

Terms defined by this specification

Terms defined by reference

References

Normative References

[HTML]
Anne van Kesteren; et al. HTML Standard. Living Standard. URL: https://html.spec.whatwg.org/multipage/
[INFRA]
Anne van Kesteren; Domenic Denicola. Infra Standard. Living Standard. URL: https://infra.spec.whatwg.org/
[RFC2119]
S. Bradner. Key words for use in RFCs to Indicate Requirement Levels. March 1997. Best Current Practice. URL: https://datatracker.ietf.org/doc/html/rfc2119
[WEBIDL]
Edgar Chen; Timothy Gu. Web IDL Standard. Living Standard. URL: https://webidl.spec.whatwg.org/

IDL Index

[
    SecureContext,
    Exposed=Window
] partial interface Navigator {
    readonly attribute unsigned short cpuPerformance;
};