アセンブリ言語での行列の操作について助けを求めています。私のコードはCとASMでコレスキー分解を行い、それらの速度を比較します。私はすでにネストされたループを作成し、それは正常に機能しています。はい、その要素にアクセスするためにマトリックスを適切にアドレス指定する方法がわかりません。MatrixはCではDOUBLEであり、アドレス(最初の要素)をアセンブリに変換することができました。
Cholesky_double proc \
tab_addr:DWORD, \ ; begin adres of matrix
num_elem:DWORD ; element count in row/column (n of Matrix[n][n])
LOCAL i:DWORD, k:DWORD, j:DWORD, skoczek:DWORD
;skoczek is for operation count check (ex.should be 13 for 3x3 matrix)
; push register on stack
push edx
push ecx
push ebx
push esi
push edi
mov k, 0
mov skoczek, 0
for0start:
inc skoczek
mov eax, k
mov i, eax
inc i
;there should be MATRIX[k][k] = sqrt(MATRIX[k][k])
mov eax, num_elem
sub eax, i
cmp eax, 0
je for1end
for1start:
inc skoczek
;MATRIX[i][k]=MATRIX[i][k]/MATRIX[k][k]
for1koniec:
inc i
mov eax, num_elem
sub eax, i
cmp eax, 0
jne for1start
for1END:
mov eax, k
mov j, eax
inc j
mov eax, num_elem
sub eax, j
cmp eax, 0
je for2end
for2start:
inc skoczek
mov eax, j
mov i, eax
for3start:
inc skoczek
;MATRIX[i][j] = MATRIX[i][j]-MATRIX[i][k]*MATRIX[j][k]
for3koniec:
inc i
mov eax, num_elem
sub eax, i
cmp eax, 0
jne for3start
for2koniec:
inc j
mov eax, num_elem
sub eax, j
cmp eax, 0
jne for2start
for2end:
for0koniec:
inc k
mov eax, num_elem
sub eax, k
cmp eax, 0
jne for0start
koniec:
pop edi
pop esi
pop ebx
pop ecx
pop edx
mov eax, skoczek
ret
; return with operation count in eax
Cholesky_double endp
Cで渡された行列
extern "C" int __stdcall Cholesky_double(double* tab_adr, int num_el);
Visual Studio 2010と、ASSEMBLYライブラリを作成するプロジェクトと、アセンブラー関数を使用できるC++のコードを使用するプロジェクトを使用します。
私は自分のためにコードを入力することを求めていません。マトリックスの要素に適切にアクセスするための正しいアドレス指定の助けを少しだけ求めています。ここでさらに問題が発生することが予想される場合(asmのSqrtのように、いくつかのガイダンスに満足します。