У меня есть массивы, связанные как с A, так и с B, в которых хранятся (x, y) позиции точек сетки для каждого.
В этом случае ответ должен быть довольно простым...
Находятся ли две сетки строго по одной и той же схеме сетки?Предполагая, что это так, вы можете просто сделать что-то вроде:
np.argwhere((Ax == Bx.min()) & (Ay == By.min()))
Предполагая, что мировые координаты двух сеток увеличиваются в том же направлении, что и индикаторы сеток, это дает нижний левый угол заданной сетки,(И если они не увеличиваются в одном и том же направлении (т.е. отрицательно dx
или dy
), это просто дает один из других углов)
В приведенном ниже примере, очевидно, мы могли бы просто вычислитьправильные указания из ix = (Bxmin - Axmin) / dx
и т. д., но при условии, что у вас более сложная система построения сетки, это все равно будет работать.Однако это предполагает, что две сетки находятся на одной и той же схеме сетки !Это немного сложнее, если они не ...
import numpy as np
# Generate grids of coordinates from a min, max, and spacing
dx, dy = 0.5, 0.5
# For the larger grid...
Axmin, Axmax = -180, 180
Aymin, Aymax = -90, 90
# For the smaller grid...
Bxmin, Bxmax = -5, 10
Bymin, Bymax = 30, 40
# Generate the indicies on a 2D grid
Ax = np.arange(Axmin, Axmax+dx, dx)
Ay = np.arange(Aymin, Aymax+dy, dy)
Ax, Ay = np.meshgrid(Ax, Ay)
Bx = np.arange(Bxmin, Bxmax+dx, dx)
By = np.arange(Bymin, Bymax+dy, dy)
Bx, By = np.meshgrid(Bx, By)
# Find the corner of where the two grids overlap...
ix, iy = np.argwhere((Ax == Bxmin) & (Ay == Bymin))[0]
# Assert that the coordinates are identical.
assert np.all(Ax[ix:ix+Bx.shape[0], iy:iy+Bx.shape[1]] == Bx)
assert np.all(Ay[ix:ix+Bx.shape[0], iy:iy+Bx.shape[1]] == By)