首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何计算差异和聚合能量作为计数器- TimescaleDB

如何计算差异和聚合能量作为计数器- TimescaleDB
EN

Stack Overflow用户
提问于 2020-01-28 21:29:32
回答 2查看 245关注 0票数 1

我有来自智能电表的TimescaleDB格式的时间序列数据,能量值被存储为计数器。

我有两个问题:

1)我如何计算每行能量值之间的差异,以便我可以看到每行的每一分钟的增加?

2)我在1分钟的间隔内得到了这个,我想汇总为30m,60m等。实现这一目标的最好方法是什么?

提前感谢你能给我的任何帮助。

EN

回答 2

Stack Overflow用户

发布于 2020-01-31 14:29:59

这里有几个挑战。首先,您必须确保计数器索引的间隔是恒定的(考虑通信中断,...)。如果没有,你将不得不处理由此产生的能量峰值。其次,您的索引可能看起来像一个离散的拼图信号,偶尔从零重新开始。

这就是我们是如何做到的。对于2),我们在索引上使用与我们需要的分辨率(15min,60min,...)一样多的连续聚合。在需要的地方使用locf。对于1),我们在飞行中进行增量计算。这意味着我们在db中查询索引,然后循环数组来计算增量。这样我们就可以很容易地处理拼图和波峰。

票数 0
EN

Stack Overflow用户

发布于 2021-08-27 13:24:04

我刚刚得到了我的问题的答案,它与您的第1部分非常相似,here

简而言之,我得到的答案是使用before_insert触发器并在插入时计算差值,将它们存储在一个新列中。这避免了需要在每个查询上重新计算增量。

我扩展了答案中建议的函数,还计算了delta_time

代码语言:javascript
复制
NEW.delta_time = EXTRACT (EPOCH FROM NEW.time - previous_time);

这将返回经过的秒数,使您能够可靠地计算仪表功率。

对于第2部分,请考虑上面建议的Continuous Aggregate with time buckets

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59949872

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档