- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机组成原理大作业二
----------使用定点运算模拟浮点运算程序
问题描述:
本题目用定点运算来模拟浮点运算(十进制)。
本程序采用C+编写,其编写、编译及运行环境均为Microsoft C++.NET。
二、设计思想:
程序结构:
(1)本程序将被操作的浮点数用一个类MyFloat来描述。
类的定义如下:
class MyFloat
{
public:
float s;//浮点数的尾数,规定为纯小数的形式,方便判断尾数的溢出
int j;//浮点数的阶码,范围在在-32768__+32767之间
int Add(MyFloat data2, MyFloat dataResult);//将本浮点对象与data2相加,结果存储到dataResult中
int Sub(MyFloat data2, MyFloat dataResult); //将本浮点对象与data2相减,结果存储到dataResult中
int Mul(MyFloat data2, MyFloat dataResult); //将本浮点对象与data2相乘,结果存储到dataResult中
int Div(MyFloat data2, MyFloat dataResult); //将本浮点对象与data2相除,结果存储到dataResult中
int CheckResult(MyLFloat dataResult); //将运算检查运算结果规格化,并判断是否溢出
//以上五个函数的返回值说明:返回0:运算合法,且没有溢出;
返回 1:运算结果上溢;
返回 -1:运算结果下溢;
返回 -3:非法运算,除数为零
//这些返回状态的判断都是在CheckResult()中实现,而CheckResult是在四个运算函数中调用的
};
(2)程序中使用了一个用来存放中间结果的结构体MyLFloat,该结构体的定义如下:
struct MyLFloat
{
float s; //浮点数的尾数
long j; //浮点数的阶码,为长整型,有较宽的范围,溢出的判断也是以它为依据
};
算法描述:
(1)加减运算法则:
1.对阶,按小阶向大阶对齐的原则。
2.尾数求和(差),将对阶后的两尾数按定点加减运算规则求和(差)。
3.判断表示尾数的定点小数部分是否溢出(|尾数| = 1),如溢出则通过移动小数点和改变阶码来消除
4.规格化,为提高运算精度,结果的尾数也要规格化。
5.判断结果是否溢出。
(2)乘除运算法则:
1.两个浮点数相乘,其乘积的阶码应为相乘两数的阶码之和,其乘积的尾数应为相乘两数的尾数之积。
2.两个浮点数相除,商的阶码为被除数的阶码减去除数的阶码,其尾数为被除数的尾数除以除数的尾数所得的商。(另外要考虑到除数可能为零的情况)
3.规格化
4.判断结果是否溢出。
程序流程图:
程序主流程:
说明:输入数据:由函数InputData(MyFloat data,Char * name)实现,data接受输入,name为“加数”“被加数”等等。
输出结果:由函数DisplayResult(MyFloat dataResult ,int iResult)实现,iResult为溢出情况
加减法流程图:
乘除法流程图:
溢出判断:先规格化----〉再判断溢出(上溢,阶码大于32767或下溢,阶码小于-32768)--〉返回溢出状态标志
关于使用:
程序执行开始界面如下:
使用步骤如下:
选择要执行的运算种类
根据格式的要求输入数据:分别输入尾数和阶码(基数为10)
显示结果:结果以 0.*** E **** 的形式显示,E前面是尾数,E后面是阶码
按任意键可返回主菜单
文档评论(0)