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

【unitrix】 5.1 第二套类型级二进制数基本结构体(types2.rs)

一、源码

这段代码定义了一个类型级(type-level)的二进制数表示系统,使用Rust的泛型结构体来实现。

//! 类型级二进制数表示方案(第二套方案)
//!
//! 使用嵌套泛型结构体表示二进制数,支持整数和实数表示。
//!
//! # 表示规则
//!
//! - 整数部分使用嵌套的`B`结构体表示,例如:
//!   - `B<Null, O>` 表示 0
//!   - `B<Null, I>` 表示 -1
//!   - `B<B<Null, O>, I>` 表示 1
//!   - `B<B<Null, O>, O>` 表示 0 (高位0可以省略,实际为`B<Null, O>`)
//!
//! - 十进制科学计数法使用`D`结构体表示:
//!   - `D<I, E10>` 表示 I × 10^E10
//!   - 例如 `D<B<Null, I>, B<Null, I>>` 表示 -1 × 10^-1 = -0.1use crate::sealed::Sealed;/// 类型级二进制数结构体
///
/// # 泛型参数
/// - `H`: 高位部分
///   - `B<H, L>` 表示嵌套的高位
///   - `Null` 表示无更高位
/// - `L`: 低位部分
///   - `I` 表示1
///   - `O` 表示0
#[derive(Eq, PartialEq, Clone, Copy, Debug)]
pub struct B<H, L>(pub H, pub L);/// 十进制科学计数法表示
///
/// # 泛型参数
/// - `I`: 二进制整数部分
/// - `E10`: 10的幂次(使用二进制表示)
///
/// # 示例
/// ```
/// // -2 × 10^1 = -20.0
/// D<B<I, O>, B<O, I>>;
///
/// // 3 × 10^-2 = 0.03
/// D<B<B<B<Null, O>, I>, I>, B<B<Null, I>, O>>;
/// ```
#[derive(Eq, PartialEq, Clone, Copy, Debug)]
pub struct D<I, E10>(pub I, pub E10);/// 类型级比特位0(逻辑假)
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct O;/// 类型级比特位1(逻辑真)
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct I;/// 空类型标记,表示无更高位或无小数部分
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct Null;// 常用类型别名
pub type Zero = B<Null, O>;
pub type One = B<Null, I>;
pub type NegOne = B<Null, I>;// 实现Default trait
impl<H: Default, L: Default> Default for B<H, L> {fn default() -> Self {B(Default::default(), Default::default())}
}impl<I: Default, E10: Default> Default for D<I, E10> {fn default() -> Self {D(Default::default(), Default::default())}
}// 构造函数实现
impl<H, L> B<H, L> {/// 创建新的二进制数实例#[inline]pub const fn new(h: H, l: L) -> Self {B(h, l)}
}impl<I, E10> D<I, E10> {/// 创建新的十进制数实例#[inline]pub const fn new(int: I, exp: E10) -> Self {D(int, exp)}
}impl Null {/// 创建新的Null实例#[inline(always)]pub const fn new() -> Self {Null}
}impl O {/// 创建新的O实例#[inline(always)]pub const fn new() -> Self {O}
}impl I {/// 创建新的I实例#[inline(always)]pub const fn new() -> Self {I}
}// 密封标记实现
impl<H, L> Sealed for B<H, L> {}
impl<I, E10> Sealed for D<I, E10> {}
impl Sealed for Null {}
impl Sealed for O {}
impl Sealed for I {}

二、源码分析

  1. 核心设计理念
  • 使用嵌套的泛型结构体表示二进制数

  • 支持两种表示形式:

    • 纯二进制整数(B结构体)

    • 十进制科学计数法(D结构体)

  1. 主要结构体
B<H, L> - 二进制数表示
  • H: 高位部分,可以是另一个B结构体或Null(表示没有更高位)

  • L: 最低位,可以是O(0)或I(1)

  • 示例:

    • B<Null, O>: 0

    • B<Null, I>: -1

    • B<B<Null, O>, I>: 1 (01,高位0是符号位,不能省略)

    • B<B<Null, I>, O>: -2 (10)

D<I, E10> - 十进制科学计数法
  • I: 整数部分,用B结构体表示

  • E10: 10的幂次,也用B结构体表示

  • 示例:

    • D<B<Null, I>, B<Null, I>>: -1 × 10⁻¹ = -0.1

    • D<B<I, O>, B<O, I>>: -2 × 10¹ = -20.0

  1. 基本类型
  • O: 表示二进制位0

  • I: 表示二进制位1

  • Null: 表示空/无更高位

  1. 类型别名

pub type Zero = B<Null, O>;  // 0
pub type One = B<Null, I>;   // -1 (注意这里表示-1)
pub type NegOne = B<Null, I>; // -1
  1. 实现细节
  • 派生特质:

    • 为所有结构体派生了一系列标准特质(Eq, PartialEq, Clone, Copy, Debug等)
    • 实现了Default特质,使得这些类型可以默认构造
  • 构造函数:

    • 为每个结构体提供了new方法

    • 基本类型(Null, O, I)的构造函数是内联的

  • 密封特质(Sealed):

    • 实现了Sealed特质,这是一种设计模式,用于限制特质只能在当前crate内实现
  1. 表示规则特点
  • 使用补码表示法,最高位为1表示负数

  • 高位0可以省略(如B<Null, O>表示0而不是B<B<Null, O>, O>)

  • 高位1可以省略(如B<Null, I>表示-1而不是B<B<Null, I>, I>)

  • 十进制数使用科学计数法表示,便于表示实数

  1. 示例解读
  • B<B<B<Null, O>, I>, I>:

    • 从内到外:Null+O=0,B<Null,O>+I=01(1),B<B<Null,O>,I>+I=011(3)

    • 表示3

  • D<B<B<B<Null, O>, I>, I>, B<B<Null, I>, O>>:

    • 整数部分:011(3)

    • 指数部分:B<B<Null,I>,O>=10(-2)

    • 表示3 × 10⁻² = 0.03

这种类型级编程技术在Rust中常用于在编译期进行复杂的类型计算和验证,常见于嵌入式开发、数学库和高安全性应用中。

http://www.lryc.cn/news/586812.html

相关文章:

  • k8s存储入门
  • archive/tar: unknown file mode ?rwxr-xr-x
  • JSON/AJAX/XHR/FetchAPI知识点学习整理
  • 06.计算两个日期之间的差值
  • IT岗位任职资格体系及发展通道-产品经理岗位任职标准参考
  • 基于Flink的实时开发平台-Dinky
  • composer如何安装以及举例在PHP项目中使用Composer安装TCPDF库-优雅草卓伊凡
  • Spring Boot中的路径变量
  • INA226 数据手册解读
  • 13.使用NiN网络进行Fashion-Mnist分类
  • macOS - Chrome 关闭自动更新
  • Python 的 MRO
  • [办公及工程版浏览器]_Google Chrome 138.0.7204.101全屏启动插件
  • es里为什么node和shard不是一对一的关系
  • 香港理工大学实验室定时预约
  • 前端框架状态管理对比:Redux、MobX、Vuex 等的优劣与选择
  • 关于 java:11. 项目结构、Maven、Gradle 构建系统
  • 用 Node.js 构建模块化的 CLI 脚手架工具,从 GitHub 下载远程模板
  • Python 学习之路(十)--常见算法实现原理及解析
  • LabVIEW调用外部DLL
  • [CH582M入门第六步]软件IIC驱动AHT10
  • 【数据结构】图 ,拓扑排序 未完
  • Docker(02) Docker-Compose、Dockerfile镜像构建、Portainer
  • 快速生成 Android 的 Splash 的 9 Patch 图片
  • Docker 搭建本地Harbor私有镜像仓库
  • SpringBoot单元测试类拿不到bean报空指针异常
  • 从架构到代码:飞算JavaAI电商订单管理系统技术解构
  • 决策树的相关理论学习
  • FusionOne HCI 23 超融合实施手册(超聚变超融合)
  • 【C++】多线程同步三剑客介绍