加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 时间序列和相关策略

发布时间:2020-12-16 01:31:07 所属栏目:百科 来源:网络整理
导读:我有各种各样的时间序列我想关联并呈现为csv文件或内存数据表(.NET).这些时间序列是时间 – 值对的数组(实际上这些对象包含的不仅仅是时间和值).时间序列可能跨越不同的重叠时段,有些甚至可能有漏洞(给定时间戳的缺失值). 对于那些感兴趣的人,我正在使用OPC
我有各种各样的时间序列我想关联并呈现为csv文件或内存数据表(.NET).这些时间序列是时间 – 值对的数组(实际上这些对象包含的不仅仅是时间和值).时间序列可能跨越不同的重叠时段,有些甚至可能有漏洞(给定时间戳的缺失值).

对于那些感兴趣的人,我正在使用OPC HDA .NET库从OPC HDA服务器中提取历史时间序列.

根据时间戳列,生成的数据表应按时间顺序为每个时间序列分配一列.见下面的例子:

|-------|-------|-------|-------|-------|
   TIME    TS1     TS2     TS3     TS4
|-------|-------|-------|-------|-------|
    1       X               X       X
|-------|-------|-------|-------|-------|
    2       X       X       X       X
|-------|-------|-------|-------|-------|
    3       X       X               X
|-------|-------|-------|-------|-------|
    4       X       X       X 
|-------|-------|-------|-------|-------|
    5       X       X       X 
|-------|-------|-------|-------|-------|

实现这一目标的最有效方法是什么? “有效”我的意思是代码量最少.但考虑到时间序列可能变得非常大,内存使用也可能是一个问题.

解决方法

您可以使用嵌套字典之类的数据结构并迭代内容:

Dictionary <TimeSeries,Dictionary<DateTime,Value>> dict = new Dictionary<TimeSeries,Value>>();

foreach (TimeSeries series in dict.Keys) {

    //table row output code goes here
    Dictionary<DateTime,Value> innerDict = dict[series];
    foreach (DateTime date in innerDict.Keys) {
        Value seriesValueAtTimeT = innerDict[date];
        //table column output code goes here
    }
}

根据您的需要,输出代码写入其他内容的位置,并将数据类型TimeSeries,Value等替换为实际数据类型.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读