Вы можете использовать необычное индексирование:
[~/repo/py]
|32>dd[dd[:,1] == 1]
[32]
array([[ 0.469, 1. , 0.479],
[ 0.48 , 1. , 0.508],
[ 0.324, 1. , 0.324]])
[~/repo/py]
|33>dd[dd[:,1] == 2]
[33]
array([[ 0.567, 2. , 0.611],
[ 0.22 , 2. , 0.269]])
В качестве альтернативы вы можете использовать понимание списка:
[~/repo/py]
|21>np.array([row for row in dd if row[1] == 1])
[21]
array([[ 0.469, 1. , 0.479],
[ 0.48 , 1. , 0.508],
[ 0.324, 1. , 0.324]])
[~/repo/py]
|22>np.array([row for row in dd if row[1] == 2])
[22]
array([[ 0.567, 2. , 0.611],
[ 0.22 , 2. , 0.269]])
edit:
как рассчитать эти вещи в ipython:
[~/repo/py]
|36>timeit dd[dd[:,1] == 1]
100000 loops, best of 3: 6 us per loop
[~/repo/py]
|37>timeit np.array([row for row in dd if row[1] == 1])
100000 loops, best of 3: 11.5 us per loop