Тайлы из Landsat 8: различия между версиями
Zverik (обсуждение | вклад) (→См. также: pan) |
Zverik (обсуждение | вклад) м (→Паншарпенинг: опечатка) |
||
(не показано 12 промежуточных версий 2 участников) | |||
Строка 1: | Строка 1: | ||
{{Статья| | {{Статья|Опубликована|landsat-tiles}} | ||
{{Аннотация|Упрощённая инструкция по получению и обработке снимков Landsat 8 и подготовке из них тайлов}} | {{Аннотация|Упрощённая инструкция по получению и обработке снимков Landsat 8 и подготовке из них тайлов}} | ||
Главное свойство данных ДЗЗ Landsat 8 — свободная лицензия, которая позволяет обрисовывать снимки для, в частности, OpenStreetMap. Эта статья не вдаётся в теорию, но содержит шаги для поиска и обработки снимков Landsat 8 и их превращения в тайлы для публикации или обрисовки в JOSM. | Главное свойство данных ДЗЗ Landsat 8 — свободная лицензия, которая позволяет обрисовывать снимки для, в частности, OpenStreetMap. Эта статья не вдаётся в теорию, но содержит шаги для поиска и обработки снимков Landsat 8 и их превращения в тайлы для публикации или обрисовки в JOSM. | ||
Некоторые шаги будет непросто выполнить в ОС Windows. Для пользователей этой системы советуем [http://gis-lab.info/qa/qgis-osgeo4w.html установить OSGeo4W] и делать [http://courses.neteler.org/processing-landsat-8-data-in-grass-gis-7-rgb-composites-and-pan-sharpening/ паншарпенинг и цветовую коррекцию в GRASS]. | |||
== Получение снимка == | == Получение снимка == | ||
Строка 10: | Строка 13: | ||
http://libra.developmentseed.org | http://libra.developmentseed.org | ||
Напоминаем, что каждый снимок весит 500-800 мегабайт в архиве (2 гигабайта вне его), и для обработки потребуются ещё гигабайта четыре. | Напоминаем, что каждый снимок весит 500-800 мегабайт в архиве (2 гигабайта вне его), и для обработки потребуются ещё гигабайта четыре. Под линуксом файл распаковывается такой командой: | ||
tar -xjvf LC*.tar.bz | |||
В архиве вы получите [ | В архиве вы получите [http://geektimes.ru/post/183416/ 11 каналов] и слой QA, на котором отмечены точки без информации о земной поверхности (например, облака). Мы будем работать с каналами 2, 3, 4 (синий, зелёный, красный) и 8 (ч/б с 15-метровым разрешением). | ||
== Паншарпенинг == | == Паншарпенинг == | ||
Строка 18: | Строка 23: | ||
У нас есть 3 канала с разрешением 30 м/пк и один — 15 м/пк. Паншарпенинг — это объединение их всех в один цветной снимок максимального разрешения. Раньше его делали длинным цепочками команд GDAL или ImageMagick, но нам повезло. Умные люди из GINA (университет Аляски) написали [https://github.com/gina-alaska/dans-gdal-scripts/ скрипт], и теперь достаточно одной команды. Набор аляскинских скриптов есть в большинстве дистрибутивов, поищите пакет ''dans-gdal-scripts''. Команда такая: | У нас есть 3 канала с разрешением 30 м/пк и один — 15 м/пк. Паншарпенинг — это объединение их всех в один цветной снимок максимального разрешения. Раньше его делали длинным цепочками команд GDAL или ImageMagick, но нам повезло. Умные люди из GINA (университет Аляски) написали [https://github.com/gina-alaska/dans-gdal-scripts/ скрипт], и теперь достаточно одной команды. Набор аляскинских скриптов есть в большинстве дистрибутивов, поищите пакет ''dans-gdal-scripts''. Команда такая: | ||
gdal_landsat_pansharp | gdal_landsat_pansharp -pan B8.TIF -ndv 0 -o result.tif \ | ||
-rgb B4.TIF -rgb B3.TIF -rgb B2.TIF -lum B3.TIF 0.5 -lum B4.TIF 0.5 | -rgb B4.TIF -rgb B3.TIF -rgb B2.TIF -lum B3.TIF 0.5 -lum B4.TIF 0.5 | ||
Здесь опущены длинные идентификаторы снимков, вида «LC81850172014281LGN00». | Здесь опущены длинные идентификаторы снимков, вида «LC81850172014281LGN00». Для удобства пригодится такой скрипт: | ||
gdal_landsat_pansharp -pan | BASE=LC81850172014281LGN00 | ||
gdal_landsat_pansharp -pan ${BASE}_B8.TIF -ndv 0 -o result.tif \ | |||
-rgb ${BASE}_B4.TIF -rgb ${BASE}_B3.TIF -rgb ${BASE}_B2.TIF \ | |||
-lum ${BASE}_B3.TIF 0.5 -lum ${BASE}_B4.TIF 0.5 | |||
Что тут происходит? Первые три параметра передают панхроматический канал (восьмой), значение «нет данных» и имя выходного файла. Следующая тройка с <code>- | Что тут происходит? Первые три параметра передают панхроматический канал (восьмой), значение «нет данных» и имя выходного файла. Следующая тройка с <code>-rgb</code> — каналы для красного, зелёного и синего цветов. В Landsat 8 им соответствуют 4, 3 и 2, но можно выбрать другие, из [http://gis-lab.info/qa/landsat-bandcomb.html невидимых областей спектра]. | ||
Наконец, параметры <code>-lum</code> корректируют наложение цвета на панхроматический канал. [https://github.com/gina-alaska/dans-gdal-scripts/wiki/Gdal_landsat_pansharp Описание алгоритма] слишком сложное, мы взяли коэффициенты из [https://gist.github.com/dwtkns/d18828165160384d0fe1 этих функций] Дерека Уоткинса. | Наконец, параметры <code>-lum</code> корректируют наложение цвета на панхроматический канал. [https://github.com/gina-alaska/dans-gdal-scripts/wiki/Gdal_landsat_pansharp Описание алгоритма] слишком сложное, мы взяли коэффициенты из [https://gist.github.com/dwtkns/d18828165160384d0fe1 этих функций] Дерека Уоткинса. | ||
Строка 33: | Строка 39: | ||
== Коррекция цвета == | == Коррекция цвета == | ||
Снимок после паншарпенинга получится либо весь в белой дымке, либо невозможно тёмный. Для его использования обязательна коррекция цвета, хотя бы методом автоматического растягивания гистограммы. | |||
=== Автоматически === | |||
В GDAL нет команды для обработки цвета, подобной вкладке в QGIS, но тот же аляскинском наборе содержит скрипт, выдающий приемлемый результат: | |||
gdal_contrast_stretch -ndv 0 -percentile-range 0.05 0.95 result.tif result2.tif | gdal_contrast_stretch -ndv 0 -percentile-range 0.05 0.95 result.tif result2.tif | ||
Доли отбрасываемых цветов можно покрутить на ±0.03: чем ближе к 0-100, тем темнее получается картинка, но тем больше деталей сохраняется. | Доли отбрасываемых цветов можно покрутить на ±0.03: чем ближе к 0-100, тем темнее получается картинка, но тем больше деталей сохраняется. | ||
=== В графическом редакторе === | |||
Раз tif — обычная картинка с доп. полями, можно открыть его в [http://imagej.nih.gov/ij/ ImageJ] или ином редакторе и подкрутить контраст вручную, акцентируя нужные полосы. Чтобы сохранить геопривязку, понадобятся программы из пакета ''libgeotiff'' (иногда ''geotiff-bin''). Экспорт геопривязки в файл: | |||
listgeo result.tif > result.geo | |||
Восстановление геопривязки для отредактированного файла (сохранять нужно, понятно, тоже в формате TIFF): | |||
geotifcp -g result.geo edited.tif edited_geo.tif | |||
== Изображение == | == Изображение == | ||
Строка 44: | Строка 64: | ||
convert result.tif -quality 85 result.jpg | convert result.tif -quality 85 result.jpg | ||
Программа выдаст несколько предупреждений об «unknown field with tag». Это нормально: она не умеет читать поля TIFF с геопривязкой, и пропускает их. | |||
== Тайлы == | == Тайлы == | ||
Строка 54: | Строка 76: | ||
gdal2tiles.py -r lanczos -z 6-13 -a 0 result_merc.tif tiles | gdal2tiles.py -r lanczos -z 6-13 -a 0 result_merc.tif tiles | ||
Она работает медленно, | Она работает очень медленно, сохраняет тайлы только в PNG и выдаёт странные ошибки во время работы. Альтернатива — QTiles. | ||
=== В QGIS === | === В QGIS === | ||
Строка 81: | Строка 103: | ||
* [http://joelarson.com/landsat/2013/12/17/landsat-pan-sharpening-and-processing/ Эксперименты с каналами] | * [http://joelarson.com/landsat/2013/12/17/landsat-pan-sharpening-and-processing/ Эксперименты с каналами] | ||
* [http://blog.remotesensing.io/2013/04/pansharpening-using-a-handy-gdal-tool/ Команды для Landsat 7] | * [http://blog.remotesensing.io/2013/04/pansharpening-using-a-handy-gdal-tool/ Команды для Landsat 7] | ||
* [http://landsat.usgs.gov/Landsat_Processing_Details.php Орторектифицирован ли снимок?] | * [http://landsat.usgs.gov/Landsat_Processing_Details.php Орторектифицирован ли снимок?] (обычно да) | ||
* [https://www.mapbox.com/blog/processing-landsat-8/ Подготовка снимков в ImageMagick] | * [https://www.mapbox.com/blog/processing-landsat-8/ Подготовка снимков в ImageMagick] | ||
* [[Паншарпенинг данных Landsat 8 средствами свободного ПО]] | * [[Паншарпенинг данных Landsat 8 средствами свободного ПО]] |
Текущая версия от 19:27, 28 августа 2015
по адресу http://gis-lab.info/qa/landsat-tiles.html
Упрощённая инструкция по получению и обработке снимков Landsat 8 и подготовке из них тайлов
Главное свойство данных ДЗЗ Landsat 8 — свободная лицензия, которая позволяет обрисовывать снимки для, в частности, OpenStreetMap. Эта статья не вдаётся в теорию, но содержит шаги для поиска и обработки снимков Landsat 8 и их превращения в тайлы для публикации или обрисовки в JOSM.
Некоторые шаги будет непросто выполнить в ОС Windows. Для пользователей этой системы советуем установить OSGeo4W и делать паншарпенинг и цветовую коррекцию в GRASS.
Получение снимка
Раньше нужно было шоркаться по EarthExplorer, вводить параметры поиска, что-то выбирать. Спасибо DevelopmentSeed, много лет работающей с Landsat, теперь выбрать нужный снимок проще. Заходите, приближайте свою область, кликайте в точку, фильтруйте и скачивайте:
http://libra.developmentseed.org
Напоминаем, что каждый снимок весит 500-800 мегабайт в архиве (2 гигабайта вне его), и для обработки потребуются ещё гигабайта четыре. Под линуксом файл распаковывается такой командой:
tar -xjvf LC*.tar.bz
В архиве вы получите 11 каналов и слой QA, на котором отмечены точки без информации о земной поверхности (например, облака). Мы будем работать с каналами 2, 3, 4 (синий, зелёный, красный) и 8 (ч/б с 15-метровым разрешением).
Паншарпенинг
У нас есть 3 канала с разрешением 30 м/пк и один — 15 м/пк. Паншарпенинг — это объединение их всех в один цветной снимок максимального разрешения. Раньше его делали длинным цепочками команд GDAL или ImageMagick, но нам повезло. Умные люди из GINA (университет Аляски) написали скрипт, и теперь достаточно одной команды. Набор аляскинских скриптов есть в большинстве дистрибутивов, поищите пакет dans-gdal-scripts. Команда такая:
gdal_landsat_pansharp -pan B8.TIF -ndv 0 -o result.tif \ -rgb B4.TIF -rgb B3.TIF -rgb B2.TIF -lum B3.TIF 0.5 -lum B4.TIF 0.5
Здесь опущены длинные идентификаторы снимков, вида «LC81850172014281LGN00». Для удобства пригодится такой скрипт:
BASE=LC81850172014281LGN00 gdal_landsat_pansharp -pan ${BASE}_B8.TIF -ndv 0 -o result.tif \ -rgb ${BASE}_B4.TIF -rgb ${BASE}_B3.TIF -rgb ${BASE}_B2.TIF \ -lum ${BASE}_B3.TIF 0.5 -lum ${BASE}_B4.TIF 0.5
Что тут происходит? Первые три параметра передают панхроматический канал (восьмой), значение «нет данных» и имя выходного файла. Следующая тройка с -rgb
— каналы для красного, зелёного и синего цветов. В Landsat 8 им соответствуют 4, 3 и 2, но можно выбрать другие, из невидимых областей спектра.
Наконец, параметры -lum
корректируют наложение цвета на панхроматический канал. Описание алгоритма слишком сложное, мы взяли коэффициенты из этих функций Дерека Уоткинса.
Коррекция цвета
Снимок после паншарпенинга получится либо весь в белой дымке, либо невозможно тёмный. Для его использования обязательна коррекция цвета, хотя бы методом автоматического растягивания гистограммы.
Автоматически
В GDAL нет команды для обработки цвета, подобной вкладке в QGIS, но тот же аляскинском наборе содержит скрипт, выдающий приемлемый результат:
gdal_contrast_stretch -ndv 0 -percentile-range 0.05 0.95 result.tif result2.tif
Доли отбрасываемых цветов можно покрутить на ±0.03: чем ближе к 0-100, тем темнее получается картинка, но тем больше деталей сохраняется.
В графическом редакторе
Раз tif — обычная картинка с доп. полями, можно открыть его в ImageJ или ином редакторе и подкрутить контраст вручную, акцентируя нужные полосы. Чтобы сохранить геопривязку, понадобятся программы из пакета libgeotiff (иногда geotiff-bin). Экспорт геопривязки в файл:
listgeo result.tif > result.geo
Восстановление геопривязки для отредактированного файла (сохранять нужно, понятно, тоже в формате TIFF):
geotifcp -g result.geo edited.tif edited_geo.tif
Изображение
Если снимок нужен для иллюстрирования, а не для обрисовки, можно просто взять файл tif: этот формат читается всеми. Как вариант, с помощью ImageMagick можно из него сделать более удобный jpeg:
convert result.tif -quality 85 result.jpg
Программа выдаст несколько предупреждений об «unknown field with tag». Это нормально: она не умеет читать поля TIFF с геопривязкой, и пропускает их.
Тайлы
С помощью GDAL
В комплекте GDAL есть программа для создания тайлов из геопривязанного растра:
gdalwarp -t_srs EPSG:3857 result.tif result_merc.tif gdal2tiles.py -r lanczos -z 6-13 -a 0 result_merc.tif tiles
Она работает очень медленно, сохраняет тайлы только в PNG и выдаёт странные ошибки во время работы. Альтернатива — QTiles.
В QGIS
Собранный растр можно обработать в QGIS, а не запускать дополнительные скрипты. Если не правили контраст скриптом, в свойствах растрового слоя, во вкладке «Стиль» нужно выбрать «Среднее ± отклонение × 2», нажать кнопку «Загрузить» — и «OK».
Отсюда же легко сделать тайлы с помощью модуля QTiles. Если его не видно в списке модулей, включите в настройках «также показывать экспериментальные модули». Если нет вкладки настроек — установите пакет qgis-python или подобный.
Тайлы рекомендуем делать в формате jpeg, до 13 масштаба. Демонстрационную html-страницу придётся поправить, заменив расширение тайлов на jpg. В JOSM тайлы подключаются так же, как и раньше, только поправьте расширение.
Подключение в JOSM
Чтобы подключить слой в JOSM, скопируйте строку для него из демонстрационной страницы, либо напишите сами:
tms[13]:file:///home/user/путь/к/тайлам/{zoom}/{x}/{y}.png
Для Windows путь записывается чуть по-другому:
tms[13]:file:///C:/путь/к/тайлам/{zoom}/{x}/{y}.png
Не забывайте проверять привязку по трекам.