[发明专利]一种嵌入式系统的浮点除法运算方法、系统和嵌入式系统在审
申请号: | 201410745916.X | 申请日: | 2014-12-09 |
公开(公告)号: | CN104375800A | 公开(公告)日: | 2015-02-25 |
发明(设计)人: | 程瑛颖;肖冀;侯兴哲;周孔均;杨华潇;杜杰 | 申请(专利权)人: | 国网重庆市电力公司电力科学研究院;国家电网公司 |
主分类号: | G06F7/487 | 分类号: | G06F7/487;G06F9/302 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 张忠魁;王宝筠 |
地址: | 401123 重*** | 国省代码: | 重庆;85 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 嵌入式 系统 浮点 除法 运算 方法 | ||
技术领域
本申请涉及计算机技术领域,更具体地说,涉及一种嵌入式系统的浮点除法运算方法、系统和嵌入式系统。
背景技术
在嵌入式系统中,浮点运算由于精度高、数值表示范围宽等特点,在各种数值运算过程中被广泛采用。浮点数即带小数点的数,在科学计算中常表示为十进制的科学计数形式:N=M×10E,其中N表示浮点数值,M为尾数(分为整数部分和小数部分),E为指数。二进制浮点数表示形式类似于上述十进制浮点数表示方法,可表示为N=M×2E。浮点四则运算中,加法运算、减法运算和乘法运算比较简单,处理速度较快,而除法一般采用迭代算法,需要较多步骤,从而造成嵌入式系统的运算资源的浪费。
发明内容
有鉴于此,本申请提供一种嵌入式系统的浮点除法运算方法、系统和嵌入式系统,以解决现有浮点除法运算方法因步骤较多而浪费嵌入式系统的运算资源的问题。
为了实现上述目的,现提出的方案如下:
一种嵌入式系统的浮点除法运算方法,用于对单精度浮点数进行除法运算,包括如下步骤:
获取被除数和除数;
提取所述除数中的小数位,将其作为除数小数位;
利用所述除数小数位获取所述除数的倒数,将其作为除数倒数;
将所述被除数的小数位和所述除数小数位相乘,取其结果的高23位作为商的小数位;
将所述被除数的指数位、所述除数的指数位和所述除数倒数的指数位相加,取其三者之和作为所述商的指数位。
根据所述被除数的符号位和所述除数的符号位确定所述商的符号位。
优选的,所述利用所述除数小数位获取所述除数的倒数,将其作为除数倒数,包括:
将0~223-1存入所述嵌入式系统的内存中,作为一个倒数表格;
将所述除数小数位作为地址从所述倒数表格中获取与所述地址相对应的数据,将所述数据作为所述除数倒数。
优选的,所述内存的容量大于32MB。
优选的,所述根据所述被除数的符号位和所述除数的符号位确定所述商的符号位,包括:
判断所述被除数的符号位与所述除数的符号位是否相同;
如果相同则确定所述商的符号位为正,反之则确定所述商的符号位为负。
一种嵌入式系统的浮点除法运算系统,用于对单精度浮点数进行除法运算,包括:
获取模块,用于获取被除数和除数
提取模块,用于提取所述除数中的小数位,将其作为除数小数位;
倒数计算模块,用于利用所述除数小数位获取所述除数的倒数,将其作为除数倒数;
小数位计算模块,用于将所述被除数的小数位和所述除数小数位相乘,取其结果的高23位作为商的小数位;
指数位计算模块,用于将所述被除数的指数位、所述除数的指数位和所述除数倒数的指数位相加,将三者之和作为所述商的指数位。
符号位计算模块,用于根据所述被除数的符号位和所述除数的符号位确定所述商的符号位。
优选的,所述倒数计算模块包括:
数据存储单元,用于存储倒数表格,所述倒数表格包括0~223-1;
查表单元,用于将所述除数小数位作为地址从所述倒数表格中获取与所述地址相对应的数据,将所述数据作为所述除数倒数。
优选的,所述数据存储单元的容量大于32MB。
优选的,所述符号位计算模块包括:
判断单元,用于判断所述被除数的符号位与所述除数的符号位是否相同;
符号确定单元,用于如果判断结果相同则确定所述商的符号位为正,反之则确定所述商的符号位为负。
一种嵌入式系统,包括如上所述的浮点除法运算系统。
优选的,所述嵌入式系统包括数字信号处理器。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于国网重庆市电力公司电力科学研究院;国家电网公司,未经国网重庆市电力公司电力科学研究院;国家电网公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201410745916.X/2.html,转载请声明来源钻瓜专利网。
- 上一篇:采用多核处理器仿真可重构处理器并行计算过程的方法
- 下一篇:一种电磁调节阀