计算机系统结构实验报告中南民族大学Word文档格式.docx
- 文档编号:15938437
- 上传时间:2022-11-17
- 格式:DOCX
- 页数:14
- 大小:58.46KB
计算机系统结构实验报告中南民族大学Word文档格式.docx
《计算机系统结构实验报告中南民族大学Word文档格式.docx》由会员分享,可在线阅读,更多相关《计算机系统结构实验报告中南民族大学Word文档格式.docx(14页珍藏版)》请在冰豆网上搜索。
验
结
果
与
分
析
一、实验结果:
1、先输入矩阵A和矩阵B的行数和列数:
2、再输入矩阵A的各元素数值:
3、再输入矩阵B的各元素数值:
4、输入A矩阵的数值并打印:
5、输入B矩阵的数值并打印:
5.输出矩阵A和矩阵B的积
二、显示流水线的部分时空图:
三、Pipeline窗口、
四、Code窗口
五、结果分析:
实验中通过对DLX软件的学习和使用,对于其汇编代码有一个整体上的认识。
熟悉了DLX仿真软件的功能,包括主要的功能界面。
DLX应用程序的编程和调试技术、DLX的流水线运行分析,包括流水线单步执行、每个流水段功能、理解流水线停顿、流水线建立和排空、定向技术。
通过编写矩阵相乘来检验掌握的程度,对与在其中出现的问题进行分析,和解决。
能通过单步执行来调试程序,找出错误点和逻辑错误点,并加以改正。
程
序
代
码
;
********multiplyanarraytoanarray*****
;
*******Writtenby*********
三个矩阵按行存储
l代表了第一个矩阵的当前被扫描的那行
r4<
=r相对于result的偏移量
r5<
-l
r10<
-i第一个矩阵某一行的某个元素的索引
r7<
-j第二个矩阵某一列的某个元素的索引
.data
dat1:
.space64
dat2:
result:
.space64
PromptRowA:
.asciiz"
InputmatrixArow:
rowA="
PromptColA:
InputmatrixAcol:
colA="
PromptRowB:
InputmatrixBrow:
rowB="
PromptColB:
InputmatrixBcol:
colB="
PromptError:
.asciiz"
MatrixA'
scolisnotequalmatrixB'
srow!
!
\n\n"
.align2
PrintfError:
.wordPromptError
PromptLB:
\n"
PrintfLB:
.wordPromptLB
PromptAOut:
\nTheMatrixAis:
PrintfAOut:
.wordPromptAOut
PromptBOut:
\nTheMatrixBis:
PrintfBOut:
.wordPromptBOut
PromptCOut:
\nTheMatrixA*Bis:
PrintfCOut:
.wordPromptCOut
PromptAIn:
\nPleaseinputmatrixAdata:
PrintfAIn:
.wordPromptAIn
PromptBIn:
\nPleaseinputmatrixBdata:
PrintfBIn:
.wordPromptBIn
PromptNumA:
a[%d][%d]="
PrintfValueA:
.wordPromptNumA
RowA:
.space4
ColA:
PromptNumB:
b[%d][%d]="
PrintfValueB:
.wordPromptNumB
RowB:
ColB:
Output:
%5.3d"
PrintfValue:
.wordOutput
value:
.text
.globalmain
main:
矩阵A、B行列输入
addir1,r0,PromptRowA
jalInputUnsigned
movi2fpf1,r1;
矩阵A的行数
addir1,r0,PromptColA
jalInputUnsigned
movi2fpf2,r1;
矩阵A的列数
RE_INPUT:
addir1,r0,PromptRowB
movi2fpf4,r1;
矩阵B的行数
neff4,f2
bfpfNEXT_INPUT
addir14,r0,PrintfError
trap5
jRE_INPUT
NEXT_INPUT:
addir1,r0,PromptColB
movi2fpf3,r1;
k矩阵B的列数
矩阵A数据输入
addir14,r0,PrintfAIn
addir4,r0,0
addir2,r0,dat1
I_FIRSTCOLA:
movi2fpf10,r4;
当前A的行号
ltff10,f1
bfpfI_NEXTMATRIX
addir5,r0,0
I_NEXTCOLA:
movi2fpf11,r5;
当前A的列号
ltff11,f2
bfpfI_NEXTROWA
swRowA,r4
swColA,r5
addir14,r0,PrintfValueA
sb0(r2),r1
addir2,r2,1
addir5,r5,1
jI_NEXTCOLA
I_NEXTROWA:
addir4,r4,1
jI_FIRSTCOLA
I_NEXTMATRIX:
矩阵B数据输入
addir14,r0,PrintfBIn
addir2,r0,dat2
I_FIRSTCOLB:
当前B的行号
ltff10,f2
bfpfI_MATRIX_OUTPUT
I_NEXTCOLB:
当前B的列号
ltff11,f3
bfpfI_NEXTROWB
swRowB,r4
swColB,r5
addir14,r0,PrintfValueB
jI_NEXTCOLB
I_NEXTROWB:
jI_FIRSTCOLB
I_MATRIX_OUTPUT:
矩阵A数据输出
addir14,r0,PrintfAOut
O_FIRSTCOLA:
bfpfO_NEXTMATRIX
O_NEXTCOLA:
bfpfO_NEXTROWA
lbur1,0(r2)
swvalue,r1
addir14,r0,PrintfValue
addir5,r5,1;
列号加1
jO_NEXTCOLA
O_NEXTROWA:
addir14,r0,PrintfLB
addir4,r4,1;
行号加1
jO_FIRSTCOLA
O_NEXTMATRIX:
矩阵B数据输出
addir14,r0,PrintfBOut
O_FIRSTCOLB:
bfpfO_MATRIXMUL
O_NEXTCOLB:
bfpfO_NEXTROWB
jO_NEXTCOLB
O_NEXTROWB:
jO_FIRSTCOLB
O_MATRIXMUL:
矩阵A、B相乘
addir11,r0,0;
temp,表示矩阵C的一个元素的累加器
addir4,r0,0;
r初始化矩阵C的偏移量
addir5,r0,0;
l矩阵A当前被扫描的行号
line:
movi2fpf4,r5;
判断是否扫描完
ltff4,f1;
f4>
f1跳转(矩阵A的行是否扫描完)
bfpffinish;
是,则跳转结束程序
addir6,r0,0;
col,r6表示当前B矩阵的列号
column:
movi2fpf4,r6
ltff4,f3;
col(f3)<
f4,矩阵B的列是否扫描完
bfpfleveladd;
是,则跳到矩阵a的下一行
movfp2ir1,f2
multur10,r5,r1;
i<
-l*nr10表示矩阵A当前行的第一个元素的索引
addir7,r6,0;
movcoltoj(矩阵B某一列的某个元素的索引)
addir11,r0,0;
temp=0,矩阵C当前的元素值的初始化
addir9,r5,1;
r9<
-l+1,r9代表矩阵A当前数组中的实
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机系统 结构 实验 报告 中南 民族大学
![提示](https://static.bdocx.com/images/bang_tan.gif)