blob: c92347dfa21d9dbdcbd03fdb9bd82718b1156e48 [file] [log] [blame]
--
-- Copyright 2022 The Android Open Source Project
--
-- Licensed under the Apache License, Version 2.0 (the "License");
-- you may not use this file except in compliance with the License.
-- You may obtain a copy of the License at
--
-- https://www.apache.org/licenses/LICENSE-2.0
--
-- Unless required by applicable law or agreed to in writing, software
-- distributed under the License is distributed on an "AS IS" BASIS,
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-- See the License for the specific language governing permissions and
-- limitations under the License.
--
-- This metric calculates the number of user inputs during a scroll per frame
-- generated, this can be used to track smoothness.
-- For normal input, we expect 2 inputs per frame, for flings, we expect
-- 1 input per frame as flings are generated once per vsync.
-- The numbers mentioned above are estimates in the ideal case scenario.
-- Grab all GestureScrollUpdate slices.
DROP VIEW IF EXISTS chrome_all_scroll_updates;
CREATE VIEW chrome_all_scroll_updates AS
SELECT
id,
EXTRACT_ARG(arg_set_id, 'chrome_latency_info.gesture_scroll_id') AS scroll_id,
EXTRACT_ARG(arg_set_id, 'chrome_latency_info.is_coalesced') AS is_coalesced,
ts,
dur,
track_id
FROM slice
WHERE name = "InputLatency::GestureScrollUpdate";
-- Count number of input GestureScrollUpdates per scroll.
DROP VIEW IF EXISTS chrome_update_count_per_scroll;
CREATE VIEW chrome_update_count_per_scroll AS
SELECT
CAST(COUNT() AS FLOAT) AS count,
scroll_id,
dur,
track_id
FROM chrome_all_scroll_updates
GROUP BY scroll_id;
-- Count the number of input GestureScrollUpdates that were converted
-- frames per scroll.
DROP VIEW IF EXISTS chrome_non_coalesced_update_count_per_scroll;
CREATE VIEW chrome_non_coalesced_update_count_per_scroll AS
SELECT
CAST(COUNT() AS FLOAT) AS non_coalesced_count,
scroll_id,
id,
track_id,
dur
FROM chrome_all_scroll_updates
WHERE NOT is_coalesced
GROUP BY scroll_id;
-- Get the average number of inputs per frame per scroll.
DROP VIEW IF EXISTS chrome_avg_scroll_inputs_per_frame;
CREATE VIEW chrome_avg_scroll_inputs_per_frame AS
SELECT
count / non_coalesced_count AS avg_inputs_per_frame_per_scroll,
scroll_id,
non_coalesced_count
FROM chrome_non_coalesced_update_count_per_scroll
JOIN chrome_update_count_per_scroll USING(scroll_id);
-- Get the last scroll update event that wasn't coalesced before the
-- current scroll update.
DROP VIEW IF EXISTS chrome_frame_main_input_id;
CREATE VIEW chrome_frame_main_input_id AS
SELECT
id,
scroll_id,
is_coalesced,
ts,
dur,
track_id,
(SELECT
MAX(id)
FROM chrome_all_scroll_updates parent_scrolls
WHERE NOT is_coalesced
AND parent_scrolls.ts <= scrolls.ts) AS presented_scroll_id
FROM chrome_all_scroll_updates scrolls;
-- Count the number of inputs per presented frame.
DROP VIEW IF EXISTS chrome_scroll_inputs_per_frame;
CREATE VIEW chrome_scroll_inputs_per_frame AS
SELECT
COUNT() AS count_for_frame,
presented_scroll_id,
ts,
dur,
id AS slice_id,
track_id
FROM
chrome_frame_main_input_id
GROUP BY presented_scroll_id;