猿问

像素化位置和通量的算法

如果你在一个平面上有 n 个粒子(位置为 (x_n,y_n)),具有一定的通量 flux_n,你会怎么做,你必须对这些粒子进行像素化,所以你必须从 (x,y) 到 (pixel_i) , pixel_j) 空间,你必须总结落入每个像素的 m 个粒子的通量?有什么建议么?谢谢!



MM们
浏览 84回答 1
1回答

慕尼黑5688855

有几种方法可以解决您的问题。假设:你的位置已经被存储成两个numpy array形状(N,),即位置x_n(或y_n)为n在[0, N),让我们称它们为x和y。通量存储在numpy array具有相同形状的 a 中fluxes。1 - 密集案例 创建看起来像网格的东西:#get minimums and maximums positionmins = int(x.min()), int(y.min())maxs = int(x.max()), int(y.max())#actually you can also add and subtract 1 or more unit&nbsp;#in order to have a grid larger than the x, y extremes#something like mins-=epsilon and maxs += epsilon#create the gridxx = np.arange(mins[0], maxs[0])yy = np.arange(mins[1], maxs[1])现在你可以执行一个 double for loop, tacking ,每次,两个连续的元素xx和yy,要做到这一点,你可以简单地采取:x1 = xx[:-1] #excluding the last elementx2 = xx[1:]&nbsp; #excluding the first element#the same for y:y1 = yy[:-1] #excluding the last elementy2 = yy[1:]&nbsp; #excluding the first elementfluxes_grid = np.zeros((xx.shape[0], yy.shape[0]))for i, (x1_i, x2_i) in enumerate(zip(x1, x2)):&nbsp; &nbsp; for j, (y1_j, y2_j) in enumerate(zip(y1, y2)):&nbsp; &nbsp; &nbsp; &nbsp; idx = np.where((x>=x1_i) & (x<x2_i) & (y>=y1_j) & (y<y2_j))[0]&nbsp; &nbsp; &nbsp; &nbsp; fluxes_grid[i,j] = np.sum(fluxes[idx])在此循环结束时,您有一个网格,其元素是代表通量总和的像素。2 - 使用像 K-NN 这样的量化算法如果你有很多 o 点,会发生什么,以至于循环需要几个小时?更快的解决方案是使用量化方法,例如 K 最近邻,刚性网格上的 KNN。有很多方法可以运行 KNN(包括已经实现的版本,例如sklearn KNN)。但如果您可以利用 GPU,则效率会有所不同。例如,这是我的 tensorflow (vs 2.1) 实现。定义方形网格后:_min, maxs = min(mins), max(maxs)xx = np.arange(_min, _max)yy = np.arange(_min, _max)您可以构建矩阵grid和位置矩阵X:grid = np.column_stack([xx, yy]) X = np.column_stack([x, y])那么你必须定义一个矩阵欧几里德成对距离函数:@tf.functiondef pairwise_dist(A, B):&nbsp;&nbsp;&nbsp; &nbsp; # squared norms of each row in A and B&nbsp; &nbsp; na = tf.reduce_sum(tf.square(A), 1)&nbsp; &nbsp; nb = tf.reduce_sum(tf.square(B), 1)&nbsp; &nbsp; # na as a row and nb as a co"lumn vectors&nbsp; &nbsp; na = tf.reshape(na, [-1, 1])&nbsp; &nbsp; nb = tf.reshape(nb, [1, -1])&nbsp; &nbsp; # return pairwise euclidead difference matrix&nbsp; &nbsp; D = tf.sqrt(tf.maximum(na - 2*tf.matmul(A, B, False, True) + nb, 0.0))&nbsp; &nbsp; return D因此:#compute the pairwise distances:D = pairwise_dist(grid, X)D = D.numpy() #get a numpy matrix from a tf tensor#D has shape M, N, where M is the number of points in the grid and N the number of positions.#now take a rank and from this the best K (e.g. 10)ranks = np.argsort(D, axis=1)[:, :10]#for each point in the grid you have the nearest ten.现在您必须获取对应于这 10 个位置的通量并对它们求和。我避免进一步指定第二种方法,我不知道你的目录的维度,如果你有或没有 GPU,或者你是否想使用这种优化。如果你愿意,我可以改进这个解释,前提是你有兴趣。
随时随地看视频慕课网APP

相关分类

Python
我要回答