news 2026/6/15 15:17:55

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/6/14 14:42:05

用给女朋友点奶茶解释AI算法:原来机器学习这么简单!

当你学会用点奶茶解释AI,就会发现技术从未如此美味 开篇:那个改变一切的下午 上周六下午3点,我犯了一个直男典型错误——给正在生理期的女友点了全冰杨枝甘露。后果很严重:她眉头紧锁,我跪了半小时键盘。 但正是这次…

作者头像 李华
网站建设 2026/6/15 11:08:10

26软考初级[信息系统运行管理员]考试核心:物联网、云计算运维

一、物联网运维1.物联网的体系结构物联网从低到高分为4层:感知层、传输层、处理层和应用层。感知层:位于物联网四层模型的最下层,是上面各层的基础。它的作用就是采集各种物体设备的数据,采集设备主要有RFID阅读器,无线…

作者头像 李华
网站建设 2026/6/15 11:03:07

【2026最新】一篇文章带你了解网络安全就业前景

作为与互联网共生的 “朝阳产业”,网络安全早已不是黑客与技术宅的专属领域。从个人隐私保护到国家信息安全,从企业数字化转型到智慧城市建设,网络安全人才的需求正呈爆发式增长。 最新数据表示: 网络安全人才缺口:202…

作者头像 李华
网站建设 2026/6/15 11:07:20

一文带你探究无感FOC电机控制代码的奥秘

无感FOC电机控制代码,算法采用滑膜观测器,SVPWM控制,启动采用Vf,全开源代码,很有参考价值。 带原理图,SMO推导,附有相关的文档资料, matlab模型,电机控制资料。最近在研究电机控制相…

作者头像 李华
网站建设 2026/6/15 11:06:34

【RAG知识库】本地搭建chatgpt知识库

🤖️ 一种利用 langchain 思想实现的基于本地知识库的问答应用,目标期望建立一套对中文场景与开源模型支持友好、可离线运行的知识库问答解决方案。 实现原理如下图所示,过程包括加载文件 -> 读取文本 -> 文本分割 -> 文本向量化 -…

作者头像 李华
网站建设 2026/6/15 12:04:13

专著和编著有啥区别?是一回事吗?

专著和编著有啥区别?专著和编著都是学术著作吗?怎么区分?下面淘淘学术来回答作者的这个疑问。 一、专著和编著的定义 很多作者容易把专著和编著混淆,是因为对于专著和编著的概念不清楚。看到专著和编著就就差一个字&#xff0c…

作者头像 李华