打印
[MCU]

用法区别

[复制链接]
616|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
wuhany|  楼主 | 2020-12-10 19:25 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
沙发
zhaoxqi| | 2020-12-10 19:28 | 只看该作者

可以参考数据手册中的解释如下:
16位乘法寄存器: MPY
16位有符号乘法寄存器:MPYS
16位乘法累加寄存器:MAC
16位有符号乘法累加寄存器:MACS

使用特权

评论回复
板凳
wuhany|  楼主 | 2020-12-10 19:33 | 只看该作者
恩,我就是想问乘法和乘法累加 两者是怎么运作的,以及二者的区别,谢谢

使用特权

评论回复
地板
zhenykun| | 2020-12-10 19:41 | 只看该作者
·16位乘法器使用方法:
1.无符号数相乘 result="n1"*n2。第一操作数n1(16位无符号)赋给MPY寄存器,第二操作数n2(16位无符号)赋给OP2寄存器,赋值完成后,结果result(32位无符号)就可以在RESLO(低16位)和RESHI(高165位)中读取。
代码如下:
   MPY = n1;                            // Load first operand -unsigned mult
   OP2 = n2;                                // Load second operand
   result = RESHI;                           // Load RESHI word result
   result = (result<<16)|RESLO;              // Shift RESHI left and concat with
2.无符号数乘加操作 result="n1"*n2+n3*n4。第一操作数n1(16位无符号)赋给MPY寄存器,第二操作数n2(16位无符号)赋给OP2寄存器,第三操作数n3(16位无符号)赋给MAC寄存器,第四操作数n4(16位无符号)赋给OP2寄存器,结果result(32位无符号)就可以在RESLO(低16位)和RESHI(高165位)中读取。SUMEXT寄存器中保存进位标志。
代码如下:
   MPY = n1;                             // Load first operand -unsigned mult
   OP2 = n2;                             // Load second operand
   MAC = n3;    // Load 3rd operand -unsigned mult
   OP2 = n4;    // Load 4rd operand
   result = RESHI;                           // Load RESHI word result
   result = (result<<16)|RESLO;              // Shift RESHI left and concat with
3.有符号数相乘 result="n1"*n2。第一操作数n1(16位有符号)赋给MPYS寄存器,第二操作数n2(16位有符号)赋给OP2寄存器,赋值完成后,结果result(32位有符号)就可以在RESLO(低16位)、RESHI(高165位)和SUMEXT(符号)中读取。SUMEXT=0xffff则结果为负,SUMEXT=0则结果为正。
代码如下:
   MPYS = n1;                            // Load first operand -signed mult
   OP2 = n2;                                // Load second operand
   result = RESHI;                           // Load RESHI word result
   result = (result<<16)|RESLO;              // Shift RESHI left and concat with
4.有符号乘加操作 result="n1"*n2+n3*n4。第一操作数n1(16位无符号)赋给MPY寄存器,第二操作数n2(16位无符号)赋给OP2寄存器,第三操作数n3(16位有符号)赋给MAC寄存器,第四操作数n4(16位有符号)赋给OP2寄存器,结果result(32位有符号)就可以在RESLO(低16位)和RESHI(高165位)中读取。SUMEXT寄存器中保存进位和正负标志。
代码如下:
   MPY = n1;                             // Load first operand -unsigned mult
   OP2 = n2;                             // Load second operand
   MACS = n3;
   OP2 = n4;
   result = RESHI;                           // Load RESHI word result
   result = (result<<16)|RESLO;              // Shift RESHI left and concat with
·32位乘法器使用方法:
1.无符号相乘 result="n1"*n2。n1(32位无符号)低16位赋给MPY32L寄存器,n1高16位赋给MPY32H寄存器,n2(32位无符号)低16位赋给OP2L寄存器,n2高16位赋给OP2H寄存器,赋值完成后,结果result(64位无符号)就可以在RES0(低位), RES1, RES2 和 RES3(高位)中读取。
代码如下:
   MPY32L = 0x1234;                          // Load lower 16 bits of operand 1
   MPY32H = 0x1234;                          // Load upper 16 bits of operand 1
   OP2L = 0x5678;                            // Load lower 16 bits of operand 2
   OP2H = 0x5678;                            // Load upper 16 bits of operand 2
   result_L = RES1;
  result_L = (result_L<<16)|RES0;
  result_H = RES3;
  result_H = (result_H<<16)|RES2;
其他情况依次类推,与16位情况类似。

使用特权

评论回复
5
shimx| | 2020-12-10 19:45 | 只看该作者

其实简单说,MPY和MAC是两种不同的操作,
MPY是简单的做乘法,即c = a x b
MAC是做乘加,即 c = a x b + c

使用特权

评论回复
6
yszong| | 2020-12-10 19:48 | 只看该作者
楼上正解

使用特权

评论回复
7
yufe| | 2020-12-10 19:52 | 只看该作者
一个乘法还搞模块,又不是除法,为何不直接用指令支持

使用特权

评论回复
8
wuhany|  楼主 | 2020-12-10 19:55 | 只看该作者

嗯,预料中的结果,多谢大家啦

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

879

主题

10435

帖子

4

粉丝