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

dw做网站简单首页wordpress js加载位置

dw做网站简单首页,wordpress js加载位置,网站自然优化是什么意思,学校的网站的代码模板下载原理 double 由以下部分组成: 符号位指数部分尾数部分 符号位的含义:为 0 表示正数,为 1 表示负数。指数部分的含义:在规格化数中,指数部分的整型值减去 1023 就是实际的指数值。在非规格化数中,指数恒为…

原理

double 由以下部分组成:

  1. 符号位
  2. 指数部分
  3. 尾数部分
  • 符号位的含义:为 0 表示正数,为 1 表示负数。
  • 指数部分的含义:在规格化数中,指数部分的整型值减去 1023 就是实际的指数值。在非规格化数中,指数恒为 -1022 这个常数。
  • 尾数部分:尾数部分的整型值就是它的值,不像指数部分那样需要分别处理。

规格化数的值:
value = ( − 1 ) sign × 2 exponent − 1023 × ( 1 + mantissa 2 52 ) \text{value} = (-1)^{\text{sign}} \times 2^{\text{exponent} - 1023} \times \left(1 + \frac{\text{mantissa}}{2^{52}}\right) value=(1)sign×2exponent1023×(1+252mantissa)

非规格化数的值:
value = ( − 1 ) sign × 2 − 1022 × ( mantissa 2 52 ) \text{value} = (-1)^{\text{sign}} \times 2^{-1022} \times \left(\frac{\text{mantissa}}{2^{52}}\right) value=(1)sign×21022×(252mantissa)

浮点特殊值

NaN

  • 指数部分所有位都为 1.
  • 尾数部分不为 0.

正无穷、负无穷

  • 指数部分所有位都为 1.
  • 尾数部分所有位都为 0.

则根据符号位来确定是正无穷还是负无穷。符号位为 0 则是正无穷,符号位为 1 则是负无穷。

DoubleBitView

设计一个类,用来解析 double 的位结构

#pragma once
#include "base/bit/bit.h"
#include "base/math/FloatNumberValueType.h"
#include <cstdint>namespace base
{namespace bit{class DoubleBitView{private:union Union{double _double;uint64_t _uint64;};Union _value_union{};public:constexpr DoubleBitView() = default;constexpr DoubleBitView(double value){_value_union._double = value;}constexpr double Value() const{return _value_union._double;}constexpr uint64_t AsUint64() const{return _value_union._uint64;}////// @brief 尾数部分的位。////// @return///constexpr uint64_t MantissaBits() const{return base::bit::ReadBits(_value_union._uint64, 0, 52);}////// @brief 指数部分的位。////// @return///constexpr uint64_t ExponentBits() const{return base::bit::ReadBits(_value_union._uint64, 52, 63);}////// @brief 符号位。////// @return///constexpr bool SignBit() const{return base::bit::ReadBit(_value_union._uint64, 63);}////// @brief 浮点值的类型。////// @return///constexpr base::bit::FloatNumberValueType ValueType() const{if (ExponentBits() == base::bit::ReadBits(UINT64_MAX, 52, 63)){// 指数位全为 1if (MantissaBits() != 0){// 尾数位不全为 0,return base::bit::FloatNumberValueType::NaN;}// 尾数位全为 0if (!SignBit()){// 正无穷return base::bit::FloatNumberValueType::PositiveInfinite;}// 负无穷return base::bit::FloatNumberValueType::NegativeInfinite;}// 指数位不全为 1if (ExponentBits() == 0){// 指数位全为 0return base::bit::FloatNumberValueType::Denormalized;}return base::bit::FloatNumberValueType::Normalized;}////// @brief 是正数。////// @return///constexpr bool Positive() const{// 符号位位 0 则是正数return !SignBit();}////// @brief 是负数。////// @return///constexpr bool Negative() const{// 符号位位 1 则是负数return SignBit();}};} // namespace bit
} // namespace base

分数类

有了 double 的位结构之后,分数类就可以基于它进行构造了

base::Fraction::Fraction(base::Double const &value)
{if (value.Value() == 0.0){SetNum(0);SetDen(1);return;}base::bit::DoubleBitView view{value.Value()};switch (view.ValueType()){case base::bit::FloatNumberValueType::Normalized:{base::Fraction f1 = base::pow(base::BigInteger{2},base::BigInteger{view.ExponentBits() - 1023});base::Fraction f2 = base::Fraction{view.MantissaBits(),base::pow(base::BigInteger{2}, base::BigInteger{52}),};base::Fraction value = f1 * (1 + f2);if (view.Positive()){*this = value;}else{*this = -value;}break;}case base::bit::FloatNumberValueType::Denormalized:{base::Fraction f1 = base::pow(base::BigInteger{2},base::BigInteger{-1022});base::Fraction f2 = base::Fraction{view.MantissaBits(),base::pow(base::BigInteger{2}, base::BigInteger{52}),};base::Fraction value = f1 * f2;if (view.Positive()){*this = value;}else{*this = -value;}break;}case base::bit::FloatNumberValueType::NaN:{throw std::invalid_argument{CODE_POS_STR + "此浮点数是 NaN."};}case base::bit::FloatNumberValueType::PositiveInfinite:{throw std::invalid_argument{CODE_POS_STR + "此浮点数是正无穷。"};}case base::bit::FloatNumberValueType::NegativeInfinite:{throw std::invalid_argument{CODE_POS_STR + "此浮点数是负无穷。"};}default:{throw std::runtime_error{CODE_POS_STR + "非法的枚举值。"};}}
}

无损地将标准库中的 π \pi π 常数转换为分数

#include "base/math/Fraction.h"
#include "base/wrapper/number-wrapper.h"
#include <cmath>
#include <cstdlib>
#include <iomanip>
#include <iostream>
#include <numbers>
#include <stdlib.h>int main()
{{base::Fraction f{base::Double{std::numbers::pi}};constexpr int precision = 512;std::cout << "分数: " << f << std::endl;std::cout << "std::numbers::pi: \t\t"<< std::setprecision(precision)<< std::numbers::pi<< std::endl;std::cout << "分数表示的 pi 转为 double: \t"<< std::setprecision(precision)<< static_cast<double>(f)<< std::endl;std::cout << "误差: "<< std::setprecision(precision)<< static_cast<double>(f) - std::numbers::pi<< std::endl;}
}

运行结果

分数: 884279719003555 / 281474976710656
std::numbers::pi:               3.141592653589793115997963468544185161590576171875
分数表示的 pi 转为 double:      3.141592653589793115997963468544185161590576171875
误差: 0

在这里插入图片描述

π \pi π 用分数近似表示就是 884279719003555 / 281474976710656

http://www.dtcms.com/a/547772.html

相关文章:

  • 怎么创建网站详细流程seo公司中国
  • 学做网站需要什么软件o2o商城系统
  • 巫山网站建设3小时网站建设平台
  • 代做毕设要注册答疑网站萍乡企业网站制作
  • php做网站标题加链接传动设备 技术支持 东莞网站建设
  • 网站设计目的苏州手机网站建设公司
  • 传奇辅助网站怎么建设dede 汽车网站
  • 工商注册在哪个网站公司网络搭建
  • 英国男女做那个视频网站百度权重9的网站
  • 宇宙企画网站wordpress很强大
  • 用php做购物网站h5怎么制作的
  • 陶瓷刀具网站策划书网站正在维护模板
  • 深圳市住房和建设局网站和市住宅租赁管理服务中心商城网站建设技术论坛
  • 如何制作境外网站新网 如何建设网站
  • 小游戏网站怎么做搜索引擎优化的流程
  • 比较知名的企业微信小程序排名关键词优化
  • 个人网站制作基本步骤网站备案 互联网信息查询
  • 运输网站建设网站上有声的文章是怎么做的
  • 天河区网站建设公司wordpress手机评论框
  • 仿制网站个人做电影网站
  • 网站策划书的编写三河市城乡建设局网站
  • 送菜网站制作项目总结报告怎么写
  • 中山市做网站百业网
  • 手机网站好还是h5好谢岗网站仿做
  • 2018年公司做网站注意事项延庆免费网站建设
  • 贵阳德天信网站建设网页设计与制作教程第二版教材
  • 阿里巴巴网站的pc端和手机端怎么做的德保县建设局的网站
  • 图片免费设计在线生成长沙网站整站优化
  • 河北 石家庄 网站建设wordpress喜欢按钮
  • html5网站案例自己做的网站怎么弄成app