реклама на сайте
подробности

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
MegaVolt
сообщение Sep 25 2017, 12:09
Сообщение #1


Знающий
****

Группа: Свой
Сообщений: 779
Регистрация: 3-01-05
Из: Минск
Пользователь №: 1 783



Есть некий контроллер дисплея. Есть проц который пишет картинку в память контроллера. Контроллер отображает с какой то своей частотой.

Собственно есть несколько вариантов
1. Проц пишет со своей скорость, контроллер отображает со своей.
2. Проц знает частоту обновления и обновляет данные синхронно с отрисовкой

Собственно подскажите есть ли какие то типовые паттерны для обоих случаев которые стоит писать в память чтобы наглядно убедиться в наличии заданных FPS. А в идеале чтобы можно было их измерить например +/-5 FPS пойдёт.

Примерно как умудряются отображать гамму дисплея рисуя чёрно белые полосочки.
Вот может уже всё придумано до нас?
Go to the top of the page
 
+Quote Post
jcxz
сообщение Sep 25 2017, 12:56
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(MegaVolt @ Sep 25 2017, 19:09) *
Собственно подскажите есть ли какие то типовые паттерны для обоих случаев которые стоит писать в память чтобы наглядно убедиться в наличии заданных FPS. А в идеале чтобы можно было их измерить например +/-5 FPS пойдёт.

Вам надо померить FPS без дополнительных датчиков (фотодиодов)?
Например так:
Допустим - известно, что видеопамять выводится построчно (т.е. - сперва 1-я, строка, потом - 2-я и т.д.).
Изначально экран пустой - заполнен 0-ми. МК с фиксированной скоростью (прерывания и прочие процессы все выключены, есть только один процесс рисования) в первом проходе цикла выводит столбец байтов 0xFF, затем сразу же этот же столбец во 2-м проходе заполняет нулями.
Скорость вывода столбца должна быть больше скорости экранной развёртки (за время одной развёртки МК должен успеть заполнить 0xFF, а затем заполнить 0-и этот столбец).
Данный процесс повторять периодически с интервалом примерно в 2-3 экранных развёртки.
На экране будет наблюдаться мерцающий вертикальный столбец, перемещающийся по вертикали (из-за разности начальных фаз отрисовки контроллером экрана и CPU).
Меряем линейкой высоту столбца на экране и из неё, зная скорость отрисовки CPU, получаем частоту развёртки.
Если знать начало развёртки видеоконтроллером (по какому либо сигналу), то привязав отрисовку CPU к этому сигналу, можно получить статичный, а не плывущий по экрану столбец.
Даже если не знать начало развёртки кадра, то можно, варьируя задержку между циклами отрисовки (на небольшую величину), добиться малой скорости смещения столбца, так чтобы померить его было удобно.
Также можно линейку нарисовать в соседнем столбце (пикселами).
Примерно так.

PS: Да - и при чём тут "Аналоговая техника"??? Вроде есть спец. ветка по устройствам отображения.
Go to the top of the page
 
+Quote Post
MegaVolt
сообщение Sep 25 2017, 13:15
Сообщение #3


Знающий
****

Группа: Свой
Сообщений: 779
Регистрация: 3-01-05
Из: Минск
Пользователь №: 1 783



Цитата(jcxz @ Sep 25 2017, 15:56) *
Вам надо померить FPS без дополнительных датчиков (фотодиодов)?
Ага именно так. И желательно без пересчёта тоже sm.gif))
Цитата
Например так: Меряем линейкой высоту столбца на экране и из неё, зная скорость отрисовки CPU, получаем частоту развёртки.
Т.е. по сути мы включаем столбец на некоторое время и смотрим сколько строк успел отрисовать экран за кадр? Хитро...
Цитата
PS: Да - и при чём тут "Аналоговая техника"??? Вроде есть спец. ветка по устройствам отображения.
Упс... не нашёл подходящий раздел sad.gif. Модераторы перенесите тему плииз в нужный раздел.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Sep 25 2017, 13:54
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(MegaVolt @ Sep 25 2017, 20:15) *
Т.е. по сути мы включаем столбец на некоторое время и смотрим сколько строк успел отрисовать экран за кадр? Хитро...

Да. Основная идея: измерение разницы частот кадровой развёртки и рисования CPU. Поэтому скорость рисования CPU должна быть фиксированной. Далее время рисования измеряем таймером и вычисляем частоту развёртки. Можно придумать разные вариации этого метода.
Go to the top of the page
 
+Quote Post
Myron
сообщение Sep 25 2017, 14:03
Сообщение #5


Профессионал
*****

Группа: Свой
Сообщений: 1 849
Регистрация: 6-02-05
Пользователь №: 2 451



Цитата(jcxz @ Sep 25 2017, 07:54) *
Да. Основная идея: измерение разницы частот кадровой развёртки и рисования CPU. Поэтому скорость рисования CPU должна быть фиксированной. Далее время рисования измеряем таймером и вычисляем частоту развёртки. Можно придумать разные вариации этого метода.
А в качестве таймера используйте песочные часы. Меняя количество песка в них можно синхронизировать частоту кадров/развертки с часами. Остается только создать механизм переворачивания песочных часов по кадровому импульсу.
Ну и решение из прошлого века - почему нельзя просто измерить частоту кадровых/строчных импульсов?
Go to the top of the page
 
+Quote Post
ViKo
сообщение Sep 25 2017, 14:22
Сообщение #6


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



С какой частотой выдает картинку контроллер, знает осциллограф по сигналам развертки.
С какой частотой процессор загружает, это можно тоже на контрольную ножку сигнал вывести.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Sep 25 2017, 16:10
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(Myron @ Sep 25 2017, 21:03) *
Ну и решение из прошлого века - почему нельзя просто измерить частоту кадровых/строчных импульсов?

Исходя из условия. А Вы знаете какой там контроллер? А если это капля компаунда на стекле?

Цитата(ViKo @ Sep 25 2017, 21:22) *
С какой частотой процессор загружает, это можно тоже на контрольную ножку сигнал вывести.

Зачем?
Go to the top of the page
 
+Quote Post
Myron
сообщение Sep 25 2017, 17:59
Сообщение #8


Профессионал
*****

Группа: Свой
Сообщений: 1 849
Регистрация: 6-02-05
Пользователь №: 2 451



Цитата(jcxz @ Sep 25 2017, 10:10) *
Исходя из условия. А Вы знаете какой там контроллер? А если это капля компаунда на стекле?
А если устройство зарыто на Луне?

Go to the top of the page
 
+Quote Post
ViKo
сообщение Sep 25 2017, 18:13
Сообщение #9


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Цитата(jcxz @ Sep 25 2017, 19:10) *
Исходя из условия. А Вы знаете какой там контроллер? А если это капля компаунда на стекле?

Пусть ТС доложит. Думается, все же нет.
Цитата
Зачем?

Проверить в реальной работе.
Go to the top of the page
 
+Quote Post
Myron
сообщение Sep 25 2017, 19:10
Сообщение #10


Профессионал
*****

Группа: Свой
Сообщений: 1 849
Регистрация: 6-02-05
Пользователь №: 2 451



Цитата(ViKo @ Sep 25 2017, 12:13) *
Пусть ТС доложит. Думается, все же нет.

Проверить в реальной работе.
Вот именно. И в реальных условиях.
Go to the top of the page
 
+Quote Post
MegaVolt
сообщение Sep 26 2017, 08:50
Сообщение #11


Знающий
****

Группа: Свой
Сообщений: 779
Регистрация: 3-01-05
Из: Минск
Пользователь №: 1 783



Цитата(Myron @ Sep 25 2017, 17:03) *
Ну и решение из прошлого века - почему нельзя просто измерить частоту кадровых/строчных импульсов?
Несколько причин.
1. В дисплее не выведена сия ножка. Т.е. есть только интерфейс от проца к памяти. Между памятью и дисплеем влезть осциллографом низя sad.gif
2. Заказчику хотелось бы показать нечто наглядное.
3. Хотелось бы показать не только то что дисплей может выводить статическую картинку с нужной частотой но и то что данные меняются с той же частотой.
Go to the top of the page
 
+Quote Post
ViKo
сообщение Sep 26 2017, 09:08
Сообщение #12


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Цитата(MegaVolt @ Sep 26 2017, 11:50) *
Несколько причин.
1. В дисплее не выведена сия ножка. Т.е. есть только интерфейс от проца к памяти. Между памятью и дисплеем влезть осциллографом низя sad.gif

В статусе контроллера дисплея есть флаги, я так думаю. Vertical non-Display period status.
Вообще-то, программист сам задает частоту работы контроллера жки. Зачем ее проверять? Раз влезть, есть очень надо, удостовериться, и шабаш.
Go to the top of the page
 
+Quote Post
MegaVolt
сообщение Sep 26 2017, 09:19
Сообщение #13


Знающий
****

Группа: Свой
Сообщений: 779
Регистрация: 3-01-05
Из: Минск
Пользователь №: 1 783



Цитата(ViKo @ Sep 26 2017, 12:08) *
В статусе контроллера дисплея есть флаги, я так думаю. Vertical non-Display period status.
Увы нет такого флага. Частота обновления вычисляется как по некой формуле от штук 5 переменных которые пишутся в разные регистры. (чем то похоже на PLL). И что там получилось на выходе можно только гадать. То ли не ту циферку записал то ли ещё где ошибся.

Но готового числа обратно он не отдаёт.

Цитата(ViKo @ Sep 26 2017, 12:08) *
Вообще-то, программист сам задает частоту работы контроллера жки. Зачем ее проверять? Раз влезть, есть очень надо, удостовериться, и шабаш.
Так в этом и вопрос. Как проверить то что программист напрограммил? Как показать это заказчику?
Go to the top of the page
 
+Quote Post
ViKo
сообщение Sep 26 2017, 09:31
Сообщение #14


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Так просто - если изображение есть и не мерцает, значит герц 50 - 60 имеется. А больше и не надо. Я попробовал камерой мобильника глянуть, может, биения частот будут видны. Но нет, у меня не видно.
P.S. А мерцание хорошо боковым зрением наблюдать.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Sep 26 2017, 12:11
Сообщение #15


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(ViKo @ Sep 26 2017, 01:13) *
Проверить в реальной работе.

Длительность операций CPU намного удобнее (и точнее) измерять по таймеру.

Цитата(ViKo @ Sep 26 2017, 16:31) *
Так просто - если изображение есть и не мерцает, значит герц 50 - 60 имеется. А больше и не надо. Я попробовал камерой мобильника глянуть, может, биения частот будут видны. Но нет, у меня не видно.

И не будет видно даже если там не 50-60Гц. Если конечно у ТС не ЭЛТ-экран biggrin.gif

Цитата(MegaVolt @ Sep 26 2017, 16:19) *
Так в этом и вопрос. Как проверить то что программист напрограммил? Как показать это заказчику?

Мой способ испытали?
Go to the top of the page
 
+Quote Post

2 страниц V   1 2 >
Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 23rd June 2025 - 23:22
Рейтинг@Mail.ru


Страница сгенерированна за 0.01879 секунд с 7
ELECTRONIX ©2004-2016