0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

LabVIEW統(tǒng)一查詢工具包 過(guò)濾器模式Por的介紹

jf_NKOETB7n ? 來(lái)源:LabVIEW的編程之道 ? 作者:LabVIEW的編程之道 ? 2022-11-28 09:52 ? 次閱讀

一、過(guò)濾器模式Pro簡(jiǎn)介

前已經(jīng)寫過(guò)過(guò)濾器模式,這里再寫一篇有以下幾個(gè)方面原因:

1、前一章的算法、數(shù)據(jù)和數(shù)據(jù)規(guī)則沒(méi)有分離,這里設(shè)計(jì)一個(gè)可用的工具包;

2、C#里面有統(tǒng)一查詢語(yǔ)言(LINQ),里面包含數(shù)據(jù)查詢、集合查詢、以及排序,這篇文章也來(lái)開(kāi)發(fā)一個(gè)LabVIEW的統(tǒng)一查詢工具包,實(shí)現(xiàn)以上功能。

功能包含以上內(nèi)容:

1、數(shù)據(jù)查詢;

2、集合運(yùn)算:交集、并集;

3、數(shù)據(jù)排序:升序和降序;

以上功能可以任意組合。

二、過(guò)濾器模式Pro-過(guò)濾

下圖為我們?cè)O(shè)計(jì)的UML關(guān)系類圖:

e69fbdde-6eac-11ed-8abf-dac502259ad0.png

1、Abstract Filter過(guò)濾器框架:定義了過(guò)濾器過(guò)濾的基本規(guī)則

2、Abstract Data需要查詢的數(shù)據(jù)類型:只定義的一個(gè)tostring用于顯示數(shù)據(jù)

3、Abstract Rule定義了具體數(shù)據(jù)規(guī)則

下面開(kāi)始編程

1、創(chuàng)建一個(gè)工程命名為L(zhǎng)LINQ,意思是LabVIEW的LINQ。

2、創(chuàng)建3個(gè)類分別命名為Abstract Filter、Abstract Data和Abstract Rule,在Abstract Filter私有數(shù)據(jù)中添加Abstract Rule和Abstract Data數(shù)組;并創(chuàng)建其數(shù)據(jù)成員訪問(wèn)。

e6c0c51a-6eac-11ed-8abf-dac502259ad0.png

e6e06e74-6eac-11ed-8abf-dac502259ad0.png

3、在Abstract Rule的私有數(shù)據(jù)數(shù)據(jù)中添加兩個(gè)Abstract Data分別命名為RData1、RData2,并創(chuàng)建其數(shù)據(jù)成員訪問(wèn)。

e6fb4ee2-6eac-11ed-8abf-dac502259ad0.png

e70a07ca-6eac-11ed-8abf-dac502259ad0.png

5、在Abstract Rule中創(chuàng)建一個(gè)動(dòng)態(tài)VI命名為Filter rule。

e723d65a-6eac-11ed-8abf-dac502259ad0.png

e73ffd30-6eac-11ed-8abf-dac502259ad0.png

6、在Abstract Filter中添加靜態(tài)類DoFilter,這個(gè)規(guī)則比較簡(jiǎn)單,只要是符合規(guī)則就留下,不符合規(guī)則就剔除。

e758999e-6eac-11ed-8abf-dac502259ad0.png

e7794ca2-6eac-11ed-8abf-dac502259ad0.png

下邊寫個(gè)實(shí)際DEMO來(lái)演示下過(guò)濾模式

6.1、創(chuàng)建VI命名為Filer DEMO

6.2、創(chuàng)建一個(gè)類命名為Double data繼承至Abstract Data,在私有數(shù)據(jù)添加一個(gè)double類型數(shù)據(jù)。

6.3、創(chuàng)建一個(gè)類命名為Greate The 0.5繼承至Abstract rule,重寫Filer rule。

e792f27e-6eac-11ed-8abf-dac502259ad0.png

6.4、在AbstratFIler中添加數(shù)據(jù)和過(guò)濾規(guī)則,進(jìn)行過(guò)濾,然后再取出數(shù)據(jù)

e7a01cb0-6eac-11ed-8abf-dac502259ad0.png

e7c0c7bc-6eac-11ed-8abf-dac502259ad0.png

三、過(guò)濾器模式Pro-集合運(yùn)算

1、并集

在Abstract Filter中創(chuàng)建靜態(tài)方法Uniton,做法分三步

1.1、設(shè)置兩個(gè)過(guò)濾器作為輸入;

1.2、找出結(jié)合2中與集合1相同的部分并剔除;

1.3、合并剔除后的集合數(shù)據(jù)并保存到結(jié)果數(shù)據(jù)中。

e7f5e636-6eac-11ed-8abf-dac502259ad0.png

2、交集

在Abstract Filter中創(chuàng)建靜態(tài)方法Intersection,做法分兩步

2.1、設(shè)置兩個(gè)過(guò)濾器作為輸入;

2.2、取出結(jié)合2中與集合1相同的部分,保存到輸出結(jié)果中。

e8230936-6eac-11ed-8abf-dac502259ad0.png

2、集合范例

下面是一個(gè)兩個(gè)數(shù)組,一個(gè)是0--9的整數(shù),一個(gè)是5--14的整數(shù),求他們的交集和并集。

先創(chuàng)建一個(gè)整類繼承至Abstract Rule,私有數(shù)據(jù)類型為整型,重寫數(shù)據(jù)規(guī)則Filer Rule:

e839d6f2-6eac-11ed-8abf-dac502259ad0.png

3、下面是具體的使用代碼:

e8590fcc-6eac-11ed-8abf-dac502259ad0.png

4、前面板結(jié)果

e870beb0-6eac-11ed-8abf-dac502259ad0.png

四、過(guò)濾器模式Pro-冒泡排序

數(shù)組排序是一個(gè)經(jīng)常使用的功能,LabVIEW自帶的數(shù)組排序功能只能對(duì)數(shù)值類型數(shù)據(jù)進(jìn)行排序,那么簇,指定類中特定數(shù)據(jù)排序呢,每次都需要自己寫非常麻煩,影響編程效率。下面寫個(gè)通用的冒泡排序算法:

從最底部?jī)蓚€(gè)元素開(kāi)始比價(jià),如果上一個(gè)元素大于下一個(gè)元素就交換位置,然后向上挪一個(gè)位置,重復(fù)以上操作直到最頂端。最大值就像泡泡浮出水面一樣,再?gòu)淖畹锥说巾敹说诙€(gè)元素重復(fù)上面動(dòng)作,依次循環(huán)

e897d2ca-6eac-11ed-8abf-dac502259ad0.png

e8ae5ac2-6eac-11ed-8abf-dac502259ad0.png

e8cc42da-6eac-11ed-8abf-dac502259ad0.png

這個(gè)是冒泡迭代的位置。

e8e4acf8-6eac-11ed-8abf-dac502259ad0.png

具體編碼如下程序框圖:

e907a94c-6eac-11ed-8abf-dac502259ad0.png

建一個(gè)double比較的數(shù)據(jù)規(guī)則

e9256a90-6eac-11ed-8abf-dac502259ad0.png

創(chuàng)建個(gè)DEMO生成一組隨機(jī)數(shù)看看運(yùn)行結(jié)果:

e93fd010-6eac-11ed-8abf-dac502259ad0.png

e9577260-6eac-11ed-8abf-dac502259ad0.png

運(yùn)行下結(jié)果達(dá)到預(yù)期,我們把數(shù)據(jù)數(shù)量改成1000,2000看看運(yùn)行時(shí)間

e973813a-6eac-11ed-8abf-dac502259ad0.png

e9947d9a-6eac-11ed-8abf-dac502259ad0.png

上面可以看到1000次運(yùn)行時(shí)間為3.39秒,2000次運(yùn)行時(shí)間為13.7秒,這個(gè)時(shí)間感覺(jué)太長(zhǎng)了,能優(yōu)化排序算法將時(shí)間縮短不?

看下一章的分治排序法。

五、過(guò)濾器模式Pro-分治排序

冒泡排序算法的時(shí)間復(fù)雜度為O(n^2)空間復(fù)雜度為O(1)

我們使用分治排序時(shí)間復(fù)雜度為O(nlog(n))空間復(fù)雜度為O(log(n))

簡(jiǎn)單介紹下原理:

固定第一個(gè)數(shù),從最后和最前搜索,當(dāng)后面大于第一個(gè)數(shù),前面小于第一個(gè)數(shù)時(shí)就交換搜到的數(shù)據(jù)。當(dāng)兩個(gè)搜索指針相遇時(shí),就交換第固定數(shù)和相遇數(shù)。交換后結(jié)果為:相遇位置數(shù)左邊數(shù)小,比右邊的數(shù)大。

e9baecf0-6eac-11ed-8abf-dac502259ad0.png

將其按照相遇位置前后分成兩組:分別重復(fù)上面內(nèi)容直到分治完成。

e9d97bac-6eac-11ed-8abf-dac502259ad0.png

下邊開(kāi)始編寫分治算法代碼,圖中有需要調(diào)用相同的算法需要用到遞歸,我們把主體算法和遞歸部分分離,創(chuàng)建一個(gè)VI命名為Devide Core,VI屬性設(shè)置如下:

e9f69b74-6eac-11ed-8abf-dac502259ad0.png

ea04e742-6eac-11ed-8abf-dac502259ad0.png

分治核心代碼

ea20be0e-6eac-11ed-8abf-dac502259ad0.png

ea40e01c-6eac-11ed-8abf-dac502259ad0.png

ea5a234c-6eac-11ed-8abf-dac502259ad0.png

ea6d9f44-6eac-11ed-8abf-dac502259ad0.png

測(cè)試后1000次時(shí)間為0.58秒,2000次時(shí)間為2.20秒,比冒泡排序有了很大的改善,那么有沒(méi)有更快的優(yōu)化方案呢?看下邊異步分治排序法。

e6822012-6eac-11ed-8abf-dac502259ad0.png

五、過(guò)濾器模式Pro-異步分治排序

eaa8f1d4-6eac-11ed-8abf-dac502259ad0.png

如上圖所示,我們第一次分組后,組一執(zhí)行完后再執(zhí)行組二,組一和組二的數(shù)據(jù)互不干擾,那么我們將異步執(zhí)行組一和組二,以空間換時(shí)間。

具體代碼改造如下:

1、將數(shù)據(jù)轉(zhuǎn)換為引用類型;

2、將組一和組二異步執(zhí)行。

具體代碼如下:

異步分治排序算法:

eac2ddf6-6eac-11ed-8abf-dac502259ad0.png

異步分治核心:

eadee2c6-6eac-11ed-8abf-dac502259ad0.png

測(cè)試代碼:

eb2d48da-6eac-11ed-8abf-dac502259ad0.png

eb4a2590-6eac-11ed-8abf-dac502259ad0.png

eb6c9648-6eac-11ed-8abf-dac502259ad0.png

eb8084a0-6eac-11ed-8abf-dac502259ad0.png

有上面例子可以看出,使用異步分治排序算法,排序速度有了指數(shù)級(jí)別提升。

審核編輯:郭婷

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • LabVIEW
    +關(guān)注

    關(guān)注

    1976

    文章

    3657

    瀏覽量

    325138
  • 過(guò)濾器
    +關(guān)注

    關(guān)注

    1

    文章

    432

    瀏覽量

    19701

原文標(biāo)題:LabVIEW的編程之道—過(guò)濾器模式Por

文章出處:【微信號(hào):LabVIEW的編程之道,微信公眾號(hào):LabVIEW的編程之道】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    解析ECAN-E02單過(guò)濾器CAN硬件過(guò)濾

    什么是CAN總線?CAN(ControllerAreaNetwork)總線是種用于車輛電子設(shè)備之間通信的標(biāo)準(zhǔn)協(xié)議。CAN過(guò)濾器是用來(lái)過(guò)濾CAN總線上收到的消息,從而確保只處理特定的數(shù)據(jù)幀。在CAN
    的頭像 發(fā)表于 01-16 19:35 ?72次閱讀
    解析ECAN-E02單<b class='flag-5'>過(guò)濾器</b>CAN硬件<b class='flag-5'>過(guò)濾</b>

    Labview聲音和振動(dòng)工具包示例文件Sound Level

    Labview 聲音和振動(dòng)工具包示例文件,聲壓測(cè)試,有模擬和DAQ兩個(gè)文件。
    發(fā)表于 01-05 09:15 ?0次下載

    英邁儀器在線過(guò)濾器:精準(zhǔn)過(guò)濾,守護(hù)精密分析儀器

    在精密分析儀器的使用過(guò)程中,任何微小的顆粒干擾都可能對(duì)實(shí)驗(yàn)結(jié)果產(chǎn)生重大影響,甚至導(dǎo)致設(shè)備損壞。為了確保分析的準(zhǔn)確性和儀器的長(zhǎng)期穩(wěn)定運(yùn)行,Instrumax(英邁儀器)精心研發(fā)了全新的在線過(guò)濾器,為
    的頭像 發(fā)表于 12-26 14:03 ?181次閱讀

    USB音頻過(guò)濾器驅(qū)動(dòng)程序安裝

    電子發(fā)燒友網(wǎng)站提供《USB音頻過(guò)濾器驅(qū)動(dòng)程序安裝.pdf》資料免費(fèi)下載
    發(fā)表于 12-19 14:28 ?0次下載
    USB音頻<b class='flag-5'>過(guò)濾器</b>驅(qū)動(dòng)程序安裝

    文理解布隆過(guò)濾器和布谷鳥過(guò)濾器

    是否存在集合中 。布隆過(guò)濾器并不存儲(chǔ)集合中的所有元素,而是存儲(chǔ)元素的哈希表示,因此犧牲了些精確性: 當(dāng)布隆過(guò)濾報(bào)告某元素在集合中不存在時(shí),那么它定不存在;報(bào)告某元素存在時(shí),允許出現(xiàn)
    的頭像 發(fā)表于 11-07 10:10 ?778次閱讀
    <b class='flag-5'>一</b>文理解布隆<b class='flag-5'>過(guò)濾器</b>和布谷鳥<b class='flag-5'>過(guò)濾器</b>

    CH32FV系列CAN設(shè)備過(guò)濾器配置

    簡(jiǎn)介CAN作為總線通信協(xié)議,在總線上可能會(huì)有大量的數(shù)據(jù)同時(shí)傳輸,適當(dāng)?shù)?b class='flag-5'>過(guò)濾機(jī)制可以提升數(shù)據(jù)處理的效率,節(jié)省處理器的資源。通過(guò)配置CAN過(guò)濾器定義自己的數(shù)據(jù)接收規(guī)則,只接收和處理符合規(guī)程的CAN數(shù)據(jù)
    的頭像 發(fā)表于 10-11 08:03 ?344次閱讀
    CH32FV系列CAN設(shè)備<b class='flag-5'>過(guò)濾器</b>配置

    優(yōu)化TPS62097 Output過(guò)濾器

    電子發(fā)燒友網(wǎng)站提供《優(yōu)化TPS62097 Output過(guò)濾器.pdf》資料免費(fèi)下載
    發(fā)表于 10-08 11:19 ?0次下載
    優(yōu)化TPS62097 Output<b class='flag-5'>過(guò)濾器</b>

    PLC工業(yè)過(guò)濾器數(shù)據(jù)采集物聯(lián)網(wǎng)解決方案

    換熱器的銅管,降低換熱率,影響整個(gè)冷卻系統(tǒng)效果。 因此往往需要加裝工業(yè)過(guò)濾器以去除原料或產(chǎn)品中的雜質(zhì),確保產(chǎn)品質(zhì)量。對(duì)此,物通博聯(lián)提供PLC工業(yè)過(guò)濾器數(shù)據(jù)采集系統(tǒng),以實(shí)現(xiàn)過(guò)濾器的智能化監(jiān)控與管理,及時(shí)發(fā)現(xiàn)
    的頭像 發(fā)表于 09-23 10:37 ?299次閱讀
    PLC工業(yè)<b class='flag-5'>過(guò)濾器</b>數(shù)據(jù)采集物聯(lián)網(wǎng)解決方案

    康謀分享 | ADTF過(guò)濾器全面解析:構(gòu)建、配置與數(shù)據(jù)處理應(yīng)用

    送數(shù)據(jù)。接下來(lái),將分享ADTF中創(chuàng)建和使用過(guò)濾器,包括設(shè)置輸入輸出針腳(Pins)、配置觸發(fā)器(Triggers)以及處理數(shù)據(jù)樣本(Samples)。、過(guò)濾器基礎(chǔ)過(guò)
    的頭像 發(fā)表于 09-18 09:42 ?2606次閱讀
    康謀分享 | ADTF<b class='flag-5'>過(guò)濾器</b>全面解析:構(gòu)建、配置與數(shù)據(jù)處理應(yīng)用

    艾體寶干貨 | 用于故障排除的最佳 Wireshark 過(guò)濾器

    Wireshark是種流行的網(wǎng)絡(luò)協(xié)議分析工具,可用于捕獲和分析網(wǎng)絡(luò)數(shù)據(jù)。在網(wǎng)絡(luò)故障排除中,Wireshark是款不可或缺的工具,它可以
    的頭像 發(fā)表于 05-29 15:40 ?621次閱讀
    艾體寶干貨 | 用于故障排除的最佳 Wireshark <b class='flag-5'>過(guò)濾器</b>

    信號(hào)分析和過(guò)濾器的作用

    在通信、電子工程、計(jì)算機(jī)科學(xué)等多個(gè)領(lǐng)域,信號(hào)分析與過(guò)濾器扮演著舉足輕重的角色。信號(hào)分析不僅涉及信號(hào)的獲取、處理、分析和判斷,更是從復(fù)雜的信號(hào)中提取有用信息,進(jìn)行精確解讀的關(guān)鍵過(guò)程。而過(guò)濾器,作為種特定的信號(hào)處理技術(shù),則在此過(guò)程
    的頭像 發(fā)表于 05-16 17:20 ?854次閱讀

    谷歌搜索引擎添加&quot;Web&quot;過(guò)濾器,僅展示文本鏈接

    啟用“Web”過(guò)濾器后,搜索結(jié)果將避免包括論壇、視頻、新聞、圖片等各類鏈接,僅呈現(xiàn)傳統(tǒng)的藍(lán)色鏈接,仿佛回到了2007年之前的通用搜索模式
    的頭像 發(fā)表于 05-16 11:21 ?447次閱讀

    請(qǐng)問(wèn)STM32對(duì)過(guò)濾器編號(hào)時(shí)有哪些注意事項(xiàng)?

    STM32對(duì)過(guò)濾器編號(hào)時(shí)有哪些注意事項(xiàng)?
    發(fā)表于 04-12 08:23

    康謀技術(shù)| 揭秘汽車功能的核心——深度解讀ADTF中的過(guò)濾器

    和可視化。而在ADTF軟件中,過(guò)濾器圖(如圖1 Filter Graph所示)則是至關(guān)重要的,這也是我們理解和應(yīng)用ADTF的關(guān)鍵所在。下面就讓我們深入探索過(guò)濾器圖的奧秘,揭示它在汽車功能開(kāi)發(fā)中的核心作用
    的頭像 發(fā)表于 02-04 11:18 ?607次閱讀
    康謀技術(shù)| 揭秘汽車功能的核心——深度解讀ADTF中的<b class='flag-5'>過(guò)濾器</b>圖

    AN-B-099:DA14535 減少凈排放過(guò)濾器應(yīng)用說(shuō)明

    電子發(fā)燒友網(wǎng)站提供《AN-B-099:DA14535 減少凈排放過(guò)濾器應(yīng)用說(shuō)明.pdf》資料免費(fèi)下載
    發(fā)表于 01-31 10:12 ?0次下載
    AN-B-099:DA14535 減少凈排放<b class='flag-5'>過(guò)濾器</b>應(yīng)用說(shuō)明