Участник:Anton/Песочница
Материал из MachineLearning.
Строка 16: | Строка 16: | ||
Среда реализации для всех вариантов — MATLAB. Неэффективная реализация кода может негативно отразиться на оценке. | Среда реализации для всех вариантов — MATLAB. Неэффективная реализация кода может негативно отразиться на оценке. | ||
- | == | + | == Сегментация изображений == |
- | + | В рамках данного задания рассматривается задача сегментации изображений на два класса: машина и фон. | |
- | + | ||
- | + | ||
- | + | ||
- | + | ||
- | + | ||
- | + | Ответом (сегментацией изображения) является аргминимум бинарной субмодулярной функции совместимости (максимизация супермодулярной функции), состоящей из унарных и парных потенциалов. | |
- | + | ||
- | + | ||
- | + | ||
- | + | Поскольку классы не сбалансированы (на изображениях пикселей фона намного больше, чем пикселей объекта), то ошибка сегментации определяется количеством правильно распознанных пикселей каждого класса, взвешенным на общее количество пикселей этого класса на изображении: | |
- | + | ||
- | # | + | <tex> error(Y, \hat{Y}) = \frac{\sum_p [y_p \neq 1][\hat{y}_p = 1]}{\sum_p [\hat{y}_p = 1]} + \frac{\sum_p [y_p \neq 0][\hat{y}_p = 0]}{\sum_p [\hat{y}_p = 0]}</tex>. |
- | # | + | |
- | # | + | Здесь Y — текущая разметка изображения, Ŷ — правильная разметка; метка фона — 0, метка объекта — 1; все суммы берутся по всем пикселям изображения. |
+ | |||
+ | Для выполнения задания выдается: | ||
+ | # исходные изображения; | ||
+ | # правильная разметка изображений; | ||
+ | # сегментация изображения на суперпиксели; | ||
+ | # признаки для каждого суперпикселя; вектором признаков является гистограмма по мешку из 128 слов, построенному по SIFT. Признаки посчитаны при помощи библиотеки VLFeat. | ||
- | |||
- | |||
- | |||
- | |||
- | |||
- | |||
- | |||
- | |||
== Вариант 1 : TRW== | == Вариант 1 : TRW== |
Версия 12:24, 17 апреля 2012
Задание находится в разработке. Не приступайте к выполнению задания до его официальной выдачи. |
|
Начало выполнения задания: 18 апреля 2012
Срок сдачи: 2 мая 2012, 23:59
Среда реализации для всех вариантов — MATLAB. Неэффективная реализация кода может негативно отразиться на оценке.
Сегментация изображений
В рамках данного задания рассматривается задача сегментации изображений на два класса: машина и фон.
Ответом (сегментацией изображения) является аргминимум бинарной субмодулярной функции совместимости (максимизация супермодулярной функции), состоящей из унарных и парных потенциалов.
Поскольку классы не сбалансированы (на изображениях пикселей фона намного больше, чем пикселей объекта), то ошибка сегментации определяется количеством правильно распознанных пикселей каждого класса, взвешенным на общее количество пикселей этого класса на изображении:
.
Здесь Y — текущая разметка изображения, Ŷ — правильная разметка; метка фона — 0, метка объекта — 1; все суммы берутся по всем пикселям изображения.
Для выполнения задания выдается:
- исходные изображения;
- правильная разметка изображений;
- сегментация изображения на суперпиксели;
- признаки для каждого суперпикселя; вектором признаков является гистограмма по мешку из 128 слов, построенному по SIFT. Признаки посчитаны при помощи библиотеки VLFeat.
Вариант 1 : TRW
Задание
- Вывести все формулы, использующиеся в вашей реализации TRW (формулировки прямой и двойственной задач, формула подсчета субградиента, конкретная схема субградиентного подъема, и т.д.).
- Реализовать алгоритм TRW.
- Протестировать алгоритм TRW на модельных данных.
- Привести примеры наличия и отсутствия зазора между решениями прямой и двойственной задач (например, зазор должен отсутствовать в случае субмодулярной энергии).
- Реализовать процедуру решения задачи стерео.
- Подобрать параметры так, чтобы на выданных стереопарах достигался хороший результат. Набор параметров может быть своим для каждой стереопары.
- На одной стереопаре из предыдущего пункта сравнить работу алгоритмов TRW и α-расширение. Реализацию недостающего алгоритма можно взять у товарища, выполняющего другой вариант (в отчете обязательно указывать, чей код вы используете). Требуется провести сравнение по энергии получаемого решения, по времени работы, по визуальному качеству решения. Все выводы должны быть подтверждены числами, графиками, картинками.
- Написать отчет в формате PDF с описанием всех проведенных исследований.
Спецификация реализуемых функций
Алгоритм TRW | ||||||||
---|---|---|---|---|---|---|---|---|
[labels, energy, lowerBound, time] = trwGridPotts(unary, vertC, horC, metric) | ||||||||
[labels, energy, lowerBound, time] = trwGridPotts(unary, vertC, horC, metric, options) | ||||||||
ВХОД | ||||||||
| ||||||||
ВЫХОД | ||||||||
|
Обратите внимание: в процедуре trwGridPotts параметры N, M, и K определяются неявно по размеру соответствующих элементов.
Стерео | |
---|---|
[disparity] = stereo(name) | |
ВХОД | |
| |
ВЫХОД | |
|
В каталоге, из которого будет запускаться решение при проверке, будет лежать выданный каталог datasets.
Рекомендации по выполнению задания
1. При разбиении MRF-решетки только на вертикальные и горизонтальные цепочки формулировка несколько упрощается:
- Каждое ребро графа принадлежит только одному подграфу, а, значит, не нужно вводить двойственные переменные, соответствующие ребрам.
- Каждая вершина принадлежит только двум деревьям, а, значит, можно ввести |P|K двойственных переменных, соответствующих условиям , где hor и vert обозначают горизонтальную и вертикальную цепочку, проходящую через p-ю вершину.
2. Поскольку двойственная функция вогнута и кусочно-линейна, оптимизировать ее можно при помощи алгоритма субградиентного подъема.
Каждый шаг метода субградиентного подъема состоит в пересчете значений двойственных переменных λ по следующему правилу:
где — субградиент в текущей точке, — параметр, отвечающий за длину сдвига.
В рамках данного практического задания можно использовать любой способ субградиентного подъема. Например, можно использовать следующий адаптивный метод выбора длины шага:
где — текущее значение двойственной функции, — оценка оптимума двойственной функции, которую можно определять следующим способом:
где — лучшее на данный момент значение двойственной функции,
— параметры метода. Обычно . Конкретные значения этих параметров нужно подобрать.
Подробнее о методах субградиентного подъема написано в статье: N. Komodakis, N.Paragios and G. Tziritas, MRF Energy Minimization and Beyond via Dual Decomposition, IEEE TPAMI, 33(3):531-552, 2011, http://www.csd.uoc.gr/~komod/publications/docs/DualDecomposition_PAMI.pdf
3. В качестве текущего значения энергии в рамках алгоритма TRW можно выбрать минимум энергий разметок, полученных по только вертикальным и только горизонтальным цепочкам.
4. При тестировании алгоритма TRW необходимо следить, чтобы наибольшее значение нижней границы было не больше, чем наименьшее значение энергии.
5. Потенциалы для стереопары tsukuba и примеры работы различных алгоритмов: http://vision.middlebury.edu/MRF/results/tsukuba/index.html
Данные для выполнения задания
rgb2luv — конвертер изображений в формат YUV.
datasets — стереопары.
Оформление задания
Выполненный вариант задания необходимо прислать письмом по адресу bayesml@gmail.com с темой «Задание 3. ФИО, вариант 1». Убедительная просьба присылать выполненное задание только один раз с окончательным вариантом. Новые версии будут рассматриваться только в самом крайнем случае. Также убедительная просьба строго придерживаться заданной выше спецификации реализуемых функций. Очень трудно проверять большое количество заданий, если у каждого будет свой формат реализации.
Письмо должно содержать:
- PDF-файл с описанием проведенных исследований (отчет должен включать в себя описание выполнения каждого пункта задания с приведением соответствующих графиков, изображений, чисел)
- trwGridPotts.m
- stereoTsukuba.m, stereoTeddy.m, stereoCones.m, stereoArt.m
- Набор вспомогательных файлов при необходимости
Вариант 2 : α-расширение
Задание
- Вывести все формулы, использующиеся в вашей реализации α-расширения (сведение шага алгоритма к разрезу графа).
- Реализовать алгоритм α-расширение, используя выданный код разрезов графов.
- Протестировать алгоритм α-расширение на модельных данных (например, решетка 100 x 100, 10 классов, случайные потенциалы).
- Реализовать процедуру решения задачи стерео.
- Подобрать параметры так, чтобы на выданных стереопарах достигался хороший результат. Набор параметров может быть своим для каждой стереопары.
- На одной стереопаре из предыдущего пункта сравнить работу алгоритмов TRW и α-расширение. Реализацию недостающего алгоритма можно взять у товарища, выполняющего другой вариант (в отчете обязательно указывать, чей код вы используете). Требуется провести сравнение по энергии получаемого решения, по времени работы, по визуальному качеству решения. Все выводы должны быть подтверждены числами, графиками, картинками.
- Написать отчет в формате PDF с описанием всех проведенных исследований.
Спецификация реализуемых функций
Алгоритм α-расширение | |||||||
---|---|---|---|---|---|---|---|
[labels, energy, time] = alphaExpansionGridPotts(unary, vertC, horC, metric) | |||||||
[labels, energy, time] = alphaExpansionGridPotts(unary, vertC, horC, metric, options) | |||||||
ВХОД | |||||||
| |||||||
ВЫХОД | |||||||
|
Обратите внимание: в процедуре alphaExpansionGridPotts параметры N, M, и K определяются неявно по размеру соответствующих элементов.
Стерео | |
---|---|
[disparity] = stereo(name) | |
ВХОД | |
| |
ВЫХОД | |
|
В каталоге, из которого будет запускаться решение при проверке, будет лежать выданный каталог datasets.
Рекомендации по выполнению задания
- Обратите внимание на область применимости алгоритма α-расширение.
- При тестировании алгоритма α-расширение необходимо следить за следующим:
- после каждого применения разреза графа общая энергия не возрастает;
- значение энергии, выдаваемое функцией graphCutMex, совпадает со значением энергии, подсчитанным независимой процедурой.
- Потенциалы для стереопары tsukuba и примеры работы различных алгоритмов: http://vision.middlebury.edu/MRF/results/tsukuba/index.html
Данные для выполнения задания
graphCut — MATLAB интерфейс к разрезам графов.
rgb2luv — конвертер изображений в формат YUV.
datasets — стереопары.
Оформление задания
Выполненный вариант задания необходимо прислать письмом по адресу bayesml@gmail.com с темой «Задание 3. ФИО, вариант 2». Убедительная просьба присылать выполненное задание только один раз с окончательным вариантом. Новые версии будут рассматриваться только в самом крайнем случае. Также убедительная просьба строго придерживаться заданной выше спецификации реализуемых функций. Очень трудно проверять большое количество заданий, если у каждого будет свой формат реализации.
Письмо должно содержать:
- PDF-файл с описанием проведенных исследований (отчет должен включать в себя описание выполнения каждого пункта задания с приведением соответствующих графиков, изображений, чисел)
- alphaExpansionGridPotts.m
- stereoTsukuba.m, stereoTeddy.m, stereoCones.m, stereoArt.m
- Набор вспомогательных файлов при необходимости