Библиотека PROJ.4 и OSGB36

Надеюсь, с тобой все хорошо

Я пытаюсь преобразовать координаты широты / долготы в OSGB36 x и y, используя библиотеку proj.4.

Кто-нибудь еще успешно сделал это? Мне нужно заполнить переменные srcPrj4String и destPrj4String, например

string srcPrj4String = "+ proj = longlat + ellps = WGS84 + datum = WGS84 + no_defs";
string destPrj4String = "+ proj = utm + zone = 11 + ellps = GRS80 + datum = NAD83 + units = m";

но я не могу понять, какой должна быть destPrj4String с OSGB36 - я знаю, что датум должен быть +datum=OSGB36, но все, что я пытаюсь, не работает

Есть идеи?

Спасибо заранее

Leddy

3 ответа

Решение

Понял:

string srcPrj4String = "+proj=longlat +ellps=WGS84 +towgs84=0,0,0 +no_defs";
string destPrj4String = "+proj=tmerc +lat_0=49 +lon_0=-2 +k=0.9996012717 +x_0=400000 +y_0=-100000 +ellps=airy +towgs84=446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894 +units=m +no_defs";

ура!

Googling говорит об этом от доктора Джона Стивенсона, академика наук о Земле из Университета Манчестера, который должен сделать это правильно, если кто-то это сделает. Вот цитата.


Проблема заключалась в том, что переход на OSGB36 требует как проекции, так и преобразования данных. До октября 2007 года proj выполнял только прогнозирование, что привело к большому смещению. Вы можете проверить, есть ли у вас новая версия, запустив 'proj -v' или посмотрев файл epsg:

cat /usr/share/proj/epsg | grep -A 1 "British National Grid" 

# OSGB 1936 / British National Grid 
<27700> +proj=tmerc +lat_0=49 +lon_0=-2 +k=0.9996012717 +x_0=400000 
+y_0=-100000 +ellps=airy +datum=OSGB36 +units=m +no_defs  <> 

В новых версиях +datum=OSGB36.

Если у вас есть старая версия, вы можете исправить ее, заменив строку на:

+proj=tmerc +lat_0=49 +lon_0=-2 +k=0.999601 +x_0=400000 +y_0=-100000 
+ellps=airy 
+towgs84=446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894 +units=m 
+no_defs <> 

Сложность состоит в том, что OSGB36 слегка искажен относительно проекций GPS (таких как WGS84 и ETRS89). Это смещение невелико и важно только для более точной съемки. Многие поиски о смещениях OSGB36 поднимают страницы, относящиеся к этому. Если вы хотите компенсировать это, вы можете скачать файл nadgrid и использовать его. По моим данным, это сдвинуло точки примерно на 1 метр.

EPSG:27700 на сайте realreference.org предоставляет различные строки для определения этого, включая строку для proj4.

Вот пример кода в ruby с использованием привязок proj4:

#!/usr/bin/ruby
require 'rubygems'
require 'proj4'

#Some example WGS84 lat lon coordinates to convert:
lon = -0.10322
lat = 51.52237

srcPoint = Proj4::Point.new(Math::PI * lon.to_f / 180, 
                            Math::PI * lat.to_f / 180)

srcPrj  = Proj4::Projection.new("+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs") 
destPrj = Proj4::Projection.new("+proj=tmerc +lat_0=49 +lon_0=-2 +k=0.999601 +x_0=400000 +y_0=-100000 +ellps=airy +towgs84=446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894 +units=m +no_defs <>")

point = srcPrj.transform(destPrj, srcPoint)

puts "http://www.openstreetmap.org/?mlat=" + lat.to_s + "&mlon=" + lon.to_s + "&zoom=16"
puts "Converts to:";
puts "http://streetmap.co.uk/grid/" + point.x.round.to_s + "_" + point.y.round.to_s + "_106"

Выход:

http://www.openstreetmap.org/?mlat=51.52237&mlon=-0.10322&zoom=16
Преобразует в:
http://streetmap.co.uk/grid/531691_182089_106

Так что это работает точно сейчас. Первоначально я пробовал просто строку 'destPrj' и вызывал метод 'forward', но это отказалось выполнить преобразование данных, в результате чего все получилось на расстоянии 100 м. Казалось необходимым использовать строку 'srcPrj' и метод 'transform', чтобы получить преобразование данных.

См. Также мое сообщение в блоге: код Ruby для преобразования в системы координат британского артиллерийского контроля из WGS84? который включает в себя чистую версию ruby ​​(не proj4) для того же

Другие вопросы по тегам