Программирование - это просто
Advertisement
Главная arrow Искусственный интеллект arrow Компьютерное зрение (платный раздел). arrow Компьютерное зрение. Урок 12. Компенсация яркости изображения.
29.04.2017 г.
Главное меню
Главная
Системный подход
Интернет магазин
Биржевые роботы
Программные продукты
Математика и информатика
1С:Предприятие
C#, Delphi, VB, F#, Web и пр.
Искусственный интеллект
Услуги
Ча. Во. (FAQ)
Платный раздел
Наука для чайников
Разное
Размышления
Карта сайта
Друзья сайта
Excel-это не сложно
Все о финансах
Компьютерное зрение. Урок 12. Компенсация яркости изображения. Печать E-mail
Автор megabax   
25.05.2016 г.
New Page 1

Компьютерное зрение. Урок 12. Компенсация яркости изображения.

Что бы смотреть урок полностью, подпишитесь на платный раздел.

В платном разделе статья находиться здесь.


Допустим, у нас есть вот такой вот сфотографированный текст:

Компьютерное зрение. Урок 12. Компенсация яркости изображения.

На данной фотографии в одном месте текст достаточно контрастный, а в другом его вообще практически не видно. Вопрос: как сделать, чтобы фотография вся была нормальная? ...

...

...

r - сама картинка:

Компьютерное зрение. Урок 12. Компенсация яркости изображения.

...

...

...Тестируем:

Компьютерное зрение. Урок 12. Компенсация яркости изображения.

Теперь, прежде чем написать программу для применения фильтра с учетом зеркального дополнения, напишем программу обрезания изображения: ...

...

...

Теперь попробуем применить фильтр Гаусса к нашей калибровочной картине, но уже с учетом зеркального дополнения:

Компьютерное зрение. Урок 12. Компенсация яркости изображения.

Итак, мы выделили ...

...

...

... Соответственно, деление всего фрейма - это деление каждой точки:

        /// <summary>

        /// Деление фреймов

        /// </summary>

        /// <param name="frame">Фрейм, на который мы делим</param>

        /// <returns>Результатирующий фрейм</returns>

        public RGBFrame division(RGBFrame frame)

        {

            RGBFrame res = new RGBFrame(width, height);

            for (int i = 0; i < width; i++)

            {

                for (int j = 0; j < height; j++)

                {

                    res.matrix[i, j] = matrix[i, j].division(frame.matrix[i, j]);

                }

            }

            return res;

        }

Применим этот алгоритм к нашей калибровочной картинке:

Компьютерное зрение. Урок 12. Компенсация яркости изображения.

Для картинки, которая приведена в начале статьи (отсканированный текст):

Компьютерное зрение. Урок 12. Компенсация яркости изображения.

А вот что будет, если применить метод к картинке из урока Компьютерное зрение. Урок 6. Основы обработки изображений. Линейная коррекция яркости:...

...

...

Последнее обновление ( 25.05.2016 г. )
 
« Пред.   След. »
 
© 2017 Программирование - это просто
Joomla! - свободное программное обеспечение, распространяемое по лицензии GNU/GPL.
Русская локализация © 2005-2008 Joom.Ru - Русский Дом Joomla!
Design by Mamboteam.com | Powered by Mambobanner.de
Я принимаю Яндекс.Деньги
Мы принимаем
Банковские карты
Оплатите покупку в интернет-магазине банковскими картами VISA и Mastercard любого банка.
узнать больше
Электронный кошелек
Моментальная оплата покупок с помощью вашего электронного кошелька RBK Money.
узнать больше
Банковский платеж
Оплатите покупку в любом российском банке. Срок зачисления средств на счет - 3-5 рабочих дней.
узнать больше
Денежные переводы
Оплата покупок через крупнейшие системы денежных переводов CONTACT и Unistream.
узнать больше
Почтовые переводы
Оплатите покупку в любом отделении Почты России. Срок зачисления платежа - 3-4 рабочих дня.
узнать больше
Платежные терминалы
Оплата покупок в терминалах крупнейших платежных систем в любом городе России - быстро и без комиссии.
узнать больше