|
軟件運行界面:
0.jpg (88.46 KB, 下載次數: 84)
下載附件
2017-12-5 15:21 上傳
0.jpg (79.67 KB, 下載次數: 92)
下載附件
2017-12-5 15:21 上傳
Stu-02型雙通道數字示波器,是一款以“低成本、高性能”為設計目標,精心設計的200K、400KS/s、2通道的虛擬示波器。通過USB將采集數據快速的傳輸給PC,借助PC的強大計算能力,可以完成對采集數據的“波形合成”、“濾波處理”、“李薩茹圖形”、“幅頻”、“相頻”、“對數幅頻”、“自功率譜”、“對數自功率譜”、“自相關”和“互相關”的分析功能。其中濾波器,支持設計IIR和FIR濾波器設計。IIR支持“巴特沃斯”、“切比雪夫I”、“切比雪夫II”、“橢圓”和“貝塞爾”類型的濾波器設計;FIR支持“矩形窗”、“三角窗”、“漢寧窗”、“海明窗”、“布萊克曼窗”和“凱塞—貝塞爾窗”。
0.jpg (58.44 KB, 下載次數: 80)
下載附件
2017-12-5 15:06 上傳
0.jpg (58.1 KB, 下載次數: 89)
下載附件
2017-12-5 15:07 上傳
0.jpg (34.22 KB, 下載次數: 94)
下載附件
2017-12-5 15:07 上傳
0.jpg (31.65 KB, 下載次數: 72)
下載附件
2017-12-5 15:08 上傳
0.jpg (64.42 KB, 下載次數: 71)
下載附件
2017-12-5 15:08 上傳
0.jpg (61.51 KB, 下載次數: 82)
下載附件
2017-12-5 15:09 上傳
1. 簡介
“低成本和高性能”為設計思想, 借助虛擬儀器的概念和高速的數字信號處理算法將傳統的函數發生器、 示波器、 數據記錄儀、 頻率計、 譜分析儀以及濾波器設計和仿真等功能高度集成、統一平臺方便使用。
軟件環境支持聲卡、 USB模塊和虛擬仿真,三種模式。聲卡模式,可以借助電腦的聲卡來完成對音頻范圍內信號的分析和處理; USB模塊,可以完成對帶寬允許內的信號的分析和處理;其中仿真模式采用軟件模擬來實現所有的功能,便于教學和理論的演示
2. 特性說明
帶寬 200K
采樣率 400KS/s
通道 2
輸入電壓范圍 [-150,150V]
存儲深度 8K*2
AD采樣位數 8位
軟件觸發 上升沿、下降沿、上升/下降沿、差分、上下+差分
分析功能 波形合成:波形相加 波形相減 波形相乘,
濾波處理:支持設計IIR和FIR濾波器。IIR支持“巴特沃斯”、“切比雪夫I”、“切比雪夫II”、“橢圓”和“貝塞爾”類
型的濾波器設計;FIR支持“矩形窗”、“三角窗”、“漢寧窗”、“海明窗”、“布萊克曼窗”和“凱塞—貝塞爾窗”,
波形分析:李薩茹圖形、幅頻、相頻、對數幅頻、自功率譜、對數
自功率譜、自相關、互相關。
抓幀功能 支持連續抓幀功能
傳輸接口 USB2.0
3. 示波器使用說明
當將Stu-02型的USB和電腦相連后,軟件會自動檢測到,并和硬件建立連接。在數字存儲示波器右側工作區“屬性控制”的頂端便會出現一個Stu-02(N)的下拉選項,N會隨不同的電腦而不同,用于區別多個的相同的設備。選擇該選項后彈出如圖3.1的界面。
3.1 通道控制 “通道控制”里的“左通道”和“右通道”用于啟動和關閉對應的示波器通
道。
3.2 自動和暫停 當打開示波器后,點擊“自動”可以開啟示波器的自動檢測功能;點擊“暫停”可 以將采集數據暫停。
3.3 觸發條件 “觸發”可以是硬件觸發和軟件觸發。
硬件觸發采用硬件電路觸發;軟件觸發只是 將采集的數據,采用算法來進行觸發。
軟件觸發:選擇軟件觸發后, “觸發 源”可以是“各自”、“左通道”和“右通 道”; “觸發條件”可以是“不觸發”、“上升 沿”、“下降沿”、“上升/下降沿”、“差 分”和“上下+差分”;“觸發電平”用于設 置觸發的電平;”觸發延遲”用于設置觸發 點,向前或向后的數據顯示比例。
說明:
a、觸發:“硬件觸發”采用硬件電路的觸發;“軟件觸發”采用軟件觸發。
b、觸發源:“各自”,兩個通道,各自對采集的. 數據進行觸發;“左通道”,右通道使用左通道的觸 發點,而不是采用自己的觸發點;“右通道”,左通 道使用右通道的觸發點,而不是采用自己的觸發點。
c、觸發條件:“不觸發”,對于硬件電路,不觸發直接采集,對于軟件觸發,采集的數據 直接顯示,不做任何觸發;“上升沿”,檢測到上升沿并且高于觸發電平便觸發;“下降沿”,檢 測到下降沿并且低于觸發電平便觸發;“上升/下降沿”滿足上述“上升沿”或“下降沿”情況就觸發;“差分”觸發電平為正值時,當兩次的數據采集的差大于 觸發電平設置的值便觸發(此時波形應該是上升的),當觸發電 平為負值時,當兩次的數據采集的差覺得值大于觸發電平設置的
uu.006.jpg (29.04 KB, 下載次數: 80)
下載附件
2017-12-5 15:12 上傳
圖3.1屬性設置
值的絕對值便觸發(此時波形應該是下降的);“上下+差分”當兩次的數據采集的差大于或小于 觸發電平設置的值便觸發。
d、觸發電平用于設置觸發的電平,對于沿觸發和差分觸發的意義不同,詳細解釋見d中。
e、觸發延遲用于設置觸發點,向前或向后的數據顯示比例g。如果小于0就代表,就從“觸發點-采集長度*g”處開始顯示;如果大于0就代表,就從“觸發點+采集長度*g”處開始顯示。
3.4自動 和傳統的示波器一樣,點擊“自動”以后,示波器將自動檢測信號,并根據實際的信號調整顯示界面。
3.5暫停
點擊“暫停”可以,暫停示波器的數據采集。
3.6內插
支持自動和手動來內插,選擇內插后,將根據給定的內插頻率,當采集的波形的頻率大于內插頻率,系統就會啟動正弦內插功能。
3.7 探頭 當改變了示波器探頭上面的×1,×10,需要在界面上選擇相應的探頭倍數,這樣便可以正確的現實波形峰值。
3.8抓幀
如圖3.1,在“屬性設置”窗口的頂端,有“抓幀”按鈕,點擊便可以啟動抓幀;“雙通道”下拉復選框用于選擇抓幀的通道,可以是“左通道”、“右通道”和“雙通道”;“1幀”下拉復選框用于選擇連續抓幀的幀數,可以是1~100幀。
抓取完成后,可以在“數據記錄”選項卡里面,找到以日期的時間命名的txt文本文件,例如10-5+14-13-2+1.txt表示這是10月5日14時13分2秒抓取的第一幀數據。只要雙擊或者右鍵“導入分析”便可以將數據載入分析。
3.9 設備屬性
“設備信息”顯示了該設備的一些具體的參數。
3.10波形分析
請參照“多功能虛擬信號分析儀使用說明書”。
安裝說明:
1.安裝驅動
正確連接 9V/1A 電源適配器,主機指示燈亮,然后將方口 USB 數據線連接于主機與電腦直接,電腦右下角出現發現新硬件 STM Virtual Com Port,如下圖所示,使用向導查找新硬件驅動,選擇從列 表或指定位置安裝(高級)(S), 點 擊 下 一 步 (N)。
首先解壓上位機驅動安裝包,出現 driver 文件夾,將驅動瀏覽到 此文件夾,點擊下一步(N)。
出現硬件安裝警告,點擊仍然繼續(C)。
點擊完成。
安裝完成后,右下角會出現新硬件已安裝并可以使用了,然后將 USB 線與電腦斷開,在重新連接一次,此次即可正常驅動,檢查“我 的電腦 屬性 硬件 設備管理器”在端口中出現主機設備的正常連 接,如下所示,由于各個電腦中設備號均不相同,所以 COM 號各異 , 屬正常現象。
2.軟件互聯
雙擊多功能虛擬信號分析儀軟件圖標,出現下圖所示界面,詳讀 軟件許可協議后,點擊接受。
進入軟件第一主界面,在顯示界面上方有四個工作切換區,分別 是函數發生器、數字存儲示波器、數據記錄儀、濾波器設計。
如使用數字存儲示波器功能,點擊上方工作切換區,即彈出數字 存儲示波器主界面,或在電腦下方工作區內多出一個軟件,即數字存 儲示波器,雙擊使其最大化,并選擇波形界面最大化,軟件右下方工 作條如下圖所示。
點擊屬性設置,上方下拉列表中出現主機設備編號 Stu-0.2(X), 選擇即可,如下圖所示。
通道控制內有左、右通道選擇開關,勾上后即可使用相應通道進 行示波顯示功能,如下圖所示,綠色信號線表示 CH1( 左 通 道 ), 紅 色信號線表示 CH2( 右 通 道 )。
軟件相應功能,請詳見使用說明書。
stm32單片機源程序如下:
- /*
- * Copyright (c) 2010 儀星電子
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2
- * of the License, or (at your option) any later version.
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
- */
- /*
- * 著作權所有(C) 2010 儀星電子
- *
- * 本程序為自由軟件;您可依據自由軟件基金會所發表的GNU通用公共授權條款規定,
- * 就本程序再為發布與/或修改;無論您依據的是本授權的第二版或(您自行選擇的)
- * 任一日后發行的版本。
- * 本程序是基于使用目的而加以發布,然而不負任何擔保責任;亦無對適售性或特定
- * 目的適用性所為的默示性擔保。詳情請參照GNU通用公共授權。
- * 您應已收到附隨于本程序的GNU通用公共授權的副本;如果沒有,請寫信至自由軟件
- * 基金會:59 Temple Place - Suite 330, Boston, Ma 02111-1307, USA。
- * Email yixingdianzi@126.com
- * Email/MSN yixingdianzi@hotmail.com
- * QQ 648887464
- */
- /******************** (C) COPYRIGHT 2009 STMicroelectronics ********************
- * File Name : main.c
- * Author : MCD Application Team
- * Version : V3.1.0
- * Date : 10/30/2009
- * Description : Virtual Com Port Demo main file
- ********************************************************************************
- * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
- * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
- * AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
- * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
- * CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
- * INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
- *******************************************************************************/
- /* Includes ------------------------------------------------------------------*/
- //#include "stm32f10x.h"
- #include "stm32f10x_gpio.h"
- #include "usb_lib.h"
- #include "usb_desc.h"
- #include "usb_pwr.h"
- #include "qdmx_usb.h"
- #include "qdmx_adc.h"
- #define SEND 32
- /* Private typedef -----------------------------------------------------------*/
- /* Private define ------------------------------------------------------------*/
- /* Private macro -------------------------------------------------------------*/
- /* Private variables ---------------------------------------------------------*/
- /* Extern variables ----------------------------------------------------------*/
- extern __IO uint32_t count_in;
- extern uint8_t Controla_a;
- extern uint8_t Controla_b;
- /* Private function prototypes -----------------------------------------------*/
- /* Private functions ---------------------------------------------------------*/
- void Set_System(void);
- void Callback(uint8_t *p);
- void Delay(__IO uint32_t nCount);
- void GPIO_configure(void);
- /*******************************************************************************
- * Function Name : main.
- * Description : Main routine.
- * Input : None.
- * Output : None.
- * Return : None.
- *******************************************************************************/
- int main(void)
- {
- vu8 s;
- /*設置系統時鐘*/
- Set_System();
-
- /*初始化USB模塊*/
- Set_USBClock();
- USB_Interrupts_Config();
- USB_Init();
- /*初始化AD模塊*/
- m_adc_clk_config();
- m_adc_gpio_config();
- m_adc_Interrupts_Config();
- m_adc_init();
- /*初始化GPIO引腳作為放大控制引腳*/
- GPIO_configure();
-
- count_in=0;
- /*默認初始值為放大1倍*/
- GPIO_ResetBits(GPIOA,GPIO_Pin_0);
- GPIO_ResetBits(GPIOA,GPIO_Pin_1);
- GPIO_ResetBits(GPIOA,GPIO_Pin_2);
- GPIO_ResetBits(GPIOB,GPIO_Pin_12);
- GPIO_ResetBits(GPIOB,GPIO_Pin_13);
- GPIO_ResetBits(GPIOB,GPIO_Pin_14);
- while (1)
- {
- }
- }
- void GPIO_configure(void)
- {
- GPIO_InitTypeDef GPIO_InitStructure;
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA , ENABLE);
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB , ENABLE);
-
- RCC_AHBPeriphClockCmd(RCC_APB2Periph_GPIOA , ENABLE);
- RCC_AHBPeriphClockCmd(RCC_APB2Periph_GPIOB , ENABLE);
-
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
- GPIO_Init(GPIOB, &GPIO_InitStructure);
-
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
- GPIO_Init(GPIOA, &GPIO_InitStructure);
- }
- void Delay(__IO uint32_t nCount)
- {
- for(; nCount != 0; nCount--);
- }
- void Callback(uint8_t *p)
- {
- if (GetENDPOINT(ENDP1) & EP_DTOG_RX)
- {
- FreeUserBuffer(ENDP1, EP_DBUF_IN);
- UserToPMABufferCopy((uint8_t*) p, ENDP1_TX1ADDR, SEND);
- SetEPDblBuf1Count(ENDP1,EP_DBUF_IN,SEND);
- }
- else
- {
- FreeUserBuffer(ENDP1, EP_DBUF_IN);
- UserToPMABufferCopy((uint8_t*) p, ENDP1_TX0ADDR, SEND);
- SetEPDblBuf0Count(ENDP1,EP_DBUF_IN,SEND);
- }
- }
- #ifdef USE_FULL_ASSERT
- /*******************************************************************************
- * Function Name : assert_failed
- * Description : Reports the name of the source file and the source line number
- * where the assert_param error has occurred.
- * Input : - file: pointer to the source file name
- * - line: assert_param error line source number
- * Output : None
- * Return : None
- *******************************************************************************/
- void assert_failed(uint8_t* file, uint32_t line)
- {
- /* User can add his own implementation to report the file name and line number,
- ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
- /* Infinite loop */
- while (1)
- {}
- }
- #endif
- /*******************************************************************************
- * Function Name : Set_System
- * Description : Configures Main system clocks & power
- * Input : None.
- * Return : None.
- *******************************************************************************/
- void Set_System(void)
- {
- ErrorStatus HSEStartUpStatus;
- /* SYSCLK, HCLK, PCLK2 and PCLK1 configuration -----------------------------*/
- /* RCC system reset(for debug purpose) */
- RCC_DeInit();
- /* Enable HSE */
- RCC_HSEConfig(RCC_HSE_ON);
- /* Wait till HSE is ready */
- HSEStartUpStatus = RCC_WaitForHSEStartUp();
- if (HSEStartUpStatus == SUCCESS)
- {
- /* Enable Prefetch Buffer */
- FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
- /* Flash 2 wait state */
- FLASH_SetLatency(FLASH_Latency_2);
-
- /* HCLK = SYSCLK */
- RCC_HCLKConfig(RCC_SYSCLK_Div1);
-
- /* PCLK2 = HCLK */
- RCC_PCLK2Config(RCC_HCLK_Div1);
- /* PCLK1 = HCLK/2 */
- RCC_PCLK1Config(RCC_HCLK_Div2);
- #ifdef STM32F10X_CL
- /* Configure PLLs *********************************************************/
- /* PLL2 configuration: PLL2CLK = (HSE / 5) * 8 = 40 MHz */
- RCC_PREDIV2Config(RCC_PREDIV2_Div5);
- RCC_PLL2Config(RCC_PLL2Mul_8);
- /* Enable PLL2 */
- RCC_PLL2Cmd(ENABLE);
- /* Wait till PLL2 is ready */
- while (RCC_GetFlagStatus(RCC_FLAG_PLL2RDY) == RESET)
- {}
- /* PLL configuration: PLLCLK = (PLL2 / 5) * 9 = 72 MHz */
- RCC_PREDIV1Config(RCC_PREDIV1_Source_PLL2, RCC_PREDIV1_Div5);
- RCC_PLLConfig(RCC_PLLSource_PREDIV1, RCC_PLLMul_9);
- #else
- /* PLLCLK = 8MHz * 9 = 72 MHz */
- RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
- ……………………
- …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼
|
-
0.png
(36.86 KB, 下載次數: 132)
下載附件
2017-12-5 15:19 上傳
-
0.png
(5.83 KB, 下載次數: 115)
下載附件
2017-12-5 15:19 上傳
-
0.png
(2.52 KB, 下載次數: 127)
下載附件
2017-12-5 15:19 上傳
-
0.png
(4.2 KB, 下載次數: 118)
下載附件
2017-12-5 15:20 上傳
-
0.png
(6.09 KB, 下載次數: 121)
下載附件
2017-12-5 15:20 上傳
-
-
多功能虛擬信號分析儀上位機 (1).zip
2017-12-5 10:39 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
2.96 MB, 下載次數: 42, 下載積分: 黑幣 -5
-
-
下位機原理圖和PCB源文件.zip
2017-12-5 10:39 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
355.18 KB, 下載次數: 44, 下載積分: 黑幣 -5
-
-
下位機源碼和USB驅動.zip
2017-12-5 10:39 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
1.09 MB, 下載次數: 38, 下載積分: 黑幣 -5
-
-
測量圖片以及信號分析儀說明書等.zip
2017-12-5 15:17 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
7.21 MB, 下載次數: 35, 下載積分: 黑幣 -5
|