51 / 37 / 14
Регистрация: 05.08.2016
Сообщений: 187
1

Как упростить функцию

29.05.2019, 15:24. Показов 1191. Ответов 4

Author24 — интернет-сервис помощи студентам
Добрый день!
Есть программа, которая выводит на экран изображение попиксельно. Имеется две картинки: одна должна наложиться на другую, с определенной прозрачностью. Все уже сделано и работает, нужно упростить алгоритм, желательно битовыми операциями.
pds - указатель на массив пиксельей RGB (типа 0хff00ff), которые выводим на экран, clr - верхняя картинка , bgsrc - нижняя, transparence - процент прозрачности первой картинки = 70%.
Алгоритм:
C++
1
2
3
4
5
6
7
                                
pDst->red = ((clr >> 16 & 0xff) * transparence / 100)
    + (bgsrc->red * (100 - transparence) / 100);
pDst->green = (((clr >> 8) & 0xff) * transparence / 100)
        + (bgsrc->green * (100 - transparence) / 100);
pDst->blue = (((clr) & 0xff) * transparence / 100)
        + (bgsrc->blue * (100 - transparence) / 100);
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
29.05.2019, 15:24
Ответы с готовыми решениями:

Как упростить булеву функцию ?
11) ((d *רc)+( רd*רb)+(c *רb))+(( רd*b)+(c*b))+( רa*a) , необходимо сократить булеву функцию...

подскажите как упростить даную функцию
function loadLog(){ $.ajax({ url: "message.php", cache: false, success: function(html){ ...

Как можно упростить код с TextBox или же минимизировать данную функцию?
На форме есть 2 textBox, ВОПРОС...Как можно упрастить код или же минимозировать данную функцию ???...

Упростить функцию n!/(k!*(n!-k!)?
Здравствуйте. Мне необходимо написать алгоритм для расчета функции: n! -----------...

4
6579 / 4564 / 1843
Регистрация: 07.05.2019
Сообщений: 13,726
29.05.2019, 16:29 2
Лучший ответ Сообщение было отмечено Pavel250 как решение

Решение

Цитата Сообщение от Pavel250 Посмотреть сообщение
Все уже сделано и работает, нужно упростить алгоритм, желательно битовыми операциями.
transparence сделай не от нуля до 100, а от нуля до 256 (или 128), тогда деление на 100 можно будет заменить битовой операцией. В остальном там вроде нечего оптимизировать.
1
51 / 37 / 14
Регистрация: 05.08.2016
Сообщений: 187
29.05.2019, 20:24  [ТС] 3
oleg-m1973, Остановился на таком варианте, жестко выставил 75%.
C++
1
2
3
4
5
6
7
8
pDst->red = (((clr >> 16 & 0xff) * 10)>>4)
    + ((bgsrc->red * 6)>>4);
 
pDst->green = ((((clr >> 8) & 0xff) * 10)>>4)
    + ((bgsrc->red * 6)>>4);
 
pDst->blue = ((((clr) & 0xff) * 10)>>4)
    + ((bgsrc->red * 6)>>4);
И вариант для для rgb типа 0xFF0000
C++
1
2
*dst=(((*clr & 0xFF0000) *10>> 4)& 0xFF0000) + (((*clr & 0xFF00)*10>> 4)&0xFF00)+((*clr & 0xFF)*10>> 4)+
     (((*bgdst & 0xFF0000)*6>> 4)& 0xFF0000) + (((*bgdst & 0xFF00)*6>> 4)&0xFF00)+((*bgdst & 0xFF)*6>> 4);
Спасибо за подсказку!
0
6579 / 4564 / 1843
Регистрация: 07.05.2019
Сообщений: 13,726
29.05.2019, 20:33 4
Цитата Сообщение от Pavel250 Посмотреть сообщение
oleg-m1973, Остановился на таком варианте, жестко выставил 75%.
Константа, это нифига не показатель. Надо всё-таки переменную.
Насколько я понял, эти строчки у тебя вызываются для каждого пикселя. Поэтому лучше вначале, для всего изображения, сделать transparence степенью двойки (лучше 256) и вычислить (256 - transparence)
0
51 / 37 / 14
Регистрация: 05.08.2016
Сообщений: 187
29.05.2019, 21:39  [ТС] 5
oleg-m1973, просто решили, прозрачность будет одна. А добавить переменную не сложно, можно будет плавный переход делать между изображениями. Для 50% алгоритм упрощается еще больше
C++
1
2
*dst=(((*clr & 0xFF0000) >> 1) & 0xFF0000) + (((*clr & 0xFF00) >> 1) & 0xFF00)+((*clr & 0xFF) >> 1)+
     (((*bgdst & 0xFF0000) >> 1) & 0xFF0000) + (((*bgdst & 0xFF00) >> 1) & 0xFF00)+((*bgdst & 0xFF) >> 1);
Это все будет трудится на микроконтроллере, со встроенным LCD процессором. Не охота грузить его библиотеками, вот и приходится писать такие вещи. Еще свой алгоритм RLE сжатия картинок запилили. Чтоб меньше памяти занимать. А восстанавливается с такими же ресурсами, как и простая картинка.
0
29.05.2019, 21:39
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.05.2019, 21:39
Помогаю со студенческими работами здесь

Упростить функцию
not(not(not(not(A)+B)*C)+not(B)+C) Ответ в конце должен получится: 0. А как упростить не понимаю.

Упростить функцию
помогите пожалуйста.

Упростить функцию
Уважаемые форумчане-мегамозги, помогите, пожалуйста! Буду безгранично благодарна за решение. 1....

Упростить функцию
Помогите пожалуйста. Нужно упростить код и сделать так, чтобы была одна функция которая решает...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru