如何解决缓冲后质心点坐标精度不够的问题?
How to solve the lack of precision of the coordinates of the centroid points after a buffer?
buffer生成多边形(此处为正方形)时,生成的几何点坐标与.centroid
方法在多边形after他们这一代。
这里举个例子,只有一点。
from shapely.ops import transform
import geopandas as gpd
import shapely.wkt
import pyproj
from math import sqrt
def edge_size(area): return sqrt(area)*1e3
point = "POINT (4379065.583907348 2872272.254645019)"
point = shapely.wkt.loads(point)
center = gpd.GeoSeries(point)
project = pyproj.Transformer.from_proj(
pyproj.Proj('epsg:3395'),
pyproj.Proj('epsg:4326'),
always_xy=True)
center = center.apply(lambda p: transform(project.transform, p))
print(center.iloc[0])
square = point.buffer(
edge_size(3), cap_style=3) #distance of 3km2
square = gpd.GeoSeries(square)
square = square.apply(lambda p: transform(project.transform, p))
square = square.apply(lambda p: p.centroid)
print(square.iloc[0])
#POINT (39.33781544185747 25.11929860805248)
#POINT (39.33781544185747 25.11929777802279)
这会导致之后的处理错误。
首先,这正常吗?以及如何解决这个问题?
我也报告了我的问题here。感谢您的关注。
从 GitHub 复制我的答案以供后代使用。
这不是bug,而是对坐标变换的误解。你必须记住,一个投影中的正方形在另一个投影中不是正方形。
如果坚持使用相同的 CRS,则缓冲区质心的输出等于初始点。但是重新投影的多边形的质心略微偏离,特别是因为您进行的重新投影使几何体在一个方向上倾斜。
How to overcome this problem?
在一个 CRS 中完成所有操作,并在完成后重新投影。
buffer生成多边形(此处为正方形)时,生成的几何点坐标与.centroid
方法在多边形after他们这一代。
这里举个例子,只有一点。
from shapely.ops import transform
import geopandas as gpd
import shapely.wkt
import pyproj
from math import sqrt
def edge_size(area): return sqrt(area)*1e3
point = "POINT (4379065.583907348 2872272.254645019)"
point = shapely.wkt.loads(point)
center = gpd.GeoSeries(point)
project = pyproj.Transformer.from_proj(
pyproj.Proj('epsg:3395'),
pyproj.Proj('epsg:4326'),
always_xy=True)
center = center.apply(lambda p: transform(project.transform, p))
print(center.iloc[0])
square = point.buffer(
edge_size(3), cap_style=3) #distance of 3km2
square = gpd.GeoSeries(square)
square = square.apply(lambda p: transform(project.transform, p))
square = square.apply(lambda p: p.centroid)
print(square.iloc[0])
#POINT (39.33781544185747 25.11929860805248)
#POINT (39.33781544185747 25.11929777802279)
这会导致之后的处理错误。
首先,这正常吗?以及如何解决这个问题?
我也报告了我的问题here。感谢您的关注。
从 GitHub 复制我的答案以供后代使用。
这不是bug,而是对坐标变换的误解。你必须记住,一个投影中的正方形在另一个投影中不是正方形。
如果坚持使用相同的 CRS,则缓冲区质心的输出等于初始点。但是重新投影的多边形的质心略微偏离,特别是因为您进行的重新投影使几何体在一个方向上倾斜。
How to overcome this problem?
在一个 CRS 中完成所有操作,并在完成后重新投影。