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

长沙门户网站开发迅睿cms和帝国哪个好

长沙门户网站开发,迅睿cms和帝国哪个好,数据库 网站开发所需流程,网页设计基础图片IEEE754介绍 IEEE 754是一种标准,用于表示和执行浮点数运算的方法。在这个标准中,单精度浮点数使用32位二进制表示,分为三个部分:符号位、指数位和尾数位。 符号位(s)用一个位来表示数的正负,0表示正数,1表…

IEEE754介绍


IEEE 754是一种标准,用于表示和执行浮点数运算的方法。在这个标准中,单精度浮点数使用32位二进制表示,分为三个部分:符号位、指数位和尾数位。

符号位(s)用一个位来表示数的正负,0表示正数,1表示负数。

指数位(e)用8位表示指数。对于单精度浮点数,指数位是以偏移量的形式表示的。也就是说,实际的指数值是指数位的无符号值减去一个偏移量(127)。

尾数位(m)用23位表示数的尾数部分。尾数是一个二进制小数,被规范化为一个小于1的数。

表达式:

V = ( − 1 ) s × ( 1. M ) × 2 ( E − 127 ) V = (-1)^s \times(1.M)\times 2^{(E-127)} V=(1)s×(1.M)×2(E127) (单精度)

V = ( − 1 ) s × ( 1. M ) × 2 ( E − 1023 ) V = (-1)^s \times(1.M)\times 2^{(E-1023)} V=(1)s×(1.M)×2(E1023)(双精度)

在这里插入图片描述

IEEE 754 半精度浮点数16 位符号 1 位,指数 5 位,尾数 10 位
IEEE 754 单精度浮点数32 位符号 1 位,指数 8 位,尾数 23 位
IEEE 754 双精度浮点数64 位 符号 1 位,指数 11 位,尾数 52 位

代码实现计算

 我们首先定义了一个函数binaryIEEE754StringToFloat,它接收一个32位的二进制字符串作为输入,并返回一个浮点数。该函数首先确定输入字符串的长度,并在必要时进行填充,使其达到32位。

 接下来,我们解析符号位、指数位和尾数位。符号位确定数的正负,指数位确定数的范围,尾数位确定数的精度。通过这些步骤,我们能够将二进制字符串转换为浮点数。

 最后,我们在main函数中提供了一个示例二进制字符串,并调用binaryIEEE754StringToFloat函数进行转换。输出结果是一个浮点数,它就是我们所求的结果。

package main
import ("fmt""math""strconv""strings"
)
func binaryIEEE754StringToFloat(binaryStr string) float32 {n := 32 - len(binaryStr)// 补充为32位if n >= 0 && n < 32 {binaryStr = strings.Repeat("0", n) + binaryStr} else {fmt.Println("二进制字符串的长度不合法")return 0}// 解析符号位sign := 1.0if binaryStr[0] == '1' {sign = -1.0}// 解析指数位
(exponent, _ := strconv.ParseInt(binaryStr[1:9], 2, 64))
(exponent -= 127)// 解析尾数位
(mantissa := float32(0))for i := 9; i < len(binaryStr); i++ {if binaryStr[i] == '1' {(mantissa += 1 / float32(math.Pow(2, float64(i-8))))}}// 计算浮点数值
(result := float32(sign) * (1 + mantissa) * float32(math.Pow(2, float64(exponent))))return result
}
func main() {
(binaryStr := "10111111100111101110101110000000") // 示例二进制字符串
(floatVal := binaryIEEE754StringToFloat(binaryStr))fmt.Printf("转换后的浮点数为: %f\n", floatVal)
}

补充(Double类型转换):

func BinaryDoubleStringToFloat(binaryStr string) float64 {// 补充为64位n := 64 - len(binaryStr)if n >= 0 && n < 64 {binaryStr = strings.Repeat("0", n) + binaryStr} else {fmt.Println("二进制字符串的长度不合法")return 0}// 解析符号位sign := 1.0if binaryStr[0] == '1' {sign = -1.0}// 解析指数位exponent, _ := strconv.ParseInt(binaryStr[1:12], 2, 64)exponent -= 1023 // 双精度指数位的偏移量// 解析尾数位mantissa := float64(0)for i := 12; i < len(binaryStr); i++ {if binaryStr[i] == '1' {mantissa += 1 / float64(math.Pow(2, float64(i-11)))}}// 计算浮点数值result := sign * (1 + mantissa) * math.Pow(2, float64(exponent))return result
}
http://www.yayakq.cn/news/10553/

相关文章:

  • 软件园做网站长沙网站推广公司排名
  • 个人微企业网站模板深圳营销型网站建设服务哪家好
  • 泉州微信网站开发公司wordpress增加注册
  • 企业网站找私人做什wordpress nonce
  • 物流网站给做软件下载万能浏览器手机版下载安装
  • 做外卖的网站专业品牌网站建设价格
  • 哪些网站是python做的如何学习网站建设app
  • 绿色大气漂亮dedecms茶叶企业网站设计制作合同模板
  • 门户网站的流程旅游网站首页模板
  • 技术支持 济源网站建设仓储网站建设
  • 福建福清市住房和建设局网站百度网盟推广是什么
  • 整体网站构架网站建设到底属于什么行业
  • 博客建站系统网站建设 中企动力泉州
  • 想学网站建设 如何开始中国建设教育协会报名网站
  • 武昌做网站电子商务网站的设计与实现
  • 怎么看网站有没有被收录海宏集团网站建设方案
  • 制作注册会员的网站如何增加网站访问量
  • 中国农村建设网站wordpress在线qq插件
  • wordpress 友情链接小工具 seo won
  • 国内优秀设计网站推荐wordpress 前端编辑器
  • 做英文行程的网站济南专业网站设计
  • 初级网站开发的自我推荐网站优化工作
  • 体育视频网站建设山东恒昆建设工程有限公司网站
  • 如何建手机网站营销网站模板下载
  • 北京模板网站建站小程序代理运营
  • 淄博便宜网站设上海松江建设发展有限公司网站
  • 做海报兼职网站东莞网站优化效果如何
  • 使用模板怎么建站株洲做网站优化
  • 课程网站建设技术品牌策划公司业务范围
  • 个人资料展示网站恒锐奇 做网站