¿hay una manera más eficiente de tomar un promedio de una matriz en contenedores preespecificados? por ejemplo, tengo una matriz de números y una matriz correspondiente a las posiciones inicial y final de la bandeja en esa matriz, y quiero simplemente tomar la media en esas ubicaciones. Tengo un código que lo hace a continuación, pero me pregunto cómo se puede reducir y mejorar. Gracias.agrupando datos en python con scipy/numpy
from scipy import *
from numpy import *
def get_bin_mean(a, b_start, b_end):
ind_upper = nonzero(a >= b_start)[0]
a_upper = a[ind_upper]
a_range = a_upper[nonzero(a_upper < b_end)[0]]
mean_val = mean(a_range)
return mean_val
data = rand(100)
bins = linspace(0, 1, 10)
binned_data = []
n = 0
for n in range(0, len(bins)-1):
b_start = bins[n]
b_end = bins[n+1]
binned_data.append(get_bin_mean(data, b_start, b_end))
print binned_data
No veo un diff - ¿qué es más rápido? – user248237dfsf
@user: no sé cuál es más rápido para sus datos y parámetros. Ambos métodos deberían ser más rápidos que los tuyos, y esperaría que el método 'histogram()' fuera más rápido para una gran cantidad de contenedores. Pero tendrás que perfilarte a ti mismo, no puedo hacer esto por ti. –