工业数据采集的时间不确定性及PLC-Recorder的通道偏移功能

目录

一、缘起

二、效果展示

三、设置方法

四、小结


一、缘起

大家都知道采集软件首先要尽可能还原数据原来的状态,给用户提供一个可以信赖的参考。但是,数据采集又有很多随机因素:Windows是一个周期不严格的系统、以太网通讯有时间波动、PLC内部时钟有快有慢、采集起点在各PLC里并不严格一致等等。这就导致了不同PLC之间的数据存在时间上的微观不一致性(时间的不确定性)。就像我们观察纸上的一个圆圈,看似轮廓光滑,但是,当你拿放大镜看时,就发现轮廓很模糊,根本找不到一个清晰边界。

PLC-Recorder通过PLC发送时间戳功能来规避掉网络、Windows系统的不稳定性,确保采样时间间隔与PLC内部一致,但是,时间戳对时有先后,不同PLC出来的相同曲线还是有一定的先后。当用户进行不同控制器之间的严格时序比对时,就出现了问题。

为了解决这个问题,PLC-Recorder就在离线分析软件里增加了通道时间偏移功能,朋友们可以随意将某个通道的曲线进行前后移动,实现曲线的对齐。

二、效果展示

下面两个截图可以看出调整通道偏移前后的效果变化。如果将两个图片反过来,是不是就实现了错位曲线的对齐效果?

图1 设置偏移前,两个通道的数据时刻完全一致

图2 PLC2进行了1s偏移后的效果

三、设置方法

打开数据文件,在左侧树状图上选择一个通道,在通道名称上点击右键,可以调出通道偏移菜单:

图3 修改通道偏移的方法

可以修改通道的偏移时间,可正可负,单位为ms或者s。也可以清除偏移。偏移时间存储在布局文件里。

被设置了时间偏移的通道,其名称会被加粗,并增加[T]的前缀。在通道信息里也能看到加粗的“时间偏移值”:

图4 带有时间偏移的通道状态

四、小结

通过表达式的计算,可以方便地进行曲线在Y轴方向上的缩放与偏移;通过通道偏移,可以实现曲线在X轴方向上的偏移。至此,我们的离线分析软件已经提供了完整的曲线在各方向移动的功能,朋友们可以自由发挥,来发现数据的更多价值。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
js-audio-recorder 是一个使用 JavaScript 实现的录音库,它提供了一个 `exportWAV` 方法可以将录音数据转换为 WAV 格式的音频文件。如果需要截取录音数据,可以在 `exportWAV` 方法中进行处理。 下面是一个简单的示例代码: ```javascript // 创建录音对象 var recorder = new Recorder({ sampleBits: 16, // 采样位数 sampleRate: 44100 // 采样率 }); // 开始录音 recorder.start(); // 停止录音 recorder.stop(); // 导出录音数据 recorder.exportWAV(function(blob) { var reader = new FileReader(); reader.onload = function() { var data = new DataView(this.result); var offset = 44; // WAV 文件头偏移量 var length = data.byteLength - offset; // 音频数据长度 var start = offset + 100; // 截取开始位置 var end = offset + 1000; // 截取结束位置 var buffer = new ArrayBuffer(length); var view = new DataView(buffer); for (var i = 0; i < length; i++) { view.setInt8(i, data.getInt8(i + offset)); } var slicedBuffer = buffer.slice(start, end); // 截取录音数据 var slicedBlob = new Blob([slicedBuffer], { type: 'audio/wav' }); var url = URL.createObjectURL(slicedBlob); // 播放截取后的录音数据 var audio = new Audio(url); audio.play(); }; reader.readAsArrayBuffer(blob); }); ``` 上述代码中,我们首先通过 `Recorder` 构造函数创建一个录音对象,然后调用 `start` 方法开始录音,`stop` 方法停止录音。接着,通过 `exportWAV` 方法导出录音数据,将录音数据转换为 DataView 对象,并根据 WAV 文件格式的头部信息计算出录音数据的偏移量和长度。接下来,我们可以通过指定开始和结束位置,使用 ArrayBuffer 的 `slice` 方法截取录音数据,并创建一个 Blob 对象,最后通过 URL.createObjectURL 方法生成一个 URL,用于播放截取后的录音数据。 需要注意的是,WAV 文件格式的头部信息通常占用了 44 字节,所以在截取录音数据时需要将偏移量设置为 44。另外,截取录音数据的开始位置和结束位置需要根据实际需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值