我正在尝试合并两个数据库以整合两个客户的网站。但是,客户端A一直使用常规的Lat / Lon对进行地理定位,而Client B使用Lambert 72(X / Y)坐标。
我已经构建了一个应该转换这些坐标的脚本(因为我不确定哪个坐标将在最终的合并数据库中使用,我正在尝试转换它们)。 我从这里拿了一些片段:http://zoologie.umh.ac.be/tc/algorithms.aspx
请注意,下面提到的所有坐标都指向比利时的位置。
我正在转换一些坐标以查看计算是否正确,但我得到的坐标似乎已经过时了。作为参考,比利时的中心大致是(North 50.84323737103243,East 4.355735778808594),所以我希望所有坐标都接近这些值。
我将Lambert 72值(X:151488250,Y:170492909)转换为Lat / Lon对,但结果是:( - 87.538 ...., - 50.724 ....)这是从预期值。 如果我转换整圆(Lambert-> LatLon-> Lambert,反之亦然),我得到的结果值与我输入的相同,所以我知道我的转换至少是一致的,并且转换是彼此完美的反转。 / p>
我也尝试了一些在线转换器工具,它们给了我相同的(-87.538 ...., - 50.724 ....)结果。
由于多个源产生相同的结果,并且我的转换是彼此正确的反转,我认为计算本身是正确的,但结果值仍然需要进一步转换/偏移?
我认为自己在代数方面已足够,但制图预测完全无法实现。
有人可以对此有所了解吗?
额外信息
请在下方找到我的转换功能:
public static Lambert72 LatLon_To_Lambert72(LatLon latlon)
{
var lat = latlon.Lat;
var lng = latlon.Lon;
double LongRef = 0.076042943;
//=4°21'24"983
double bLamb = 6378388 * (1 - (1 / 297));
double aCarre = Math.Pow(6378388, 2);
double eCarre = (aCarre - Math.Pow(bLamb, 2)) / aCarre;
double KLamb = 11565915.812935;
double nLamb = 0.7716421928;
double eLamb = Math.Sqrt(eCarre);
double eSur2 = eLamb / 2;
//conversion to radians
lat = (Math.PI / 180) * lat;
lng = (Math.PI / 180) * lng;
double eSinLatitude = eLamb * Math.Sin(lat);
double TanZDemi = (Math.Tan((Math.PI / 4) - (lat / 2))) * (Math.Pow(((1 + (eSinLatitude)) / (1 - (eSinLatitude))), (eSur2)));
double RLamb = KLamb * (Math.Pow((TanZDemi), nLamb));
double Teta = nLamb * (lng - LongRef);
double x = 0;
double y = 0;
x = 150000 + 0.01256 + RLamb * Math.Sin(Teta - 0.000142043);
y = 5400000 + 88.4378 - RLamb * Math.Cos(Teta - 0.000142043);
return new Lambert72(x, y);
}
public static LatLon Lambert72_To_LatLon(Lambert72 lb72)
{
double X = lb72.X;
double Y = lb72.Y;
double LongRef = 0.076042943;
//=4°21'24"983
double nLamb = 0.7716421928;
double aCarre = Math.Pow(6378388, 2);
double bLamb = 6378388 * (1 - (1 / 297));
double eCarre = (aCarre - Math.Pow(bLamb, 2)) / aCarre;
double KLamb = 11565915.812935;
double eLamb = Math.Sqrt(eCarre);
double eSur2 = eLamb / 2;
double Tan1 = (X - 150000.01256) / (5400088.4378 - Y);
double Lambda = LongRef + (1 / nLamb) * (0.000142043 + Math.Atan(Tan1));
double RLamb = Math.Sqrt(Math.Pow((X - 150000.01256), 2) + Math.Pow((5400088.4378 - Y), 2));
double TanZDemi = Math.Pow((RLamb / KLamb), (1 / nLamb));
double Lati1 = 2 * Math.Atan(TanZDemi);
double eSin = 0;
double Mult1 = 0;
double Mult2 = 0;
double Mult = 0;
double LatiN = 0;
double Diff = 0;
double lat = 0;
double lng = 0;
do {
eSin = eLamb * Math.Sin(Lati1);
Mult1 = 1 - eSin;
Mult2 = 1 + eSin;
Mult = Math.Pow((Mult1 / Mult2), (eLamb / 2));
LatiN = (Math.PI / 2) - (2 * (Math.Atan(TanZDemi * Mult)));
Diff = LatiN - Lati1;
Lati1 = LatiN;
} while (Math.Abs(Diff) > 2.77777E-08);
lat = (LatiN * 180) / Math.PI;
lng = (Lambda * 180) / Math.PI;
return new LatLon(lat, lng);
}
答案 0 :(得分:2)
我是您在帖子中提到的页面的作者。 我不知道你是否已经解决了你的问题,但你给出的Lambert坐标是不正确的。我认为你必须将它们除以1000.这给出了x = 151488.250和y = 170492.909,它们是可能的坐标,对应于...布鲁塞尔的一条街道。 转换为纬度/经度值时,请注意选择原点。