Московский государственный университет имени М.В.Ломоносова
Опубликован: 23.04.2007 | Доступ: свободный | Студентов: 3281 / 443 | Оценка: 4.18 / 3.71 | Длительность: 17:54:00
ISBN: 978-5-9556-0098-7
Специальности: Программист
Лекция 11:

Алгоритмы повышения количества оттенков (псевдотонирования)

< Лекция 10 || Лекция 11: 123 || Лекция 12 >

11.3. Алгоритм упорядоченного размытия

Очевидно, что метод, рассмотренный в "Алгоритмы повышения количества оттенков (псевдотонирования)" , требует улучшений. Можно специально добавить в исходное изображение шум1некоторую, часто случайную, величину , а затем применить алгоритм 11.1. Если добавлять произвольный шум, то результаты алгоритма нельзя считать удовлетворительными.

Тем не менее существует искусственный псевдошум, который минимизирует эффект периодичности, т.е. появления на изображении некоторого упорядоченного узора. Данный шум возможно задать с помощью квадратной матрицы специального вида [13]. Такая матрица называется матрицей размытия2(англ.) dither matrix. Сначала исходное изображение разбивается на квадратные области размером NxN, совпадающие с размерностью матрицы размытия, затем к каждому квадрату применяется алгоритм 11.2, где в качестве порога выбирается соответствующее значение из матрицы.

Исходное изображение.

Рис. 11.3. Исходное изображение.

Для случая 2x2 оптимальной является следующая матрица:

D_2 = 
{\left( \begin{array}{cc} 
0 & 2 \\ 
3 & 1 
\end{array} \right)}.

Для получения матриц большего размера следует использовать следующие рекурсивные соотношения:

D_n = 
{ \left( \begin{array}{cc} 
4D_{n/2} & 4D_{n/2} + 2U_{n/2} \\ 
4D_{n/2} + 3U_{n/2} & 4D_{n/2} + U_{n/2}  
\end{array} \right) },

где

U_n  = 
\left( \begin{array}{ccccc} 
1 & 1 & 1 & \ldots & 1 \\ 
1 & 1 & 1 & \ldots & 1 \\ 
1 & 1 & 1 & \ldots & 1 \\ 
\vdots & \vdots & \vdots & \ddots & 1 \\  
1 & 1 & 1 & 1 & 1 
\end{array} \right)

- матрица, состоящая из единиц размером nxn. Например, матрица размером 4x4 будет следующая:

D_4  = 
{ \left( \begin{array}{cccc} 
0 & 8 & 2 & 10 \\ 
12 & 4 & 14 & 6 \\ 
3 & 11 & 1 & 9 \\ 
15 & 7 & 13 & 5 
\end{array} \right) }.
Результат работы простого метода псевдотонирования.

Рис. 11.4. Результат работы простого метода псевдотонирования.
Результат работы алгоритма упорядоченного размытия.

Рис. 11.5. Результат работы алгоритма упорядоченного размытия.

Матрица размытия Dn позволяет получить n2 значений атрибутов; при этом пространственное разрешение не изменяется. Ниже приведен псевдокод алгоритма:

foreach( pixel in 8bit_picture ) // для каждого пикселя
{
      // I(pixel) - атрибут пикселя
      // Dn(i,j) - матрица размытия, n - размер матрицы
      // X Mod Y - остаток от деления X на Y
      // i, pixel.Y - координаты строк
      i = pixel.Y Mod n;
      // j, pixel.X - координаты столбцов
      j = pixel.X Mod n;
      if( I(pixel) > Dn(i,j) )
          I(pixel) = Белый;
      else
          I(pixel) = Черный;
}
Листинг 11.2. Алгоритм псевдотонирования - упорядоченное размытие

Как видно из рис. 11.5 результаты работы данного алгоритма намного лучше, чем описанного в разделе "Алгоритмы повышения количества оттенков (псевдотонирования)" , - изображение выглядит более детально.

< Лекция 10 || Лекция 11: 123 || Лекция 12 >