news 2026/4/18 11:47:15

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/4/18 5:14:27

正式发布:RT-Thread首款双核低功耗AI语音产品

RT-Thread与英飞凌深度协同打造的行业突破性产品——基于英飞凌PSOC™ Edge系列微控制器的低功耗AI开发平台“Edgi Talk”,今日正式发布!我们将于今晚举行线上新品发布直播,深度解析技术亮点与应用场景,更有现场演示与互动答疑。产…

作者头像 李华
网站建设 2026/4/18 6:26:13

好写作AI:综述类文献的智能整合——AI在知识脉络梳理中的角色

当海量文献成为思维的负担面对一个研究主题,检索到数百篇相关文献,你是否感到无所适从?信息过载的时代,撰写一篇合格的文献综述,最大的挑战已非“找不到资料”,而是 “理不清脉络” —— 如何在庞杂的文献中…

作者头像 李华
网站建设 2026/4/18 6:29:59

调音神器,百万调音师专业工具

今天再给大家推荐一款与音频相关的工具,也是非常好用,有需要的小伙伴可以下载收藏。 软件介绍 今天给大家推荐的这款软件Melodyne是一款非常专业的音频编辑工具,据说百万调音师用的就是这款工具。 这款软件最大的特点是以“音符”为单位&…

作者头像 李华
网站建设 2026/4/17 14:51:21

LLM微调的关键要点:如何打造高效、可靠的AI模型

.01 概述 在人工智能(AI)领域,近年来大规模语言模型(LLM)的发展给我们带来了巨大的惊喜。无论是文本生成、翻译、摘要,还是问答任务,LLM都表现出了强大的多功能性。然而,尽管这些模…

作者头像 李华
网站建设 2026/4/18 6:24:01

Python中的with语句与try语句:资源管理的两种哲学

Python 中的 with 语句 与 try 语句:资源管理的两种哲学 Python 中处理“资源获取 → 使用 → 释放”这一经典模式,主要有两种主流写法,它们背后代表了两种完全不同的设计哲学。 1. 两种写法最直观的对比 # 方式1:经典的 try..…

作者头像 李华