Cython を学習して、計算の一部を高速化しようとしています。これは、私がやろうとしていることのサブセットです。これは、NumPy 配列を利用しながら、再帰式を使用して微分方程式を単純に統合することです。私はすでに、純粋な python バージョンよりも約 100 倍の速度向上を達成しています。-a
ただし、 cython コマンドによってコード用に生成された HTML ファイルを見ると、速度が向上するようです。私のコードは次のとおりです(HTMLファイルで黄色になり、白にしたい行にラベルが付けられています):
%%cython
import numpy as np
cimport numpy as np
cimport cython
from libc.math cimport exp,sqrt
@cython.boundscheck(False)
cdef double riccati_int(double j, double w, double h, double an, double d):
cdef:
double W
double an1
W = sqrt(w**2 + d**2)
#dark_yellow
an1 = ((d - (W + w) * an) * exp(-2 * W * h / j ) - d - (W - w) * an) /
((d * an - W + w) * exp(-2 * W * h / j) - d * an - W - w)
return an1
def acalc(double j, double w):
cdef:
int xpos, i, n
np.ndarray[np.int_t, ndim=1] xvals
np.ndarray[np.double_t, ndim=1] h, a
xpos = 74
xvals = np.array([0, 8, 23, 123, 218], dtype=np.int) #dark_yellow
h = np.array([1, .1, .01, .1], dtype=np.double) #dark_yellow
a = np.empty(219, dtype=np.double) #dark_yellow
a[0] = 1 / (w + sqrt(w**2 + 1)) #light_yellow
for i in range(h.size): #dark_yellow
for n in range(xvals[i], xvals[i + 1]): #light_yellow
if n < xpos:
a[n+1] = riccati_int(j, w, h[i], a[n], 1.) #light_yellow
else:
a[n+1] = riccati_int(j, w, h[i], a[n], 0.) #light_yellow
return a
上記でラベル付けした 9 行すべてを適切な調整で白くできるように思えます。1 つの問題は、NumPy 配列を適切な方法で定義する機能です。しかし、おそらくもっと重要なのは、ラベル付けされた最初の行を効率的に機能させる能力です。これは、計算の大部分が行われる場所だからです。黄色い線をクリックした後に HTML ファイルが表示する、生成された C コードを読んでみましたが、正直、そのコードの読み方がわかりません。誰かが私を助けてくれれば、それは大歓迎です。