MMIX derlemesi (28 Bayt)
64 bit sayılar
rbit:
SETH $1,#0102 # load matrix in 16-byte steps
ORMH $1,#0408
ORML $1,#1020
ORL $1,#4080
MOR $0,$1,$0 # multiplication 1
MOR $0,$0,$1 # multiplication 2
POP 1,0 # return
Bu toplanır:
rbit:
E0010102 # SETH $1,#0102
E9010408 # ORMH $1,#0408
EA011020 # ORML $1,#1020
EB014080 # ORL $1,#4080
DC000100 # MOR $0,$1,$0
DC000001 # MOR $0,$0,$1
F8010000 # POP 1,0
O nasıl çalışır?
MOR
Talimat Boolean iki 8x8 matris olarak kullanılabilir iki 64-bit miktarlarda bir matris çarpımını yapar. Abcdefghklmnopqr 2 basamaklı bir boolean sayısı şöyle bir matris olarak kullanılır:
/ abcd \
| efgh |
| klmn |
\ opqr /
MOR
Talimat çarpar matrisler çarpma olduğunu onların argümanları ile temsil and
ve ektir or
. Bu:
/ 0001 \ / abcd \ / opqr \
| 0010 | \/ | efgh | -- | klmn |
| 0100 | /\ | klmn | -- | efgh |
\ 1000 / \ opqr / \ abcd /
ve ayrıca:
/ opqr \ / 0001 \ / rqpo \
| klmn | \/ | 0010 | -- | nmlk |
| efgh | /\ | 0100 | -- | hgfe |
\ abcd / \ 1000 / \ dcba /
Bu, orijinal sayının bitlerinin ters sırasıdır.
32 bit sayılar
64 bitlik sayı yerine 32 bitlik bir sayının tersini istiyorsanız, bu değiştirilmiş yöntemi kullanabilirsiniz:
rbit:
SETL $1,#0408 # load first matrix in two steps
ORML $1,#0102
MOR $1,$1,$0 # apply first matrix
SLU $2,$1,32 # compile second matrix
16ADDU $1,$2,$1
MOR $1,$0,$1 # apply second matrix
POP 1,0 # return
birleştirilmiş:
rbit:
E3010408 # SETL $1,#0408
EA010102 # ORML $1,#0102
DC010001 # MOR $1,$1,$0
3B020120 # SLU $2,$1,32
2E010201 # 16ADDU $1,$2,$1
DC010001 # MOR $1,$0,$1
F8010000 # POP 1,0
İlk matris çarpımı temelde şöyle çalışır:
/ 0000 \ / 0000 \ / 0000 \
| 0000 | \/ | 0000 | -- | 0000 |
| 0001 | /\ | abcd | -- | efgh |
\ 0010 / \ efgh / \ abcd /
karşılık gelen oktabayt, #0000000001020408
ilk iki talimatta yüklediğimizdir. İkinci çarpım şöyle görünür:
/ 0000 \ / 0001 \ / 0000 \
| 0000 | \/ | 0010 | -- | 0000 |
| efgh | /\ | 0100 | -- | hgfe |
\ abcd / \ 1000 / \ dcba /
Karşılık gelen oktabayt, #0102040810204080
aşağıdaki gibi birinci matristen yarattığımız şeydir :
SLU $2,$1,#32 # $2 = #0102040800000000
16ADDU $1,$2,$1 # $2 = $2 + $1 << 4
= $2 + #0000000010204080
# = #0102040810204080
İkinci çarpım her zamanki gibi işdir, sonuçta ortaya çıkan kod aynı uzunluktadır (28 bayt).