Board.KolibriOS.org

Official KolibriOS board
It is currently Sat Apr 20, 2019 7:37 am

All times are UTC+03:00




Post new topic  Reply to topic  [ 46 posts ]  Go to page 1 2 3 4 Next
Author Message
PostPosted: Sat May 14, 2011 9:25 am 
Offline

Joined: Mon Sep 24, 2007 11:11 am
Posts: 2814
В другой теме я уже писал о своей программе-растеризаторе шрифтов. Пришло время отдать растеризатор на тестирование.
Сейчас программа написана на Си. Я хочу убедиться, что выбранные алгоритмы работают с приемлемой скоростью на всех машинах, и если это не так, буду думать об оптимизации отдельных блоков. После этого, по всей видимости, можно будет переносить растеризатор на ассемблер.

Причесывание и вылизывание Си-шного кода продолжается, в программе с недавнего времени не используется FPU (используются только целочисленные вычисления).

Attachment:
scalefont.zip [2.64 KiB]
Downloaded 488 times


Что делает программа fonter? Она выводит на экран глиф S из шрифта Droid Sans (пока что сделал версию без сглаживания), размер этого глифа можно менять (13,14,16,17,20,22,26,32,40,53,80 или 160 пикселов в высоту).

Что нужно протестировать? Работает ли программа, заметна ли отрисовка символа на экране.



Замечу, что если отрисовка символа незаметна без сглаживания, то и со сглаживанием она заметна скорее всего не будет - зато качество символа будет гораздо выше. Программа использует menuetlibc, поэтому CPU показывает, что она кушает много памяти. В реальности программа потребляет чуть больше 270 килобайт ОЗУ - из них большая часть идет на хранение изображения символа в памяти (300*300*3 байта). Потребление можно снизить, заменив 7ю функцию на 65ю.

1) Что делать с прозрачностью? Все еще нужно извращаться с чтением фона в буфер?
2) Предлагаю начать обсуждение API библиотеки шрифтов и всего сопутствующего.


Top
   
PostPosted: Sat May 14, 2011 1:19 pm 
Offline

Joined: Tue Jun 24, 2008 11:12 pm
Posts: 64
Всё работает, всё отрисовывается. Хорошая работа проделана!


Top
   
PostPosted: Sat May 14, 2011 4:48 pm 
Offline

Joined: Mon Sep 24, 2007 11:11 am
Posts: 2814
Спасибо за тестирование!
Особенно мне интересны результаты для eBox и других слабых машинок. С нетерпением жду отзывов.
Проверил в qemu и virtualbox. Загрузка процессора (2.4ГГц) не более 3% даже на больших разрешениях, мерцания нет. При запуске параллельно процесса-пожирателя ресурсов (который нагружает процессор на 99%) видно мерцание при перерисовке - но не только в демо-программе, а вообще везде.


Top
   
PostPosted: Sun May 15, 2011 8:28 am 
А не проще ориентироваться на Qemu? Он как раз достаточно слабую машину эмулирует.


Top
   
PostPosted: Sun May 15, 2011 8:36 am 
Offline
Moderator

Joined: Thu Apr 08, 2010 8:11 pm
Posts: 269
На моём компьютере отрисовки вообще не видно, появляются моментально. Только хвостики гораздо тоньше чем середина, на мелком шрифте...на самом крупном всё нормально.


Top
   
PostPosted: Sun May 15, 2011 9:00 am 
Offline

Joined: Mon Sep 24, 2007 11:11 am
Posts: 2814
Mario wrote:
А не проще ориентироваться на Qemu? Он как раз достаточно слабую машину эмулирует.

У меня qemu определяет процессор как 200МГц, а затем очень странно себя ведет - то быстрее эмулирует, то медленнее, и вдобавок загрузка процессора отображается неправильно. Процесс-пожиратель ресурсов отъедает 700-800% процессорного времени :mrgreen: А перерисовки без серьезной нагрузки в qemu тоже не видно.

popovpa wrote:
На моём компьютере отрисовки вообще не видно, появляются моментально. Только хвостики гораздо тоньше чем середина, на мелком шрифте...на самом крупном всё нормально.

Спасибо за тест! В этом шрифте хвостики и так тоньше, чем середина. Если бы был алгоритм хинтинга, то что-то возможно поменялось бы. Сглаживание увеличит качество изображения.


Top
   
PostPosted: Thu May 19, 2011 6:08 pm 
Offline

Joined: Mon Sep 24, 2007 11:11 am
Posts: 2814
Статья о моем растеризаторе на Хабре(для тех, кому интересно, как именно работает мой алгоритм).


Top
   
PostPosted: Fri May 20, 2011 8:09 am 
Толковая статья. Глядишь кто-то с такими же фанатичными устремлениями применит опыт в другом месте.
Особенно повеселил коммент про "теплый жидкий стул ламповый мак".


Top
   
PostPosted: Fri May 20, 2011 8:31 am 
Offline

Joined: Tue May 11, 2010 8:14 am
Posts: 112
Сегодня протестирую на Pentium 2.

Статья понравилась, хотя признаться честно прочитал наискосок, смотря только на основу, не пытаясь серьезно вникнуть в формулы.


Top
   
PostPosted: Fri May 20, 2011 9:21 pm 
Offline

Joined: Tue May 11, 2010 8:14 am
Posts: 112
Окно появляется практически мгновенно, надпись не мерцает. Но думаю она отрисовывается только при запуске, так что это не показательно. При быстром запуске нескольких приложений подряд задержка тоже не заметна.


Top
   
PostPosted: Sat May 21, 2011 5:01 pm 
Наконец-то доступ к сети появился у меня дома и когда выдался первый свободный выходной - я протестировал.
Тестировал на Roverbook U800, процессор AMD Geode LX - 500 MHz (15 x 33) - CPUID определил его как AMD K6-2+ 498 MHz (4.5 x 110). Видео встроенное в центральный процессор - никакого графического ускорителя - полный VESA. :-)

Смотрел с максимальным глифом - скорость отрисовки хорошая. Для полноценного теста нужно отрисовывать кусок текста, тогда будет видна действительно реальная скорость какой она будет в приложении.

Ну и для полноты ощущений - программа жрет 400000h, что является 4 Мб в обычном представлении. Вероятно при компиляции бинарника что-то прошло неправильно.


Top
   
PostPosted: Sat May 21, 2011 6:40 pm 
Offline

Joined: Mon Sep 24, 2007 11:11 am
Posts: 2814
Про память я писал-это фича menuetlibc.


Top
   
PostPosted: Mon May 30, 2011 9:19 pm 
Offline

Joined: Mon Sep 24, 2007 11:11 am
Posts: 2814
Предлагаю начать обсуждение API библиотеки. Сейчас самое время для этого. Высказывайте свободно свои мысли и свои желания, по возможности они будут учтены. Это официальное приглашение к обсуждению, если не высказать своё мнение по вопросам библиотеки сейчас - потом может быть уже поздно.


Top
   
PostPosted: Mon May 30, 2011 9:22 pm 
Offline
User avatar

Joined: Tue Aug 25, 2009 4:45 pm
Posts: 794
Взять подмножество функций из http://freetype.sourceforge.net/freetyp ... 2-toc.html ?


Top
   
PostPosted: Mon May 30, 2011 9:22 pm 
Offline
User avatar

Joined: Mon Apr 16, 2007 6:38 pm
Posts: 1222
Sorcerer, "если не высказать своё мнение по вопросам библиотеки сейчас - потом может быть уже поздно." - т.е. библиотека будет closed-source?

_________________
И мы уже давно не пешки,
Мы пули, мы орлы, и решки!
Война ютит бинарный код,
Умри, или иди вперед!


Top
   
Display posts from previous:  Sort by  
Post new topic  Reply to topic  [ 46 posts ]  Go to page 1 2 3 4 Next

All times are UTC+03:00


Who is online

Users browsing this forum: No registered users and 3 guests


You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot post attachments in this forum

Search for:
Jump to:  
Powered by phpBB® Forum Software © phpBB Limited