浮点加法器

计算机科学与技术名词

浮点数的基本运算包括加法、减法、乘法和除法。浮点加法算法主要有基本算法、Two-Path算法和Triple-data-path算法。在一般的处理器中,浮点加法、减法、转换和传送最终都是可以转换为采用浮点加法器实现,所以浮点加法器的使用频率高达55%,是使用频率最高的浮点运算模块。

基本概念
在一般的处理器中,浮点加法、减法、转换和传送最终都是可以转换为采用浮点加法器实现,所以浮点加法器的使用频率高达55%,是使用频率最高的浮点运算模块。浮点加法的两个特点,一是它复杂,二是它被使用的频率在所有操作里面是最高的,所以它是现代微处理器数字信号处理器中非常关键的部分。因此,浮点加法器的设计对FPU的整体性能十分重要。
浮点数的基本运算包括加法、减法、乘法和除法。浮点加法算法主要有基本算法、Two-Path算法和Triple-data-path算法。
基本算法
标准数据格式
IEEE标准格式的二进制浮点加法器完成两个二进制数相加时,要求输入的两个二进制数与输出的和数均为56位,其指数(e)为8位,尾数(f)为47位,符号位(s)为1。lEEE格式的标准数如下:
它与普通二进制浮点数的差别是增加了2位:第47位设为尾数为‘1’的隐含位;第56位是指数为‘0’的符号扩展位。
浮点加法器的框图
设加法运算的两个数为:
加法运算表达式为:
浮点数的加(或减)运算可分3步做:
第1步:比较数据大小,以便对数据小的尾数进行移位,从而在尾数运算前完成对阶的工作。
第2步:对尾数进行加(减)法运算。
第3步:对运算结果格式化,还原为IEEE浮点格式。浮点加法器框图如图3所示:
算法设计和结构映射
当浮点数的格式化完成后,第1步就是用比较指数的大小,完成对阶的工作。这也是整个加法器设计的核心部分。其主要作用是把运算结果作为尾数运算的条件,控制尾数运算始终由大数加(或减)小数,同时结果的符号以大数的符号作为参照。具体作法是并行地比较指数的大小,得出的值,只在x=0(阶对齐)的情况下做尾数比较大小的运算,并根据x的值对小指数的尾数右移对阶,最后对运算结果的指数按输出数据的格式做相应修正,以满足数据格式要求。
步骤
对于浮点加法操作来说,一般要求以下一系列的基本操作步骤:
(1)阶码相减:完成两十操作数阶码相减,形成阶差。
(2)对齐:小的操作散的有效位右移d位。
(3)有效位相加:根据摊作码和操作散的符号完成加法或减法。
(4)转换:当有救位的结果为负数时,转换为符号一尾数的表示方式。因为尾数采用原码表示,所以转换需要求补操作,即包括一个加法步骤。
(5)前导1的判定:判定由于减法结果产生的左移位数,对于加法判定是否右移一位或不移。对前导1判定的结果进行编码以驱动规格化移位。
(6)规格化:规格化有效位并且根据移位的方向和位数修改大的阶码。
(7)舍入:根据IEEE标准判定对最终结果的舍入,如果需要入,则在最末有效位加1。假如舍入引起溢出,则需要有效位右移1位,同时阶码加1。
由于需要很多的部件,这个算法的延时很大。
浮点加法的Two-Path算法
浮点加法器的设计经过多年的发展,在算法的改进上取得了大量的成果,其中最重要的就是Two-Path算法。基于这种算法的加法器已经在一些商用机上设计实现。随后,人们在此基础上逐步完善,使算法的性能进一步提高,并得到了更加广泛的应用。结构图如图4:
Frmwald针对浮点加法的基本算法进行了一系列的改进,提出了Two-Path算法。此算法的目的就是使各十操作步骤尽可能地并行化,以减少算法总的延时。这些改进一般都需要附加的硬件。改进是基于浮点加/减计算的某些特性。
(1)阶码差的符号决定两个操作数哪一个大。交换操作数,使其总是大的藏小的,在所有情况下,除了阶码相等的情况外,第4步转换将被取消。在阶码相等的情况下,第3步的结果可能是负的,仅在这种情况下需要转换。因为不需要初始的对阶移位,减后的结果是一个精确值,因此也就不需要舍入。所以遥过操作数的交换,使第4步的加法和第7步的加法互斥。这样可以消减三个全长加法延时中的一个。
(2)在有效的加法中.规格化移位操作是不需要的。因此,只有一个全长的对阶移位。对于减法,需要区分两种情况。第一,阶差d>1,可能需要一个生长的对阶移位。然而,它却不需要超过1位的规格化左移。同样,如果d1则不需要全长的对阶移位,但是需要一个垒长的规格化移位。在这种情况下,一位的对阶和条件交换能够通过阶码的低两位预测,减少这一路径的延时,因此,垒长的对阶移位和全长的规格化移位是互斥的,并且,在关键路径上只出现一个。这两种情况可以表示为:当d1为CLOSE路径;当d>1为FAR路径。在每一个路径的组成中.只有一个全长的移位。
(3)更进一步采用前导1的预测判定.在有效位加法完成之后,可能直接从操作数中预测结果前导0的数量。采用特殊的硬件前导1的预测可以与有效位加法并行处理。利用过三种情况,可以提高加法器的性能。按照数据分成两个路径实现有效位的运算:CLOSE路径和FAR路径。在这一优化中,为了增加加法器的性能的代价是一个附加的有效位加法器和一个多路进通器来选择两条路径产生的最终结果。如果采用流水技术一个浮点加法器可分成四级流水,完成一个浮点加法运算需要4个周期。
Triple-data-path算法
进一步的分析表明,当两个操作数的指数差的绝对值比尾数的有效宽度还要大时,浮点加法的结果即为两个操作数中较大的一个,加法运算不需要执行,因此根据Two-Path算法的原理,我们引入Triple-data-path算法。在此算法中,浮点加法过程分为三个通道,其中两个数据通道为计算通道,另外一个为旁路数据通道。当指数差的绝对值大于尾数的位宽时,旁路通道为当前通道,否则计算通道为当前通道。Triple.data-path算法的结构图如图5所示:
左数据通道尾数的移位只需单级的多路选择器即可完成,由于有效数的预对准操作速度很快,所以加法完成后再进行先导0计数,而不采用先导零预测逻辑,这样也能达到右数据通道相同的执行速度。由于先导零计数器远比先导零预测逻辑简单,所以简化了硬件复杂度,降低了功耗。右数据通道有效数的预对准需要移多位,这一操作用桶形移位器来实现。由于减法是用补码来实现的,所以补码器只有在减法运算中才被激活。无论是左数据通道还是右数据通道,舍入的计算与尾数的加法运算并行执行,提高了加法的执行速度。结果选择器根据舍入条件选择合适的加法结果。时序控制逻辑用于为不同的输入选择合适的通道,并将它们传送到所选的数据通道,同时产生不同的选通信号用于控制数据通道的状态。标志位逻辑用于标记异常情况,并进行相应的异常处理。
Triple-data-path浮点加法器结构在降低功耗方面有突出的优势,但其流水线设计较复杂,硬件规模大,实现起来难度较大。
全国各地天气预报查询

上海市

  • 市辖区
  • 云南省

  • 临沧市
  • 云南省

  • 丽江市
  • 云南省

  • 保山市
  • 云南省

  • 大理白族自治州
  • 云南省

  • 德宏傣族景颇族自治州
  • 云南省

  • 怒江傈僳族自治州
  • 云南省

  • 文山壮族苗族自治州
  • 云南省

  • 昆明市
  • 云南省

  • 昭通市
  • 云南省

  • 普洱市
  • 云南省

  • 曲靖市
  • 云南省

  • 楚雄彝族自治州
  • 云南省

  • 玉溪市
  • 云南省

  • 红河哈尼族彝族自治州
  • 云南省

  • 西双版纳傣族自治州
  • 云南省

  • 迪庆藏族自治州
  • 内蒙古自治区

  • 乌兰察布市
  • 内蒙古自治区

  • 乌海市
  • 内蒙古自治区

  • 兴安盟
  • 内蒙古自治区

  • 包头市
  • 内蒙古自治区

  • 呼伦贝尔市
  • 内蒙古自治区

  • 呼和浩特市
  • 内蒙古自治区

  • 巴彦淖尔市
  • 内蒙古自治区

  • 赤峰市
  • 内蒙古自治区

  • 通辽市
  • 内蒙古自治区

  • 鄂尔多斯市
  • 内蒙古自治区

  • 锡林郭勒盟
  • 内蒙古自治区

  • 阿拉善盟
  • 北京市

  • 市辖区
  • 吉林省

  • 吉林市
  • 吉林省

  • 四平市
  • 吉林省

  • 延边朝鲜族自治州
  • 吉林省

  • 松原市
  • 吉林省

  • 白城市
  • 吉林省

  • 白山市
  • 吉林省

  • 辽源市
  • 吉林省

  • 通化市
  • 吉林省

  • 长春市
  • 四川省

  • 乐山市
  • 四川省

  • 内江市
  • 四川省

  • 凉山彝族自治州
  • 四川省

  • 南充市
  • 四川省

  • 宜宾市
  • 四川省

  • 巴中市
  • 四川省

  • 广元市
  • 四川省

  • 广安市
  • 四川省

  • 德阳市
  • 四川省

  • 成都市
  • 四川省

  • 攀枝花市
  • 四川省

  • 泸州市
  • 四川省

  • 甘孜藏族自治州
  • 四川省

  • 眉山市
  • 四川省

  • 绵阳市
  • 四川省

  • 自贡市
  • 四川省

  • 资阳市
  • 四川省

  • 达州市
  • 四川省

  • 遂宁市
  • 四川省

  • 阿坝藏族羌族自治州
  • 四川省

  • 雅安市
  • 天津市

  • 市辖区
  • 宁夏回族自治区

  • 中卫市
  • 宁夏回族自治区

  • 吴忠市
  • 宁夏回族自治区

  • 固原市
  • 宁夏回族自治区

  • 石嘴山市
  • 宁夏回族自治区

  • 银川市
  • 安徽省

  • 亳州市
  • 安徽省

  • 六安市
  • 安徽省

  • 合肥市
  • 安徽省

  • 安庆市
  • 安徽省

  • 宣城市
  • 安徽省

  • 宿州市
  • 安徽省

  • 池州市
  • 安徽省

  • 淮北市
  • 安徽省

  • 淮南市
  • 安徽省

  • 滁州市
  • 安徽省

  • 芜湖市
  • 安徽省

  • 蚌埠市
  • 安徽省

  • 铜陵市
  • 安徽省

  • 阜阳市
  • 安徽省

  • 马鞍山市
  • 安徽省

  • 黄山市
  • 山东省

  • 东营市
  • 山东省

  • 临沂市
  • 山东省

  • 威海市
  • 山东省

  • 德州市
  • 山东省

  • 日照市
  • 山东省

  • 枣庄市
  • 山东省

  • 泰安市
  • 山东省

  • 济南市
  • 山东省

  • 济宁市
  • 山东省

  • 淄博市
  • 山东省

  • 滨州市
  • 山东省

  • 潍坊市
  • 山东省

  • 烟台市
  • 山东省

  • 聊城市
  • 山东省

  • 菏泽市
  • 山东省

  • 青岛市
  • 山西省

  • 临汾市
  • 山西省

  • 吕梁市
  • 山西省

  • 大同市
  • 山西省

  • 太原市
  • 山西省

  • 忻州市
  • 山西省

  • 晋中市
  • 山西省

  • 晋城市
  • 山西省

  • 朔州市
  • 山西省

  • 运城市
  • 山西省

  • 长治市
  • 山西省

  • 阳泉市
  • 广东省

  • 东莞市
  • 广东省

  • 中山市
  • 广东省

  • 云浮市
  • 广东省

  • 佛山市
  • 广东省

  • 广州市
  • 广东省

  • 惠州市
  • 广东省

  • 揭阳市
  • 广东省

  • 梅州市
  • 广东省

  • 汕头市
  • 广东省

  • 汕尾市
  • 广东省

  • 江门市
  • 广东省

  • 河源市
  • 广东省

  • 深圳市
  • 广东省

  • 清远市
  • 广东省

  • 湛江市
  • 广东省

  • 潮州市
  • 广东省

  • 珠海市
  • 广东省

  • 肇庆市
  • 广东省

  • 茂名市
  • 广东省

  • 阳江市
  • 广东省

  • 韶关市
  • 广西壮族自治区

  • 北海市
  • 广西壮族自治区

  • 南宁市
  • 广西壮族自治区

  • 崇左市
  • 广西壮族自治区

  • 来宾市
  • 广西壮族自治区

  • 柳州市
  • 广西壮族自治区

  • 桂林市
  • 广西壮族自治区

  • 梧州市
  • 广西壮族自治区

  • 河池市
  • 广西壮族自治区

  • 玉林市
  • 广西壮族自治区

  • 百色市
  • 广西壮族自治区

  • 贵港市
  • 广西壮族自治区

  • 贺州市
  • 广西壮族自治区

  • 钦州市
  • 广西壮族自治区

  • 防城港市
  • 新疆维吾尔自治区

  • 乌鲁木齐市
  • 新疆维吾尔自治区

  • 伊犁哈萨克自治州
  • 新疆维吾尔自治区

  • 克孜勒苏柯尔克孜自治州
  • 新疆维吾尔自治区

  • 克拉玛依市
  • 新疆维吾尔自治区

  • 博尔塔拉蒙古自治州
  • 新疆维吾尔自治区

  • 吐鲁番市
  • 新疆维吾尔自治区

  • 和田地区
  • 新疆维吾尔自治区

  • 哈密市
  • 新疆维吾尔自治区

  • 喀什地区
  • 新疆维吾尔自治区

  • 塔城地区
  • 新疆维吾尔自治区

  • 巴音郭楞蒙古自治州
  • 新疆维吾尔自治区

  • 昌吉回族自治州
  • 新疆维吾尔自治区

  • 自治区直辖县级行政区划
  • 新疆维吾尔自治区

  • 阿克苏地区
  • 新疆维吾尔自治区

  • 阿勒泰地区
  • 江苏省

  • 南京市
  • 江苏省

  • 南通市
  • 江苏省

  • 宿迁市
  • 江苏省

  • 常州市
  • 江苏省

  • 徐州市
  • 江苏省

  • 扬州市
  • 江苏省

  • 无锡市
  • 江苏省

  • 泰州市
  • 江苏省

  • 淮安市
  • 江苏省

  • 盐城市
  • 江苏省

  • 苏州市
  • 江苏省

  • 连云港市
  • 江苏省

  • 镇江市
  • 江西省

  • 上饶市
  • 江西省

  • 九江市
  • 江西省

  • 南昌市
  • 江西省

  • 吉安市
  • 江西省

  • 宜春市
  • 江西省

  • 抚州市
  • 江西省

  • 新余市
  • 江西省

  • 景德镇市
  • 江西省

  • 萍乡市
  • 江西省

  • 赣州市
  • 江西省

  • 鹰潭市
  • 河北省

  • 保定市
  • 河北省

  • 唐山市
  • 河北省

  • 廊坊市
  • 河北省

  • 张家口市
  • 河北省

  • 承德市
  • 河北省

  • 沧州市
  • 河北省

  • 石家庄市
  • 河北省

  • 秦皇岛市
  • 河北省

  • 衡水市
  • 河北省

  • 邢台市
  • 河北省

  • 邯郸市
  • 河南省

  • 三门峡市
  • 河南省

  • 信阳市
  • 河南省

  • 南阳市
  • 河南省

  • 周口市
  • 河南省

  • 商丘市
  • 河南省

  • 安阳市
  • 河南省

  • 平顶山市
  • 河南省

  • 开封市
  • 河南省

  • 新乡市
  • 河南省

  • 洛阳市
  • 河南省

  • 漯河市
  • 河南省

  • 濮阳市
  • 河南省

  • 焦作市
  • 河南省

  • 省直辖县级行政区划
  • 河南省

  • 许昌市
  • 河南省

  • 郑州市
  • 河南省

  • 驻马店市
  • 河南省

  • 鹤壁市
  • 浙江省

  • 丽水市
  • 浙江省

  • 台州市
  • 浙江省

  • 嘉兴市
  • 浙江省

  • 宁波市
  • 浙江省

  • 杭州市
  • 浙江省

  • 温州市
  • 浙江省

  • 湖州市
  • 浙江省

  • 绍兴市
  • 浙江省

  • 舟山市
  • 浙江省

  • 衢州市
  • 浙江省

  • 金华市
  • 海南省

  • 三亚市
  • 海南省

  • 三沙市
  • 海南省

  • 儋州市
  • 海南省

  • 海口市
  • 海南省

  • 省直辖县级行政区划
  • 湖北省

  • 十堰市
  • 湖北省

  • 咸宁市
  • 湖北省

  • 孝感市
  • 湖北省

  • 宜昌市
  • 湖北省

  • 恩施土家族苗族自治州
  • 湖北省

  • 武汉市
  • 湖北省

  • 省直辖县级行政区划
  • 湖北省

  • 荆州市
  • 湖北省

  • 荆门市
  • 湖北省

  • 襄阳市
  • 湖北省

  • 鄂州市
  • 湖北省

  • 随州市
  • 湖北省

  • 黄冈市
  • 湖北省

  • 黄石市
  • 湖南省

  • 娄底市
  • 湖南省

  • 岳阳市
  • 湖南省

  • 常德市
  • 湖南省

  • 张家界市
  • 湖南省

  • 怀化市
  • 湖南省

  • 株洲市
  • 湖南省

  • 永州市
  • 湖南省

  • 湘潭市
  • 湖南省

  • 湘西土家族苗族自治州
  • 湖南省

  • 益阳市
  • 湖南省

  • 衡阳市
  • 湖南省

  • 邵阳市
  • 湖南省

  • 郴州市
  • 湖南省

  • 长沙市
  • 甘肃省

  • 临夏回族自治州
  • 甘肃省

  • 兰州市
  • 甘肃省

  • 嘉峪关市
  • 甘肃省

  • 天水市
  • 甘肃省

  • 定西市
  • 甘肃省

  • 平凉市
  • 甘肃省

  • 庆阳市
  • 甘肃省

  • 张掖市
  • 甘肃省

  • 武威市
  • 甘肃省

  • 甘南藏族自治州
  • 甘肃省

  • 白银市
  • 甘肃省

  • 酒泉市
  • 甘肃省

  • 金昌市
  • 甘肃省

  • 陇南市
  • 福建省

  • 三明市
  • 福建省

  • 南平市
  • 福建省

  • 厦门市
  • 福建省

  • 宁德市
  • 福建省

  • 泉州市
  • 福建省

  • 漳州市
  • 福建省

  • 福州市
  • 福建省

  • 莆田市
  • 福建省

  • 龙岩市
  • 西藏自治区

  • 山南市
  • 西藏自治区

  • 拉萨市
  • 西藏自治区

  • 日喀则市
  • 西藏自治区

  • 昌都市
  • 西藏自治区

  • 林芝市
  • 西藏自治区

  • 那曲市
  • 西藏自治区

  • 阿里地区
  • 贵州省

  • 六盘水市
  • 贵州省

  • 安顺市
  • 贵州省

  • 毕节市
  • 贵州省

  • 贵阳市
  • 贵州省

  • 遵义市
  • 贵州省

  • 铜仁市
  • 贵州省

  • 黔东南苗族侗族自治州
  • 贵州省

  • 黔南布依族苗族自治州
  • 贵州省

  • 黔西南布依族苗族自治州
  • 辽宁省

  • 丹东市
  • 辽宁省

  • 大连市
  • 辽宁省

  • 抚顺市
  • 辽宁省

  • 朝阳市
  • 辽宁省

  • 本溪市
  • 辽宁省

  • 沈阳市
  • 辽宁省

  • 盘锦市
  • 辽宁省

  • 营口市
  • 辽宁省

  • 葫芦岛市
  • 辽宁省

  • 辽阳市
  • 辽宁省

  • 铁岭市
  • 辽宁省

  • 锦州市
  • 辽宁省

  • 阜新市
  • 辽宁省

  • 鞍山市
  • 重庆市

  • 重庆市

  • 市辖区
  • 陕西省

  • 咸阳市
  • 陕西省

  • 商洛市
  • 陕西省

  • 安康市
  • 陕西省

  • 宝鸡市
  • 陕西省

  • 延安市
  • 陕西省

  • 榆林市
  • 陕西省

  • 汉中市
  • 陕西省

  • 渭南市
  • 陕西省

  • 西安市
  • 陕西省

  • 铜川市
  • 青海省

  • 果洛藏族自治州
  • 青海省

  • 海东市
  • 青海省

  • 海北藏族自治州
  • 青海省

  • 海南藏族自治州
  • 青海省

  • 海西蒙古族藏族自治州
  • 青海省

  • 玉树藏族自治州
  • 青海省

  • 西宁市
  • 青海省

  • 黄南藏族自治州
  • 黑龙江省

  • 七台河市
  • 黑龙江省

  • 伊春市
  • 黑龙江省

  • 佳木斯市
  • 黑龙江省

  • 双鸭山市
  • 黑龙江省

  • 哈尔滨市
  • 黑龙江省

  • 大兴安岭地区
  • 黑龙江省

  • 大庆市
  • 黑龙江省

  • 牡丹江市
  • 黑龙江省

  • 绥化市
  • 黑龙江省

  • 鸡西市
  • 黑龙江省

  • 鹤岗市
  • 黑龙江省

  • 黑河市
  • 黑龙江省

  • 齐齐哈尔市