2.3 定点乘法运算

学习目标:

如果我要学习定点乘法运算,我会按照以下步骤进行学习:

  1. 确定学习目标:明确学习定点乘法运算的目的和重点,以便有针对性地进行学习。

  2. 掌握基础知识:首先需要了解定点数和定点乘法的基础知识,包括定点数的表示方法、定点数的加减乘除运算规则和定点数的溢出处理等。

  3. 熟悉乘法原理:学习定点乘法运算的原理和基本方法,了解定点数的乘法操作过程,理解乘法的本质和意义。

  4. 掌握乘法算法:学习不同的乘法算法,包括基本乘法算法、快速乘法算法和 Booth算法等,掌握它们的优缺点、实现方法和适用场景。

  5. 实践练习:进行定点乘法的实践练习,从简单的乘法操作开始,逐步增加难度,加深对定点乘法的理解和掌握。

  6. 深入学习:学习高级的定点乘法运算知识,包括带符号乘法、小数点定位和压缩乘法等,扩展定点乘法运算的应用范围和能力。

  7. 实际应用:将所学的定点乘法知识应用到具体的项目和实际应用中,例如数字信号处理、图像处理和音频处理等,提高实际解决问题的能力。

总之,学习定点乘法运算需要掌握基础知识、熟悉乘法原理、掌握乘法算法、进行实践练习、深入学习和实际应用,需要不断的思考和练习,才能掌握并运用得熟练。

 2.3 定点乘法运算的理解:

定点乘法是指在定点数的表示下进行的乘法运算,其中乘积的小数点位置是固定的,即不随运算过程改变,因此称之为定点乘法。定点乘法常用于数字信号处理、图像处理、嵌入式系统等领域,它可以有效地降低硬件复杂度和延长系统寿命。

在定点乘法中,两个定点数的乘积的小数点位置是固定的,一般情况下,小数点位于数值位的某个位置。例如,若小数点位于低位第k位,则称为k位定点数。两个k位定点数的乘积就是将它们的数值相乘后,将结果向右移动k位,即可得到k位定点数的结果。

在定点乘法的计算过程中,需要考虑两个关键问题:1) 溢出问题,即乘积超出了定点数所能表示的范围;2) 精度问题,即乘积的精度不足或过高,导致结果失真。

为了解决溢出和精度问题,常用的定点乘法算法包括基本乘法算法和 Booth算法等。其中,基本乘法算法是将乘数和被乘数的每一位相乘,再按位相加的方法进行计算;而 Booth算法则是一种快速乘法算法,它利用了二进制数的位权规律,可以减少计算的次数,提高计算效率。

除了基本乘法算法和 Booth算法,还有许多其他的定点乘法算法,如Karatsuba算法和快速傅里叶变换算法等,它们各有特点和适用范围。在实际应用中,需要根据具体场景选择最合适的算法。

总之,定点乘法是数字信号处理和图像处理等领域中广泛应用的一种重要技术,它涉及到数值表示、算法设计和精度控制等方面的知识,需要认真学习和掌握。

2.3.0 引入

 ***2.3.1 原码一位乘(很大概率要考)

实际设计: 

 

 

 硬件实现:

 

 

1.人工算法与机器算法的同异性理解: 

人工算法和机器算法是两种不同的算法,它们有着各自的特点和应用场景。

一方面,人工算法是由人类设计和实现的算法,它通常采用符号运算或数值运算的方式进行计算。人工算法可以充分考虑计算的精度和效率等问题,因此通常具有较高的可读性和可调试性,可以灵活地适应不同的应用需求。另外,人工算法还可以利用人类的经验和知识,对特定的问题进行优化,提高算法的性能和效果。

另一方面,机器算法是由计算机程序实现的算法,它通常采用计算机语言进行描述和实现。机器算法可以充分利用计算机的计算能力和存储能力,能够处理大规模数据和复杂问题,可以快速地完成计算任务。此外,机器算法还可以通过机器学习等方法,自动学习和优化算法,提高算法的精度和效率。

在同一问题领域中,人工算法和机器算法可能存在一定的同异性。例如,在图像处理领域中,人工算法可以根据图像的特征和应用场景,设计出特定的算法来完成图像处理任务,而机器算法可以通过深度学习等方法,自动学习图像的特征和规律,并完成相应的图像处理任务。在一些应用场景下,人工算法和机器算法可能会相互补充,从而提高整个算法系统的性能和效果。

总之,人工算法和机器算法都是算法设计和实现中的重要部分,它们各自有着不同的特点和应用场景,需要根据具体问题和需求选择最合适的算法。

 

2.3.3 

 

 

 2.不带符号的阵列乘法器

不带符号的阵列乘法器是一种在计算机硬件中广泛应用的乘法器,它可以高效地实现大规模的数字信号处理和图像处理等应用。

不带符号的阵列乘法器的基本结构是由一组乘法器、加法器和寄存器等硬件单元组成的。其中,乘法器用于计算两个输入数的乘积,加法器用于将多个乘积相加,寄存器用于暂存运算结果。不带符号的阵列乘法器可以支持任意长度的输入数,并且可以快速地完成乘法运算,从而满足了高效计算的需求。

具体来说,不带符号的阵列乘法器可以按照以下步骤完成乘法运算:

  1. 将输入数分别拆分成若干个位数,并将每个位数依次输入到乘法器中。

  2. 乘法器对每个位数进行乘法运算,并将结果输出到加法器中。

  3. 加法器对所有乘积进行累加,并将结果输出到寄存器中。

  4. 寄存器暂存运算结果,并输出最终的乘积。

需要注意的是,不带符号的阵列乘法器只适用于处理不带符号的数字信号,因此在处理带符号的数字信号时,需要进行额外的符号扩展和处理。

总之,不带符号的阵列乘法器是一种高效的数字信号处理硬件,它可以快速地完成大规模的乘法运算,从而满足了各种高效计算的需求。

 

 

 3.带符号的阵列乘法器

带符号的整列乘法器是一种在计算机硬件中广泛应用的乘法器,与不带符号的阵列乘法器相比,它可以同时处理带符号和无符号的数字信号。

 

带符号的整列乘法器的基本结构和不带符号的阵列乘法器类似,但需要增加一些额外的硬件单元来实现符号扩展和运算。其具体实现方法如下:

  1. 首先将输入的带符号数进行符号扩展,即将符号位复制到高位,保证输入数的长度相同。

  2. 对扩展后的两个带符号数进行无符号乘法运算,得到一个无符号的乘积。

  3. 将无符号乘积的位数减去扩展的位数得到有效位数,然后再根据输入数的符号位进行符号位的处理。

  4. 将得到的结果存储到寄存器中,输出最终的乘积。

需要注意的是,在进行符号扩展和符号处理时,需要考虑到带符号数的溢出问题,否则会导致计算结果错误。

总之,带符号的整列乘法器是一种可以同时处理带符号和无符号的数字信号的硬件乘法器,它可以高效地完成大规模的乘法运算,从而满足各种数字信号处理和图像处理等应用的需求。

2.3.4 带补位的乘法器

 

带补位的乘法器通常指的是使用补码表示的有符号数进行乘法运算的乘法器。补码乘法器可以处理正负数的乘法,并且可以正确处理溢出和符号位反演的情况。下面是带补位的乘法器的一般步骤:

1. 确定被乘数和乘数的符号位,即最高位。

2. 将被乘数和乘数的绝对值(去掉符号位)转换为补码表示。

3. 对于数值位,使用逻辑门(通常是逻辑与门)来实现乘法运算。将相应位的被乘数和乘数连接到逻辑与门的输入,输出为相应位的乘积。

4. 对于符号位,使用逻辑门(通常是逻辑异或门)来实现异或运算,得到符号位的乘积。

5. 对于乘积的数值位,进行进位和溢出的处理。进位可以通过加法器来实现,溢出的检测可以通过观察进位位和最高位的异或结果来进行判断。

6. 最后,根据乘积的符号位和数值位的结果,可以进行必要的调整或处理,以得到最终的带补位的乘积结果。

需要注意的是,带补位的乘法器的具体设计涉及更复杂的电路组合和算法。它需要考虑到溢出、符号位反演以及进位的处理等问题,以确保正确的乘法运算结果。在实际的电路设计中,通常会使用多级乘法器和加法器的组合,以实现更高位数的乘法运算,并且采用优化的算法和电路设计技术,以提高性能和效率。

2.3.5 对2求补电路

 这里隐含了求补码的另一种方法即按位扫描法。

对于二进制数求补,可以使用取反(NOT)电路来实现。以下是对2求补的电路实现步骤:

1. 确定输入端,即二进制数2。

2. 对于每一位,使用取反(NOT)门来将输入位取反。

3. 对于多位数,需要使用多个取反门,对每一位进行取反操作。

4. 得到的输出即为对2求补的结果。

需要注意的是,对于二进制数2,它的补码表示与其本身相等,因此对2求补的结果仍为2。所以,对于对2求补的电路实现,输出应该等于输入。

在实际的电路设计中,可以使用逻辑门电路(如NOT门)来实现取反操作。对于多位数,需要根据位数进行逐位取反。此外,为了确保电路的正确性和稳定性,还需要考虑输入的稳定性、时序和电路的延迟等因素。

需要注意的是,对于其他二进制数的求补,求补操作会将二进制数的每一位取反并加1。这是补码表示中的求补操作规则。

 电路图:

 

考过这里:(注意不要忘了复习这里)

 

 

 总结:

定点乘法是数字信号处理中的一项重要运算,其重点、难点和易错点如下:

重点:

  1. 定点乘法的基本原理和算法;
  2. 定点乘法的精度分析;
  3. 定点乘法的实现方法和优化策略;
  4. 定点乘法在数字信号处理中的应用。

难点:

  1. 定点数的表示和运算;
  2. 定点数的溢出和截断处理;
  3. 定点乘法的精度和误差分析;
  4. 定点乘法的高效实现和优化。

易错点:

  1. 定点数位宽和小数点位置的选取;
  2. 定点数的溢出和截断处理;
  3. 定点乘法的算法细节,如符号扩展、进位处理等;
  4. 定点乘法的优化策略的选取。

为了避免这些易错点,需要对定点乘法有深入的理解,并仔细设计和优化算法。同时,也需要进行严格的精度分析和测试,以保证算法的正确性和有效性。

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏驰和徐策

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值