cythonを使用して次のコードを高速化したい:
class A(object):
cdef fun(self):
return 3
class B(object):
cdef fun(self):
return 2
def test():
cdef int x, y, i, s = 0
a = [ [A(), B()], [B(), A()]]
for i in xrange(1000):
for x in xrange(2):
for y in xrange(2):
s += a[x][y].fun()
return s
頭に浮かぶのは次のようなものだけです。
def test():
cdef int x, y, i, s = 0
types = [ [0, 1], [1, 0]]
data = [[...], [...]]
for i in xrange(1000):
for x in xrange(2):
for y in xrange(2):
if types[x,y] == 0:
s+= A(data[x,y]).fun()
else:
s+= B(data[x,y]).fun()
return s
基本的に、C ++での解決策は、仮想メソッドを使用していくつかの基本クラスへのポインターの配列をfun()
作成することです。そうすれば、かなりすばやく反復処理できます。Python / Cythonを使用してそれを行う方法はありますか?
ところで:Pythonリストの代わりにdtype = object_でnumpyの2D配列を使用する方が速いでしょうか?