How to convert the output of meshgrid to the corresponding array of points?

前端 未结 3 2031
自闭症患者
自闭症患者 2021-01-30 18:19

I want to create a list of points that would correspond to a grid. So if I want to create a grid of the region from (0, 0) to (1, 1), it would contain

相关标签:
3条回答
  • 2021-01-30 18:47

    Yet another way to do it is:

    np.indices((2,2)).T.reshape(-1,2)
    

    Which can be generalized to higher dimensions, e.g.:

    In [60]: np.indices((2,2,2)).T.reshape(-1,3)
    Out[60]:
    array([[0, 0, 0],
           [1, 0, 0],
           [0, 1, 0],
           [1, 1, 0],
           [0, 0, 1],
           [1, 0, 1],
           [0, 1, 1],
           [1, 1, 1]])
    
    0 讨论(0)
  • 2021-01-30 18:55

    Are your gridpoints always integral? If so, you could use numpy.ndindex

    print list(np.ndindex(2,2))
    

    Higher dimensions:

    print list(np.ndindex(2,2,2))
    

    Unfortunately, this does not meet the requirements of the OP since the integral assumption (starting with 0) is not met. I'll leave this answer only in case someone else is looking for the same thing where those assumptions are true.


    Another way to do this relies on zip:

    g = np.meshgrid([0,1],[0,1])
    zip(*(x.flat for x in g))
    

    This portion scales nicely to arbitrary dimensions. Unfortunately, np.meshgrid doesn't scale well to multiple dimensions, so that part will need to be worked out, or (assuming it works), you could use this SO answer to create your own ndmeshgrid function.

    0 讨论(0)
  • 2021-01-30 19:00

    I just noticed that the documentation in numpy provides an even faster way to do this:

    X, Y = np.mgrid[xmin:xmax:100j, ymin:ymax:100j]
    positions = np.vstack([X.ravel(), Y.ravel()])
    

    This can easily be generalized to more dimensions using the linked meshgrid2 function and mapping 'ravel' to the resulting grid.

    g = meshgrid2(x, y, z)
    positions = np.vstack(map(np.ravel, g))
    

    The result is about 35 times faster than the zip method for a 3D array with 1000 ticks on each axis.

    Source: http://docs.scipy.org/doc/scipy/reference/generated/scipy.stats.gaussian_kde.html#scipy.stats.gaussian_kde

    To compare the two methods consider the following sections of code:

    Create the proverbial tick marks that will help to create the grid.

    In [23]: import numpy as np
    
    In [34]: from numpy import asarray
    
    In [35]: x = np.random.rand(100,1)
    
    In [36]: y = np.random.rand(100,1)
    
    In [37]: z = np.random.rand(100,1)
    

    Define the function that mgilson linked to for the meshgrid:

    In [38]: def meshgrid2(*arrs):
       ....:     arrs = tuple(reversed(arrs))
       ....:     lens = map(len, arrs)
       ....:     dim = len(arrs)
       ....:     sz = 1
       ....:     for s in lens:
       ....:        sz *= s
       ....:     ans = []
       ....:     for i, arr in enumerate(arrs):
       ....:         slc = [1]*dim
       ....:         slc[i] = lens[i]
       ....:         arr2 = asarray(arr).reshape(slc)
       ....:         for j, sz in enumerate(lens):
       ....:             if j != i:
       ....:                 arr2 = arr2.repeat(sz, axis=j)
       ....:         ans.append(arr2)
       ....:     return tuple(ans)
    

    Create the grid and time the two functions.

    In [39]: g = meshgrid2(x, y, z)
    
    In [40]: %timeit pos = np.vstack(map(np.ravel, g)).T
    100 loops, best of 3: 7.26 ms per loop
    
    In [41]: %timeit zip(*(x.flat for x in g))
    1 loops, best of 3: 264 ms per loop
    
    0 讨论(0)
提交回复
热议问题