ChatGPT научит вас оценивать и анализировать производительность приложений.
ChatGPT научит вас оценивать и анализировать производительность приложений.

Откройте адрес Intelligent Cat GPT: https://chat.plexpt.com/i/511440.

1.1 Понятия, связанные с беглостью речи Частота обновления и частота кадров Частота обновления: количество замечательных обновлений экрана, частота обновления элементов мобильного телефона составляет 60 Гц. Частота кадров: частота кадров, с которой графический процессор рисует за одну секунду.

рвать vs пропущенные кадры разрушить: Поскольку процесс обновления экрана происходит сверху вниз и слева направо, если Частота кадров>частота обновление, когда на экране не обновились данные n-1 кадров, Начинают формироваться данные n-го кадра, охватывающие n-1-й кадр сверху вниз. Если вы обновите экран в это время, Произойдёт такое явление, что верхняя половина изображения будет n-м кадром, а нижняя половина — n-м кадром. CPU/GPU постоянно выполняет рендеринг. пропущенные кадры: Система Android отправляет сигнал VSYNC каждые 16 мс, чтобы заставить графический процессор выполнить рендеринг пользовательского интерфейса. Если одна из ваших операций занимает 24 мс, система не готова к получению сигнала VSYNC. Невозможно обновить какой-либо контент, поэтому пользователь увидит один и тот же кадр в течение 32 мс (феномен заикания), то есть потеря кадра.

одиночный буфер vs VSYNC vs Двойная буферизация vs тройной кэш одиночный буфер (CSync не введен): Графический процессор записывает данные в кеш, а экран считывает данные из буфера и отображает их после обновления. Частота обновления и частота кадров не всегда совпадают, Это может вызвать явление разрушения. Решить одиночный проблема с разрывом экрана буфера, появилась Двойная буферизацияиVSYCNC VSYCNCи Двойная буферизация: Двойная буферизация используется для двух кэшей: Назад Buffer、Frame Buffer При записи следующего кадра графический процессор сначала заполнит Back В буфере, Когда экран обновляется, экран меняется с Frame Buffer Чтение данных в VSYNC в основном завершает копирование кадра и рендеринг следующего кадра. Тройной кэш: Недостатком двойного кэширования является то, что при CPU/GPU Рисование кадра занимает больше времени, чем 16 ms когда, будет производить Джанк. Что еще страшнее, производить Jank Во время отображения этого кадра графический процессор/процессор Они все бездействуют.

Принцип ФПС FPS — это аббревиатура кадра в секунду, то есть количества кадров в секунду. Этот термин широко используется в компьютерной графике, захвате видео, играх и т. д.

Здесь мы в основном представляем частоту кадров в видеоиграх, первый из них person shooter Частота кадров в игре составляет всего около 6FPS, но все равно очень удачно. Однако с улучшением аппаратного оборудования, особенно производительности видеокарт, частота кадров в играх теперь обычно составляет от 30 до 100 кадров в секунду. Поскольку время, затрачиваемое на каждый кадр изображения, разное, частота кадров постоянно меняется, поэтому в каждой игре будет установлена ​​максимальная частота кадров, чтобы обеспечить плавное переключение.         // Timing...         static QTime time;         static int frames = 0;         static bool started = false;         if (!started || time.elapsed() > 1000) {             qreal fps = frames * 1000. / time.elapsed();             if (fps == 0)                 m_current_fps = "counting fps...";             else                 m_current_fps = QString::fromLatin1("%3 FPS").arg((int) qRound(fps));             time.start();             started = true;             frames = 0;         } else {             ++frames;             p.setOpacity(1);             p.setFont(QFont("times", 30));             p.fillRect(5, height() - 40, 250, 40, Qt::white);             p.drawText(10, height() - 8, m_current_fps);         }     } Поскольку в большинстве игр реального времени есть таймер, который постоянно обновляет экран, вывод каждого кадра завершается с помощью PaintEvent. Поместите приведенный выше код в PaintEvent, чтобы рассчитать частоту кадров в секунду.

Так как же контролировать максимальную частоту кадров?

На самом деле это очень просто делается установкой интервала таймера. Учитывая, что частота отображения текущего монитора обычно 60Гц, то вообще лучше ставить интервал 1000/60мс, то есть 60FPS. теоретическая максимальная частота кадров.

Краткое изложение шести методов расчета частоты кадров (FPS):

1. Метод фиксированных сроков Формула расчета частоты кадров: fps = FrameNum / ElapsedTime; Если вы записываете количество кадров в течение фиксированного периода времени, вы можете рассчитать скорость синхронизации. Этот метод используется чаще. интервал кадров в секунду() { статический int fps = 0; статический int LastTime = getTime() // мс; статический intframeCount = 0;

    ++frameCount;

    int curTime = getTime();     if (curTime - lastTime > 1000) // Возьмите фиксированный интервал времени в 1 секунду.     {         fps = frameCount;         frameCount = 0;         lastTime = curTime;     }     return fps; } Есть еще один способ написать: int fps(int deltaTime) {     static int fps = 0;     static int timeLeft = 1000; // Возьмите фиксированный интервал времени в 1 секунду.     static int frameCount = 0;

    ++frameCount;     timeLeft -= deltaTime;     if (timeLeft < 0)     {         fps = frameCount;         frameCount = 0;         timeLeft = 1000;     }     return fps; }

2. Метод фиксированного номера кадра по времени. Формула расчета частоты кадров: fps = FrameNum / ElapsedTime; Если вы подсчитаете время, необходимое для расчета количества кадров для каждого фиксированного количества кадров, вы также сможете найти частоту кадров. Этот метод используется реже. интервал кадров в секунду() { статический int fps = 0; статический intframeCount = 0; статический int LastTime = getTime() // мс;

    ++frameCount;

    if (frameCount >= 100) // Возьмите фиксированное количество кадров за 100 кадров.     {         int curTime = getTime();         fps = frameCount / (curTime - lastTime) * 1000;         lastTime = curTime;         frameCount = 0;     }     return fps; }

3. Метод расчета в реальном времени. Метод расчета в реальном времени напрямую использует для расчета временной интервал предыдущего кадра, и результат получается в реальном времени, но плавность не очень хорошая. int fps(int deltaTime) // ms {     int fps = static_cast<int>(1.f / deltaTime * 1000); // Не забудьте сначала преобразовать в плавающую точку, иначе будет потеря точности.     return fps; }

4. Метод общего среднего Метод общего среднего использует глобальный номер кадра, разделенный на глобальное время, чтобы найти частоту кадров. int BeginTime = GetTime();

int fps() {     static int frameCount = 0;

    ++frameCount;

    int deltaTime = getTime() - beginTime();     return static_cast<int>(frameCount * 1.f / deltaTime * 1000); // Не забудьте сначала преобразовать в плавающую точку, иначе будет потеря точности. }

5. Точный метод отбора проб Метод точной выборки отбирает первые N кадров, а затем вычисляет среднее значение. Этот метод требует дополнительного места в памяти, поэтому он широко не используется. int fps(int deltaTime) // ms {     static std::queue<int> q;     static int sumDuration = 0; // ms

    int fps = 0;     if (q.size() < 100) // Количество образцов установлено на 100.     {         sumDuration += deltaTime;         q.push(deltaTime);         fps = static_cast<int>(q.size() * 1.f / sumDuration * 1000.f); // Не забудьте преобразовать в плавающую точку, иначе будет потеря точности.     }     else     {         sumDuration -= q.front();         sumDuration += deltaTime;         sumDuration.pop();         sumDuration.push(deltaTime);         fps = static_cast<int>(100.f / sumDuration * 1000.f); // Не забудьте преобразовать в плавающую точку, иначе будет потеря точности.     }     return fps; }

6. Метод средней выборки Метод средней выборки использует последние статистические результаты, чтобы преодолеть недостатки точного метода выборки, который требует дополнительного места. Этот метод используется чаще. int fps(int deltaTime) // мс { статическое плавающее значение avgDuration = 0.f; static альфа = 1.f / 100.f // Количество выборок установлено на 100; статический intframeCount = 0;

    ++frameCount;

    int fps = 0;     if (1 == frameCount)     {         avgDuration = static_cast<float>(deltaTime);     }     else     {         avgDuration = avgDuration * (1 - alpha) + deltaTime * alpha;      }

    fps = static_cast<int>(1.f / avgDuration * 1000);     return fps; }

boy illustration
Учебное пособие по Jetpack Compose для начинающих, базовые элементы управления и макет
boy illustration
Код js веб-страницы, фон частицы, код спецэффектов
boy illustration
【новый! Суперподробное】Полное руководство по свойствам компонентов Figma.
boy illustration
🎉Обязательно к прочтению новичкам: полное руководство по написанию мини-программ WeChat с использованием программного обеспечения Cursor.
boy illustration
[Забавный проект Docker] VoceChat — еще одно приложение для мгновенного чата (IM)! Может быть встроен в любую веб-страницу!
boy illustration
Как реализовать переход по странице в HTML (html переходит на указанную страницу)
boy illustration
Как решить проблему зависания и низкой скорости при установке зависимостей с помощью npm. Существуют ли доступные источники npm, которые могут решить эту проблему?
boy illustration
Серия From Zero to Fun: Uni-App WeChat Payment Practice WeChat авторизует вход в систему и украшает страницу заказа, создает интерфейс заказа и инициирует запрос заказа
boy illustration
Серия uni-app: uni.navigateЧтобы передать скачок значения
boy illustration
Апплет WeChat настраивает верхнюю панель навигации и адаптируется к различным моделям.
boy illustration
JS-время конвертации
boy illustration
Обеспечьте бесперебойную работу ChromeDriver 125: советы по решению проблемы chromedriver.exe не найдены
boy illustration
Поле комментария, щелчок мышью, специальные эффекты, js-код
boy illustration
Объект массива перемещения объекта JS
boy illustration
Как открыть разрешение на позиционирование апплета WeChat_Как использовать WeChat для определения местонахождения друзей
boy illustration
Я даю вам два набора из 18 простых в использовании фонов холста Power BI, так что вам больше не придется возиться с цветами!
boy illustration
Получить текущее время в js_Как динамически отображать дату и время в js
boy illustration
Вам необходимо изучить сочетания клавиш vsCode для форматирования и организации кода, чтобы вам больше не приходилось настраивать формат вручную.
boy illustration
У ChatGPT большое обновление. Всего за 45 минут пресс-конференция показывает, что OpenAI сделал еще один шаг вперед.
boy illustration
Copilot облачной разработки — упрощение разработки
boy illustration
Микросборка xChatGPT с низким кодом, создание апплета чат-бота с искусственным интеллектом за пять шагов
boy illustration
CUDA Out of Memory: идеальное решение проблемы нехватки памяти CUDA
boy illustration
Анализ кластеризации отдельных ячеек, который должен освоить каждый&MarkerгенетическийВизуализация
boy illustration
vLLM: мощный инструмент для ускорения вывода ИИ
boy illustration
CodeGeeX: мощный инструмент генерации кода искусственного интеллекта, который можно использовать бесплатно в дополнение к второму пилоту.
boy illustration
Машинное обучение Реальный бой LightGBM + настройка параметров случайного поиска: точность 96,67%
boy illustration
Бесшовная интеграция, мгновенный интеллект [1]: платформа больших моделей Dify-LLM, интеграция без кодирования и встраивание в сторонние системы, более 42 тысяч звезд, чтобы стать свидетелями эксклюзивных интеллектуальных решений.
boy illustration
LM Studio для создания локальных больших моделей
boy illustration
Как определить количество слоев и нейронов скрытых слоев нейронной сети?
boy illustration
[Отслеживание целей] Подробное объяснение ByteTrack и детали кода