91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

電子發(fā)燒友App

硬聲App

掃碼添加小助手

加入工程師交流群

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>基于Arduino的雙通道示波器

基于Arduino的雙通道示波器

2023-02-03 | zip | 0.01 MB | 次下載 | 2積分

資料介紹

描述

我制作了 2 種不同的示波器,這些都在這個(gè)平臺(tái)上有特色?,F(xiàn)在我想到了雙通道示波器。這個(gè)有主要的微控制器作為 Arduino1.3" OLED 顯示器。這次我還有電池操作選項(xiàng)和板載充電電路。您可以先在面包板上制作它,然后使用下面給出的 PCB 布局。非常感謝 JLCPCB贊助這個(gè)雙通道 Arduino 示波器項(xiàng)目。

mini_20220320_113232_yVRzn4MTQW.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

這不僅是范圍,還有 DDS_PWM(具有 8 種不同波形的函數(shù)發(fā)生器)、脈沖發(fā)生器和頻率計(jì)數(shù)器的一些額外功能。我在日語(yǔ)網(wǎng)頁(yè)上找到了這個(gè)項(xiàng)目,但所有的解釋都在這里給你們看。

特征:

最大實(shí)時(shí)采樣率為 17.2ksps(2 個(gè)通道)和 307ksps(一個(gè)通道)。單通道最大等效時(shí)間采樣率為 16Msps。

20220320_111601_VVX5aHKUM7.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

單通道-30Khz帶寬

屏幕 - 伏特/格和時(shí)間/格

占空比監(jiān)控

小型 1.3 英寸 I2C

交流/直流測(cè)量選項(xiàng)

模式改變,保持狀態(tài)功能

雙通道切換模式

脈沖發(fā)生器選項(xiàng)

DDS_PWM波形發(fā)生器

頻率計(jì)數(shù)器

低電池消耗

便攜式和袖珍型

重要的提示:

該項(xiàng)目?jī)H用于教育目的,展示了 16Mhz 8 位微控制器板的功能。此 MCU 可支持 50KHz 以下的頻率,因此不適用于商業(yè)和專業(yè)用途。這樣,該項(xiàng)目也可以為我命名為 POOR MAN OSCILLOSCOPE。我還發(fā)現(xiàn)這對(duì)下面與音頻相關(guān)的項(xiàng)目很有幫助。

展示:

mini_20220320_112957_mcMp7Ayn5U.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

1.3寸OLED顯示屏帶I2C功能,有SSD1306和SH1106兩種不同型號(hào),可根據(jù)需要改碼。我們必須取消注釋我們?cè)谶@個(gè)項(xiàng)目中使用的是哪個(gè)版本的 LCD。并且屏幕能夠在兩個(gè)通道中用占空比和頻率來(lái)表示波的性質(zhì)。

使用的組件:

阿杜諾納米

1M電阻

10k電阻

1.3英寸OLED顯示屏

100nF 電容

4個(gè)觸覺(jué)按鈕

5v電源

電路圖:

ice_screenshot_20220320-225332_BzZ0cwGm1i.png?auto=compress%2Cformat&w=740&h=555&fit=max

與往常一樣,這是圖示電路,我將電路最小化為一個(gè)通道的操作。如果您想使用兩個(gè)通道,只需按照下面給出的主電路圖進(jìn)行操作即可。

非常感謝“ Cirkit designer ”軟件,證明它是一個(gè)以圖形格式呈現(xiàn)電路和布線的好工具。對(duì)于新手或?qū)W生來(lái)說(shuō),這將是一種更容易理解的方法。

目前,cirkit designer 對(duì)所有人免費(fèi)提供(從此處下載),因此沒(méi)有理由不利用此優(yōu)惠。作為回顧,我發(fā)現(xiàn)這對(duì)我的項(xiàng)目非常有幫助。該軟件的一些特殊功能是:代碼編譯、BOM 管理器、面包板和自定義組件創(chuàng)建。

電路圖:

ice_screenshot_20220322-120530_buiTKLAUX1.png?auto=compress%2Cformat&w=740&h=555&fit=max

1 / 2 ?雙通道簡(jiǎn)化示意圖

電路說(shuō)明:

?

Pin usage
A0 oscilloscope probe ch1
A1 oscilloscope probe ch2
A4 I2C SDA
A5 I2C SCL
D3 PWM output for trigger level
D4 Up button
D6 trigger level input
D8 Down button
D9 Right button
D10 Pulse generator output
D11 PWM DDS output
D12 Left button

?

這種小型示波器可以使用 5volts @200mA 供電。您可以在上面看到兩個(gè)不同的電路,兩者都很好,但我制作的電路經(jīng)過(guò)簡(jiǎn)化并且在所有情況下都最有用。您可以根據(jù)自己的情況修改電路。

看看示波器中那些漂亮的波浪就知道了。

square_380hz_noCLB8Z73B.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

1 / 4 ?方形 380HZ

這次電路還具有外部頻率測(cè)量和 PWM、DDS 脈沖輸出選項(xiàng),具有 2 個(gè)通道。4 觸覺(jué)按鈕在下拉時(shí)觸發(fā)。所有的電阻都是為了適當(dāng)?shù)腷aising。作為一項(xiàng)改進(jìn),您可以制作電路的 PCB 布局,并以 2 美元的價(jià)格從JLCPCB訂購(gòu)它們。順便說(shuō)一句,如果你想使用我的,下面給出你可以下載。使用我的鏈接注冊(cè)將為您提供 PCB 優(yōu)惠券作為原型 SMT 服務(wù)的獎(jiǎng)勵(lì)。為什么不免費(fèi)使用價(jià)值 27 美元的優(yōu)惠券。

探索菜單:

完整菜單比以前的 arduscope 項(xiàng)目有更多的選項(xiàng)。然而,我沒(méi)有得到大屏幕。可能下次我會(huì)使用 TFT 和 mega2560 板構(gòu)建一個(gè)。

通道切換選項(xiàng):

不使用時(shí)關(guān)閉第二個(gè)通道,因?yàn)檫@也會(huì)增加采樣率。

電壓讀數(shù):

還將顯示信號(hào)的最大值和最小值,稱為幅度。

電壓/分區(qū):

時(shí)間/部門(mén):

代碼:

我得到了十六進(jìn)制格式的代碼,但確認(rèn)在 INO Arduino 文件中有一些支持文件。我得到了這些支持文件的 Arduino INO 代碼。一旦我得到完整的代碼,我會(huì)分享,你會(huì)自己改變它。HEX 文件仍然正常工作。如果您不知道如何使用 HEX文件對(duì) Arduino 進(jìn)行編程,請(qǐng)查看本教程。從這里下載這個(gè)項(xiàng)目的代碼。

頻率計(jì)數(shù)器:

?

//int dataMin;                   // buffer minimum value (smallest=0)
//int dataMax;                   //        maximum value (largest=1023)
//int dataAve;                   // 10 x average value (use 10x value to keep accuracy. so, max=10230)
//int dataRms;                   // 10x rms. value

void dataAnalize() {                       // 波形の分析 get various information from wave form
  long d;
  long sum = 0;
  byte *waveBuff = data[sample+0];

  // search max and min value
  dataMin = 255;                          // min value initialize to big number
  dataMax = 0;                             // max value initialize to small number
  for (int i = 0; i < SAMPLES; i++) {     // serach max min value
    d = waveBuff[i];
    sum = sum + d;
    if (d < dataMin) {                     // update min
      dataMin = d;
    }
    if (d > dataMax) {                     // updata max
      dataMax = d;
    }
  }

  // calculate average
  dataAve = (10 * sum + (SAMPLES / 2)) / SAMPLES;  // Average value calculation (calculated by 10 times to improve accuracy)

  // 実効値の計(jì)算 rms value calc.
//  sum = 0;
//  for (int i = 0; i < SAMPLES; i++) {     // バッファ全體に対し to all buffer
//    d = waveBuff[i] - (dataAve + 5) / 10;  // オーバーフロー防止のため生の値で計(jì)算(10倍しない)
//    sum += d * d;                          // 二乗和を積分
//  }
//  dataRms = sqrt(sum / SAMPLES);          // 実効値の10倍の値 get rms value
}

void freqDuty() {                               // 周波數(shù)とデューティ比を求める detect frequency and duty cycle value from waveform data
  int swingCenter;                              // center of wave (half of p-p)
  float p0 = 0;                                 // 1-st posi edge
  float p1 = 0;                                 // total length of cycles
  float p2 = 0;                                 // total length of pulse high time
  float pFine = 0;                              // fine position (0-1.0)
  float lastPosiEdge;                           // last positive edge position

  float pPeriod;                                // pulse period
  float pWidth;                                 // pulse width

  int p1Count = 0;                              // wave cycle count
  int p2Count = 0;                              // High time count

  boolean a0Detected = false;
  //  boolean b0Detected = false;
  boolean posiSerch = true;                     // true when serching posi edge

  swingCenter = (3 * (dataMin + dataMax)) / 2;  // calculate wave center value

  for (int i = 1; i < SAMPLES - 2; i++) {      // scan all over the buffer
    if (posiSerch == true) {   // posi slope (frequency serch)
      if ((sum3(i) <= swingCenter) && (sum3(i + 1) > swingCenter)) {  // if across the center when rising (+-3data used to eliminate noize)
        pFine = (float)(swingCenter - sum3(i)) / ((swingCenter - sum3(i)) + (sum3(i + 1) - swingCenter) );  // fine cross point calc.
        if (a0Detected == false) {              // if 1-st cross
          a0Detected = true;                    // set find flag
          p0 = i + pFine;                       // save this position as startposition
        } else {
          p1 = i + pFine - p0;                  // record length (length of n*cycle time)
          p1Count++;
        }
        lastPosiEdge = i + pFine;               // record location for Pw calcration
        posiSerch = false;
      }
    } else {   // nega slope serch (duration serch)
      if ((sum3(i) >= swingCenter) && (sum3(i + 1) < swingCenter)) {  // if across the center when falling (+-3data used to eliminate noize)
        pFine = (float)(sum3(i) - swingCenter) / ((sum3(i) - swingCenter) + (swingCenter - sum3(i + 1)) );
        if (a0Detected == true) {
          p2 = p2 + (i + pFine - lastPosiEdge); // calucurate pulse width and accumurate it
          p2Count++;
        }
        posiSerch = true;
      }

?

脈沖發(fā)生器:

?

void dataAnalize() {                       // 波形の分析 get various information from wave form
  long d;
  long sum = 0;
  byte *waveBuff = data[sample+0];

  // search max and min value
  dataMin = 255;                          // min value initialize to big number
  dataMax = 0;                             // max value initialize to small number
  for (int i = 0; i < SAMPLES; i++) {     // serach max min value
    d = waveBuff[i];
    sum = sum + d;
    if (d < dataMin) {                     // update min
      dataMin = d;
    }
    if (d > dataMax) {                     // updata max
      dataMax = d;
    }
  }

  // calculate average
  dataAve = (10 * sum + (SAMPLES / 2)) / SAMPLES;  // Average value calculation (calculated by 10 times to improve accuracy)

  // 実効値の計(jì)算 rms value calc.
//  sum = 0;
//  for (int i = 0; i < SAMPLES; i++) {     // バッファ全體に対し to all buffer
//    d = waveBuff[i] - (dataAve + 5) / 10;  // オーバーフロー防止のため生の値で計(jì)算(10倍しない)
//    sum += d * d;                          // 二乗和を積分
//  }
//  dataRms = sqrt(sum / SAMPLES);          // 実効値の10倍の値 get rms value
}

void freqDuty() {                               // 周波數(shù)とデューティ比を求める detect frequency and duty cycle value from waveform data
  int swingCenter;                              // center of wave (half of p-p)
  float p0 = 0;                                 // 1-st posi edge
  float p1 = 0;                                 // total length of cycles
  float p2 = 0;                                 // total length of pulse high time
  float pFine = 0;                              // fine position (0-1.0)
  float lastPosiEdge;                           // last positive edge position

  float pPeriod;                                // pulse period
  float pWidth;                                 // pulse width

  int p1Count = 0;                              // wave cycle count
  int p2Count = 0;                              // High time count

  boolean a0Detected = false;
  //  boolean b0Detected = false;
  boolean posiSerch = true;                     // true when serching posi edge

  swingCenter = (3 * (dataMin + dataMax)) / 2;  // calculate wave center value

  for (int i = 1; i < SAMPLES - 2; i++) {      // scan all over the buffer
    if (posiSerch == true) {   // posi slope (frequency serch)
      if ((sum3(i) <= swingCenter) && (sum3(i + 1) > swingCenter)) {  // if across the center when rising (+-3data used to eliminate noize)
        pFine = (float)(swingCenter - sum3(i)) / ((swingCenter - sum3(i)) + (sum3(i + 1) - swingCenter) );  // fine cross point calc.
        if (a0Detected == false) {              // if 1-st cross
          a0Detected = true;                    // set find flag
          p0 = i + pFine;                       // save this position as startposition
        } else {
          p1 = i + pFine - p0;                  // record length (length of n*cycle time)
          p1Count++;
        }
        lastPosiEdge = i + pFine;               // record location for Pw calcration
        posiSerch = false;
      }
    } else {   // nega slope serch (duration serch)
      if ((sum3(i) >= swingCenter) && (sum3(i + 1) < swingCenter)) {  // if across the center when falling (+-3data used to eliminate noize)
        pFine = (float)(sum3(i) - swingCenter) / ((sum3(i) - swingCenter) + (swingCenter - sum3(i + 1)) );
        if (a0Detected == true) {
          p2 = p2 + (i + pFine - lastPosiEdge); // calucurate pulse width and accumurate it
          p2Count++;
        }
        posiSerch = true;
      }
    }

?

從這里下載代碼文件,目前為十六進(jìn)制格式。要在 Arduino 中上傳十六進(jìn)制文件,請(qǐng)參閱我們之前的教程。

電路板文件:

ghdg_ZQDvB38xfE.png?auto=compress%2Cformat&w=740&h=555&fit=max

感謝積聯(lián)電路和EasyEda贊助并生成了如此優(yōu)質(zhì)的PCB 原型。訂購(gòu)過(guò)程也很簡(jiǎn)單,如下所示。

下載我的 Gerber 文件,轉(zhuǎn)到 JLCPCB,然后選擇厚度顏色參數(shù),只需 2 美元即可訂購(gòu) 5 個(gè) pcb。

測(cè)量:

這里的大問(wèn)題是獲得正確的頻率,正如我所說(shuō),最好先使用音頻頻率。所以我將它與在線音調(diào)生成器工具配對(duì)。這將使我們能夠檢查精度以及不同的波形。

此處顯示了不同頻率下的正弦波測(cè)量值。

1_HtmffATKL1.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

1 / 2

測(cè)量 2:

3_cfSuPBK40d.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

1 / 2

測(cè)量3:

5_WorKlrvMax.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

1 / 2

觀察:

8k_8m5DysuPuo.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

回到最大頻率和振幅,它能夠以 5Khz 的最大頻率測(cè)量高達(dá) 50v 的電壓。是的,波在這個(gè)頻率以上是扭曲的。

下一個(gè)更新:

mini_wer_FayxNNPIV5.jpg?auto=compress%2Cformat&w=740&h=555&fit=max

下次我們將返回一個(gè)更大的微控制器 (2560),也許還有一個(gè) TFT 屏幕。順便說(shuō)一句,這是我上一個(gè) Arduscope 項(xiàng)目的鏈接,該項(xiàng)目支持高達(dá) 10khz 頻率的 1 通道和Raspberry pi Pico 項(xiàng)目,模擬信號(hào)帶寬為 200Khz。再次感謝 JLCPCB。

mcu 示波器 Arduino
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

  1. 1耗盡型MOS FET產(chǎn)品目錄選型表
  2. 0.14 MB   |  2次下載  |  免費(fèi)
  3. 2TI系列-米爾TI AM62L核心板開(kāi)發(fā)板-高能效低功耗嵌入式平臺(tái)
  4. 1.51 MB  |  次下載  |  免費(fèi)
  5. 3WILLSEMI韋爾20年半年度報(bào)告由代理分銷經(jīng)銷一級(jí)代理分銷經(jīng)銷
  6. 3.30 MB  |  次下載  |  免費(fèi)
  7. 4LRC 樂(lè)山無(wú)線電InTWSApplications家電由原廠代理分銷經(jīng)銷一級(jí)代理分銷經(jīng)銷供應(yīng)
  8. 85.84 KB  |  次下載  |  免費(fèi)
  9. 5LAT1596 一文說(shuō)明白 STM32G4 雙 Bank 啟動(dòng)與升級(jí)
  10. 0.64 MB   |  次下載  |  5 積分
  11. 6LAT1594_基于事件喚醒低功耗之介紹
  12. 0.37 MB   |  次下載  |  5 積分
  13. 7PT8P2309 觸控 A/D 型 8-Bit MCU規(guī)格書(shū)
  14. 4.05 MB   |  次下載  |  免費(fèi)
  15. 8PT8P2308 觸控 A/D 型 8-Bit MCU規(guī)格書(shū)
  16. 4.13 MB   |  次下載  |  免費(fèi)

本月

  1. 1美的電磁爐電路原理圖資料
  2. 4.39 MB   |  19次下載  |  10 積分
  3. 2反激式開(kāi)關(guān)電源設(shè)計(jì)解析
  4. 0.89 MB   |  11次下載  |  5 積分
  5. 3耗盡型MOS FET產(chǎn)品目錄選型表
  6. 0.14 MB   |  2次下載  |  免費(fèi)
  7. 4簡(jiǎn)易光伏控制器原理圖資料
  8. 0.07 MB   |  1次下載  |  5 積分
  9. 52EDL05x06xx系列 600V半橋門(mén)驅(qū)動(dòng)器帶集成自舉二極管(BSD)手冊(cè)
  10. 0.69 MB   |  1次下載  |  免費(fèi)
  11. 6國(guó)產(chǎn)千兆網(wǎng)口芯片PT153S中文資料
  12. 1.35 MB   |  次下載  |  免費(fèi)
  13. 7斯丹電子 | 用于芯片測(cè)試系統(tǒng)的射頻干簧繼電器
  14. 5.11 MB  |  次下載  |  免費(fèi)
  15. 8SFI立昌ESD/TVS管原廠代理分銷經(jīng)銷一級(jí)代理分銷經(jīng)銷
  16. 294.76 KB  |  次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935137次下載  |  10 積分
  3. 2開(kāi)源硬件-PMP21529.1-4 開(kāi)關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233095次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費(fèi)下載
  8. 340992  |  191448次下載  |  10 積分
  9. 5十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
  10. 158M  |  183360次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81605次下載  |  10 積分
  13. 7Keil工具M(jìn)DK-Arm免費(fèi)下載
  14. 0.02 MB  |  73829次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65991次下載  |  10 積分