Gauss-Boaga to WGS84



我正在尝试将一些坐标从Gauss-Boaga转换为WGS84。下面是我所做的(PHP):

function gaussToLatLng($Eutm, $Nutm){
    // parametri che dipendono dal fuso ovest
    $l0 = 9;
    $fraz = $Nutm/111092.0821;
    echo "$fraz ";
    $A= $fraz + 
        (0.1449300705 * sin(deg2rad(2*$fraz))) + 
        (0.0002138508 * sin(deg2rad(4*$fraz))) + 
        (0.0000004322 * sin(deg2rad(6*$fraz)));
    $v = sqrt(1 + (0.0067681702 * cos(deg2rad($A)) * cos(deg2rad($A)) ) );
    $y = $Eutm - 500000;
    $B = rad2deg(atan( ($v * sinh(deg2rad($y/6397376.633)) ) / cos(deg2rad($A))));
    $lng = rad2deg(atan(tan(deg2rad($A)) * cos(deg2rad($v * $B))));
    $lat = $B + $l0;
    echo "A=$A, B=$B n";
    return array(
        'lat' => $lat,
        'lng' => $lng
    );
}

使用(1517140,5036970)作为输入,我得到(9.2271558768758 45.485183518206),而使用这个在线工具,我计算出我应该有(9.2189597,45.4859253)(大约1公里的差异)。

你能帮我找出代码中的错误吗?

使用PHP库解决:proj4php,使用此处找到的Gauss Boaga fuso oest的定义。

那些家伙太棒了!

最新更新