当前位置: 首页 > news >正文

由浮点数的位级表示判断大小关系

由浮点数x和y的位级表示,判断它们的大小关系,当 𝑥≥𝑦 时,返回1,否则,返回0。

程序代码

long int float_ge(float x, float y);
unsigned long int f2u(float x);void main()
{static float x,y;static long int z;x=3.534;y=3.533;z=float_ge(x, y);while(1);
}
/* 由浮点数x和y的位级表示,判断x是否大于等于y */
long int float_ge(float x, float y)
{unsigned long int ux=f2u(x);unsigned long int uy=f2u(y);unsigned long int sx=ux>>31;unsigned long int sy=ux>>31;return ((sx==0)&&(sy==0)&&(ux>=uy))|| ((sx==1)&&(sy==1)&&(ux<=uy))||((sx==0)&&(sy==1));
}
/* 由浮点数得到其位级表示 */
unsigned long int f2u(float x)
{unsigned long int m,temp,s,e,k=0,l=1,p=1;int i=0,j=0,n=-1;float f;if(x<0)  //若x<0,则符号位为1{s=1;s<<=31;}else if(x>0)s=0;else{s=0;m=0;e=0;}if(x<0)x=-x;m=(unsigned long int)x;  //得到x的整数部分f=x-m;while(f!=0){k=k|(unsigned long int)(f*2); //小数部分的二进制表示存于kf=(f*2)-(unsigned long int)(f*2);i++;   if(f!=0&&i<=9)k<<=1;	if(i>9)  //小数部分的二进制表示不超过10位break;}temp=m;while(m!=0)  //得到整数部分二进制表示最左边1的位置{j++;if((m&0x1)==1){if((m>>=1)==0)break;}else if((m&0x1)==0)m>>=1;}m=temp;if(m!=0)  //得到阶码字段e和小数字段m{m<<=i;m=m|k;m=(m<<(24-(i+j))&((l<<23)-1));e=(j-1)+127;e<<=23;}else //若x是纯小数,得到其阶码字段e和小数字段m{j=i;while(1){if((k&(p<<(i-1)))==0){i--;n--;}elsebreak;}e=n+127;e<<=23;k<<=(23-(j+n));m=k&((l<<23)-1);	}return s+e+m;   //返回x的位级表示
}

运行结果

http://www.xdnf.cn/news/629371.html

相关文章:

  • 人工智能100问☞第31问:如何评估一个AI模型的性能?
  • 【MySQL】索引
  • 【动态规划】P12223 [蓝桥杯 2023 国 Java B] 非对称二叉树|普及+
  • python打卡day35@浙大疏锦行
  • 【笔记】OpenCV的学习(未完)
  • CodeBuddy 实现图片转素描手绘工具
  • springboot中各模块间实现bean之间互相调用(service以及自定义的bean)
  • 符合Python风格的对象(使用 __slots__ 类属性节省空间)
  • 搜索二叉树
  • 开盘啦 APP 抓包 逆向分析
  • 从有线到无线:PLC通讯“剪断“最后一根线!
  • MQTT-排它订阅
  • STM32F103 HAL多实例通用USART驱动 - 高效DMA+RingBuffer方案,量产级工程模板
  • python训练营第33天
  • Lesson 22 A glass envelope
  • HJ14 字符串排序【牛客网】
  • Spring AI 源码解析:Tool Calling链路调用流程及示例
  • 从法律视角看债务管理:湖北理元理律师事务所的实践探索
  • 【信息系统项目管理师】一文掌握高项常考题型-成本类计算
  • 巡礼中国西极·跨越昆仑天山 | 北斗卫星徽章护航昆仑科考
  • 神经算子项目实战:数据分析、可视化与实现全过程
  • 归一化 超全总结!!
  • leetcode hot100刷题日记——16.全排列
  • 探秘Transformer系列之(34)--- 量化基础
  • 开源轻量级语音合成和语音克隆模型:OuteTTS-1.0-0.6B
  • AWTK嵌入式图形框架开发备忘(二)
  • 【GESP真题解析】第 5 集 GESP 二级 2023 年 3 月编程题 2:百鸡问题
  • 【Python】【电网规划】基于经济与可靠性双目标的混合配电系统规划及可靠性评估
  • ShenNiusModularity项目源码学习(30:ShenNius.Admin.Mvc项目分析-15)
  • 可增添功能的鼠标右键优化工具