my Numpy statements are slower than indexed formulations in some cases
data:image/s3,"s3://crabby-images/160df/160dfd49f4685071609eb8f96ef2f792a02facc1" alt=""
I have a number of thse routines in some EM code. I've tried to Numpyize them, but end up with code that runs even slower. Here is the old indexed routing: ----------------- for JJ in range(0,TotExtMetalEdgeNum): McVector+=Ccc[0:TotExtMetalEdgeNum,JJ] * VcVector[JJ] ---------------- Here is the Numpy version: --------------------- McVector= add.reduce(transpose(Ccc[...] * VcVector[...])) --------------------- I wonder if there is another faster way to do this? Thanks, Rob. -- The Numeric Python EM Project www.pythonemproject.com
data:image/s3,"s3://crabby-images/160df/160dfd49f4685071609eb8f96ef2f792a02facc1" alt=""
Rob wrote:
I did speed things up just a tiny bit by using: add.reduce(Ccc*VcVector,1) instead of add.reduce(transpose(Ccc*VcVector). But I'm still running way slower than an indexed array scheme. Rob.
The Numeric Python EM Project
www.pythonemproject.com
-- The Numeric Python EM Project www.pythonemproject.com
data:image/s3,"s3://crabby-images/160df/160dfd49f4685071609eb8f96ef2f792a02facc1" alt=""
Problem solved. I had one last for loop in there. Its odd that as I gradually got rid of the for loops, the speed went down, but when I got rid of the last on, bingo! That routine now runs at a 1/10 of its original time. Rob. Rob wrote:
-- The Numeric Python EM Project www.pythonemproject.com
data:image/s3,"s3://crabby-images/160df/160dfd49f4685071609eb8f96ef2f792a02facc1" alt=""
Rob wrote:
I did speed things up just a tiny bit by using: add.reduce(Ccc*VcVector,1) instead of add.reduce(transpose(Ccc*VcVector). But I'm still running way slower than an indexed array scheme. Rob.
The Numeric Python EM Project
www.pythonemproject.com
-- The Numeric Python EM Project www.pythonemproject.com
data:image/s3,"s3://crabby-images/160df/160dfd49f4685071609eb8f96ef2f792a02facc1" alt=""
Problem solved. I had one last for loop in there. Its odd that as I gradually got rid of the for loops, the speed went down, but when I got rid of the last on, bingo! That routine now runs at a 1/10 of its original time. Rob. Rob wrote:
-- The Numeric Python EM Project www.pythonemproject.com
participants (1)
-
Rob