一、源码

这是一个使用 Rust 类型系统实现类型级二进制数的方案,通过泛型和嵌套结构体在编译期表示数值。

//! 类型级二进制数表示方案
//!
//! 使用嵌套泛型结构体表示二进制数,支持整数和实数表示。
//!
//! ## 表示规则
//! - 整数部分: `B<高位, 低位>` 结构体
//!   - `B<Null, O>` = 0
//!   - `B<Null, I>` = -1
//!   - `B<B<Null, O>, I>` = 1
//! - 实数部分: `D<整数部分, 10的幂次>`
//!   - `D<Int, Exp10>` = Int × 10^Exp10use crate::sealed::Sealed;// 基本类型定义
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct Null;  // 终止标记#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct O;     // 比特0#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct I;     // 比特1/// 二进制数结构体
/// - H: 高位部分 (B<H,L> 或 Null)
/// - L: 低位部分 (I 或 O)
#[derive(Eq, PartialEq, Clone, Copy, Debug, Default)]
pub struct B<H, L> {pub(crate) h: H,pub(crate) l: L,
}/// 十进制科学计数法
/// - Int: 二进制整数部分
/// - Exp10: 10的幂次(二进制表示)
#[derive(Eq, PartialEq, Clone, Copy, Debug, Default)]
pub struct D<Int, Exp10>(pub Int, pub Exp10);/// 原生数值包装类型
#[derive(Eq, PartialEq, Debug, Clone, Copy, Default)]
pub struct V<T>(pub T);// 常用类型别名
pub type False = O;        // 逻辑假
pub type True = I;         // 逻辑真
pub type Z0 = B<Null, O>;  // 0
pub type P1 = B<Z0, I>;    // 1
pub type N1 = B<Null, I>;  // -1
pub type N2 = B<N1, O>;    // -2
pub type B0<H> = B<H, O>;  // 以0结尾的数
pub type B1<H> = B<H, I>;  // 以1结尾的数// 构造方法
impl<H> B<H, O> {#[inline]pub const fn b0(h: H) -> Self {B { h, l: O }}
}impl<H> B<H, I> {#[inline]pub const fn b1(h: H) -> Self {B { h, l: I }}
}impl<H, L> B<H, L> {#[inline]pub const fn new() -> Self {Self::default()}
}impl<Int, Exp10> D<Int, Exp10> {#[inline]pub const fn new() -> Self {Self::default()}
}impl Null {#[inline]pub const fn new() -> Self {Null}
}// 密封标记实现
impl<H, L> Sealed for B<H, L> {}
impl<Int, Exp10> Sealed for D<Int, Exp10> {}
impl Sealed for Null {}
impl Sealed for O {}
impl Sealed for I {}
impl<T> Sealed for V<T> {}

二、代码解析

  1. 基本设计理念
  • 使用类型系统在编译期表示数值

  • 通过嵌套泛型结构体表示二进制位

  • 支持整数和实数(科学计数法)表示

  1. 核心类型定义
    基本标记类型:

struct Null;  // 终止标记,表示没有更高位
struct O;     // 表示二进制位0
struct I;     // 表示二进制位1

二进制数结构体 B<H, L>:


struct B<H, L> {h: H,  // 高位部分l: L   // 低位部分(只能是O或I)
}

表示规则:

  • B<Null, O> = 0

  • B<Null, I> = -1 (采用补码表示)

  • B<B<Null, O>, I> = 1 (正数需要前导零)

十进制科学计数法 D<Int, Exp10>:


struct D<Int, Exp10>(Int, Exp10);

表示 Int × 10^Exp10,其中:

  • Int 是二进制整数部分

  • Exp10 是10的幂次(也用二进制表示)

  1. 类型别名

定义常用数字和逻辑值:


type False = O;        // 逻辑假
type True = I;         // 逻辑真 
type Z0 = B<Null, O>;  // 0
type P1 = B<Z0, I>;    // 1
type N1 = B<Null, I>;  // -1
type N2 = B<N1, O>;    // -2
  1. 构造方法

提供方便的构造方式:


// 构造以0结尾的数
B::<H>::b0(h) -> B<H, O>// 构造以1结尾的数  
B::<H>::b1(h) -> B<H, I>// 默认构造
B::new() -> B<H, L>
D::new() -> D<Int, Exp10>
Null::new() -> Null
  1. 密封特质(Sealed)

防止外部实现这些特质,保持类型安全:


impl Sealed for B<H, L> {}
impl Sealed for D<Int, Exp10> {}
// ...其他类型的Sealed实现
  1. 数值表示示例
  • 整数:

    • 0: B<Null, O>

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

    • -1: B<Null, I>

    • -2: B<B<Null, I>, O>

  • 实数:

    • -0.1: D<N1, N1> (-1 × 10^-1)

    • 20.0: D<B<P1, O>, P1> (2 × 10^1)

  1. 特点
  • 编译期计算:所有数值在编译期确定

  • 类型安全:通过类型系统保证操作合法性

  • 零成本抽象:运行时无额外开销

  • 可扩展性:可以添加各种运算的类型级实现

这种设计常用于需要编译期数值计算和验证的场景,如维度检查、单位系统等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/89394.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/89394.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/89394.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Scikit-learn的机器学习建模与SHAP解释分析

基于Scikit-learn的机器学习建模与SHAP解释分析 1. 项目概述 本项目将使用Python的scikit-learn库对一个包含400条记录的数据集进行完整的机器学习建模流程,包括数据预处理、特征工程、模型训练和模型解释。我们将重点关注以下几个方面: 数据预处理:包括连续变量的标准化/…

QA:备份一般存储这块是怎么考虑?备份服务器如何选择?

1. 性能需求与架构设计 大数据平台的备份需满足高并发、加密传输、增量扫描、重复数据删除&#xff08;重删&#xff09;、数据压缩等复杂操作&#xff0c;对备份服务器的计算能力、存储吞吐及网络带宽提出极高要求。建议采用多节点集群架构&#xff0c;通过横向扩展提升备份效…

【东枫科技】用于汽车和工业传感器应用的高性能、集成式 24 GHz FMCW 雷达收发器芯片组

用于汽车和工业传感器应用的高性能、集成式 24 GHz FMCW 雷达收发器芯片组 ADF5904是一款高度集成的4通道、24 GHz接收机下变频器MMIC&#xff0c;具有卓越的低噪声性能、高线性度和低功耗组合。ADF5904集成式多通道接收机下变频器具有10 dB噪声系数性能&#xff0c;优于竞争型…

新版本flutter(3.32.7) android 端集成百度地图sdk

新版本flutter(3.32.7) android 端集成百度地图sdk 因为官方文档有很多地方没有说清楚,导致在适配过程中踩了很多坑,本文档基于已经实现集成的flutter安卓端应用编写。 官方文档地址:https://lbs.baidu.com/faq/api?title=flutter/loc/create-project/configure Flutt…

FreeRTOS—列表和列表项

文章目录一、列表与列表项1.1.列表与列表项的简介1.2.列表与列表项相关结构体1.2.1.列表结构体1.2.2.列表项结构体1.2.3.迷你列表项二、列表相关API函数2.1.列表相关API函数介绍2.1.1.vListInitalise( )初始化列表函数2.1.2.vListInitaliseItem( )初始化列表项函数2.1.3.vListI…

超详细 anji-captcha滑块验证uniapp微信小程序前端组件

由于步骤太多&#xff0c;字数太多&#xff0c;废话也太多&#xff0c;所以前后端分开讲了&#xff0c;后端文章请看&#xff1a; 超详细 anji-captcha滑块验证springbootuniapp微信小程序前后端组合https://blog.csdn.net/new_public/article/details/149116742 anji-captcha…

面向对象编程篇

文章目录一、思维导图二、详细内容第 6 章&#xff1a;面向对象编程基础6.1 面向对象编程的概念和优势6.2 类和对象的定义与创建6.3 类的属性和方法6.4 构造函数&#xff08;__init__&#xff09;和析构函数&#xff08;__del__&#xff09;6.5 封装、继承和多态的实现第 7 章&…

虚拟商品自动化实践:闲鱼订单防漏发与模板化管理的技术解析

最近阿灿发现了一款闲鱼虚拟商品卖家必备神器&#xff01;告别手动发货&#xff0c;订单自动处理&#xff0c;防错防漏&#xff0c;支持课程、激活码、电子书等多种商品&#xff0c;预设模板更省心。文末获取工具&#xff01;最厉害的是&#xff0c;你完全不用一直开着电脑。以…

【Zephyr开发实践系列】08_NVS文件系统调试记录

文章目录前言一、NVS原理介绍&#xff1a;二、BUG-NO1&#xff1a;将NVS运用在NAND-Flash类大容量存储设备2.1 情况描述&#xff1a;2.2 BUG复现&#xff1a;文件系统设备树构建测试应用编写&#xff08;导致错误部分&#xff09;&#xff1a;问题呈现&#xff1a;2.3 问题简述…

网络安全第二次作业

靶场闯关1~8 1. 在url后的name后输入payload ?name<script>alert(1)</script> 2. 尝试在框中输入上一关的payload,发现并没有通过&#xff0c;此时我们可以点开页面的源代码看看我们输入的值被送到什么地方去了 从图中可以看到&#xff0c;我们输入的值被送到i…

LangChain 源码剖析(七)RunnableBindingBase 深度剖析:给 Runnable“穿衣服“ 的装饰器架构

每一篇文章都短小精悍&#xff0c;不啰嗦。一、功能定位&#xff1a;Runnable 的 "增强包装器"RunnableBindingBase 是 LangChain 中实现装饰器模式的核心组件。它就像给原有 Runnable 套上一件 "功能外套"—— 不改变原有 Runnable 的核心逻辑&#xff0c…

为 Git branch 命令添加描述功能

写在最前面的使用方式 查看 所有分支的备注 git branch.notes创建分支并为分支添加备注 git co -b feat/oauth -m 第三方用户登录对分支描述的添加与清除 添加 git branch.note --add 清除 git branch.note --clear &#x1f4dd; 为 Git branch 命令添加描述功能 &#x…

LeetCode|Day18|20. 有效的括号|Python刷题笔记

LeetCode&#xff5c;Day18&#xff5c;20. 有效的括号&#xff5c;Python刷题笔记 &#x1f5d3;️ 本文属于【LeetCode 简单题百日计划】系列 &#x1f449; 点击查看系列总目录 >> &#x1f4cc; 题目简介 题号&#xff1a;20. 有效的括号 难度&#xff1a;简单 题目…

使⽤Pytorch构建⼀个神经⽹络

关于torch.nn:使⽤Pytorch来构建神经⽹络, 主要的⼯具都在torch.nn包中.nn依赖于autograd来定义模型, 并对其⾃动求导.构建神经⽹络的典型流程:定义⼀个拥有可学习参数的神经⽹络遍历训练数据集处理输⼊数据使其流经神经⽹络计算损失值将⽹络参数的梯度进⾏反向传播以⼀定的规则…

网络爬虫的详细知识点

基本介绍 什么是网络爬虫 网络爬虫&#xff08;Web Crawler&#xff09;是一种自动化程序&#xff0c;用于从互联网上抓取、解析和存储网页数据。其核心功能是模拟人类浏览行为&#xff0c;通过HTTP/HTTPS协议访问目标网站&#xff0c;提取文本、链接、图片或其他结构化信息&…

AndroidX中ComponentActivity与原生 Activity 的区别

一、AndroidX 与原生 Activity 的区别 1. 概念与背景 原生 Activity&#xff1a;指 Android 早期&#xff08;API 1 起&#xff09;就存在于 android.app 包下的 Activity 类&#xff08;如 android.app.Activity&#xff09;&#xff0c;是 Android 最初的 Activity 实现&…

Spring AI 使用 Elasticsearch 作为向量数据库

前言 嗨&#xff0c;大家好&#xff0c;我是雪荷&#xff0c;最近在公司开发 AI 知识库&#xff0c;同时学到了一些 AI 开发相关的技术&#xff0c;这期先与大家分享一下如何用 ES 当做向量数据库。 安装ES 第一步我们先安装 Elasticsearch&#xff0c;这里建议 Elasticsear…

TypeScript 配置全解析:tsconfig.json、tsconfig.app.json 与 tsconfig.node.json 的深度指南

前言在现代前端和后端开发中&#xff0c;TypeScript 已经成为许多开发者的首选语言。然而&#xff0c;TypeScript 的配置文件&#xff08;特别是多个配置文件协同工作时&#xff09;常常让开发者感到困惑。本文将深入探讨 tsconfig.json、tsconfig.app.json 和 tsconfig.node.j…

读书笔记(学会说话)

1、一个人只有会说话&#xff0c;才会有好人缘&#xff0c;做事才会顺利。会说话的人容易成功。善于说话的人易成功&#xff0c;而不善说话的人往往寸步难行。我们要把话说得好听&#xff0c;同时更要把事做得漂亮。或许一句话&#xff0c;一件事&#xff0c;就可能使人生的旅途…

私有服务器AI智能体搭建-大模型选择优缺点、扩展性、可开发

以下是主流 AI 框架与模型的对比分析&#xff0c;涵盖其优缺点、扩展性、可开发性等方面。 文章目录一、AI 框架对比二、主流大模型对比三、扩展性对比总结四、可开发性对比总结五、选择建议&#xff08;按场景&#xff09;六、未来趋势一、AI 框架对比 框架优点缺点扩展性可开…