news 2026/2/16 3:13:36

HighGo Database中的seg模块

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
HighGo Database中的seg模块

文章目录

  • 文档用途
  • 详细信息

文档用途

seg模块提供了一种数据类型seg,它用于表示线段或者浮点区间。seg可以表示区间端点中的不确定性,这使得它在表示实验测量的数据时特别有用。

详细信息

进行几何学测量时,由于不确定性和随机性,测量值可能是表示特定条件的区间,例如一个温度范围区间。

举个例子,进行几何学测量时,我们把使用仪器测出的值放到数据库中。当以后再从数据库中取出这个值时,得到的结果可能会出现差异。

首先创建扩展:

highgo=# create extension seg;CREATEEXTENSION

假设当时存入数据库中几个精确的高度值,再次查询时,得到的值的精确度可能会不同。

highgo=# create table measurement(height float8);CREATETABLEhighgo=# insert into measurement values(4.30);INSERT01highgo=# insert into measurement values(4.56);INSERT01highgo=# select * from measurement;height--------4.34.56(2rows)

值得注意的是,在测量学领域里,4.30和4.3可能表示的是截然不同的意义。4.30可能被包含于4.3这个区间之内,所以通常我们不希望这些不同的数据项看起来是相同的。

此时,如果使用seg模块提供的seg数据类型,就可以记录带有任意可变精度的区间。这是非常有用的,每个数据元素会记录它自己的精度。

举例如下:

用seg数据类型表示带精度的pH值区间:

highgo=# select '3.25 .. 3.50' :: seg as "pH";pH--------------3.25..3.50(1row)

在seg这种数据类型中,一个区间的外部表达是一个或两个浮点数,中间使用 “…” 或 “…” 分隔。也可以使用一个中心点加上(或减去)一个偏差值的方式,例如‘5(±)2’。

作为seg的一种完整性检查,如果区间的下界比上界大,会导致报错。例如 “10 … 2”

highgo=# select '10 .. 2' :: seg as "rank"; ERROR: 22023: swapped boundaries: 10 is greater than 2 LINE 1: select '10 .. 2' :: seg as "rank"; ^ seg值被内部存储为32位浮点数对。这意味着超过7位有效数字的数会被截断,有7位或7位以下有效数字的数会保持原有的精度。 highgo=# select '3.1415926535 .. 3.572729128219' :: seg as "measurement"; measurement -------------------- 3.14159 .. 3.57273 (1 row)

如果查询返回了0.00,我们需要明确的是尾部的零不是人工设置的,而是反映了原始数据的精度。数字中开头部分的0不影响精度。例如,值0.00045会被认为只有两位有效数字。

还有一个需要注意的问题是:将(±)转换成常规范围的机制在确定边界的有效位数时并不完全准确。

highgo=# select '4(+-)2' :: seg as seg;seg--------2..6(1row)highgo=# select '10(+-)1' :: seg as "range";range--------------9.0..1.1e1(1row)

可以看到,第二次查询的结果,转换后的边界有效位数会增加。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/12 9:07:25

Clawdbot 完整安装教程:打造你的 24/7 私人 AI 助手

Clawdbot 完整安装教程:打造你的 24/7 私人 AI 助手 📖 目录 什么是 Clawdbot核心特性系统要求安装前准备安装步骤 Windows 安装macOS 安装Linux 安装Docker 安装 初始化配置连接聊天平台MCP 工具集成常见问题解决最佳实践总结 什么是 Clawdbot Clawd…

作者头像 李华
网站建设 2026/2/11 23:37:23

基于Matlab实现CNN卷积神经网络回归预测算法

CNN 卷积神经网络回归预测算法(基于Matlab实现) 特殊要求:Matlab版本应高于2018b MATLAB代码,多输入单输出,结果如图换数据直接用,附样本供实验。 代码运行无误,直接更换Excel数据即可实现。 不…

作者头像 李华
网站建设 2026/2/9 16:46:11

使用高版本SpringBoot导致Junit5的NoSuchMethodError的错误

关于作者: 一个深耕自己,不内耗的长期主义者。一个对技术充满激情,对工作对生活充满热情的热血青年。坚信,真正能让大家看懂的技术文章才是好文章,坚持用通俗易懂的大白话写技术文章,并会持续更新。 一、问…

作者头像 李华
网站建设 2026/2/12 14:14:35

深入理解 Java 虚拟机内存模型

深入理解 Java 虚拟机内存模型(JMM)—— 从底层原理到多线程实战(2026 年视角) Java 内存模型(Java Memory Model,简称 JMM)是 JVM 规范中定义的抽象模型,它屏蔽了底层硬件&#xf…

作者头像 李华
网站建设 2026/2/9 20:43:45

现代嵌入式C++教程——C++一定会使得代码膨胀嘛?

现代嵌入式 C 教程系列 —— “C 一定会导致代码膨胀吗?” 答案是:不一定,甚至在很多情况下不会。 现代 C(C11/14/17/20/23)在嵌入式领域已经可以做到零成本抽象(zero-cost abstractions)或极低…

作者头像 李华
网站建设 2026/2/12 0:59:09

Python 文件读写核心机制与最佳实践

Python 文件读写核心机制与最佳实践 (2025-2026 年视角,兼顾性能、安全、可维护性) Python 的文件操作表面上看很简单(open() 一行搞定),但底层机制、编码处理、缓冲策略、异常场景、并发安全等细节如果没…

作者头像 李华