0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

手工打造能分析CMOS和TTL电路的分析仪

数据分析与开发 来源:电子森林 作者: John Bradnam 2021-08-17 17:00 次阅读

这是发布在Hackster.io上的一个项目,作者为John Bradnam,一个很小的分析仪能分析CMOS和TTL电路,能够测量5种状态,检测脉冲并针对不同的状态播放不同的声音。

国外的玩家没有我们方便,做个PCB是件很折腾的事情,因此简单的电路都要想办法手工打造。

下面就是这个项目的简单介绍:

在此之前,作者尝试做过多种不同的逻辑分析探针,看下图是作者多年来设计的一些作品:

eee3f4ac-ff30-11eb-9bcf-12bb97331649.png

作者认为应该设计一款终极的逻辑探针,具有如下的一些特点:

它必须足够小以方便拿在手中

能够显示低、高和不关心的状态

一个显示系统,在使用时易于阅读

对“低”和“高”状态有声音反馈

处理不同逻辑系列的器件,例如:TTL 和 CMOS

能够检测探头是否正在测量快速变化的信号

具有针对意外过电压的输入保护

硬件的设计

采用了ATtiny1614位微处理器,通过一个7段数码管进行显示测量的电压,并驱动一个扬声器发出声音,轻触开关切换不同的逻辑系列,一个3.3V的稳压器给微处理器提供电源,原理图见下(使用Eagle绘制)

ef03b224-ff30-11eb-9bcf-12bb97331649.png

这个设计中用到的器件主要有:

微芯科技 ATtiny1614 x1
TSS-307EWA 7-Seg 0.36in CC 显示器 x1
LM1117-33 3.3V 稳压器(SOT-223封装) x1
C&K 开关 PTS 645 系列开关(6mm轴) x1
SMT-916喇叭 x1
3.6V 400mW 齐纳二极管(SOD80C 封装) x2
1N4007 – 高电压、高额定电流二极管(SOD-123 包装) x2
无源元件:5 个 180R 0805、1 个 91R 0805、2 个 1K 0805、2 个 3K 0805、1 个 15K 0805 电阻器;2 x 0.1uF 0805, 1 x 10uF 0805, 1 x 100uF/10V 7343 电容器

作者制作了一个PCB,单面板,主要器件都是表面贴装的。7段数码管和电路板成直角安装。

该探针是高度可以配置的,允许添加其它的逻辑系列器件,见下面程序中的截图部分:

ef8e09e2-ff30-11eb-9bcf-12bb97331649.png

下面是制作的PCB,在国外制作PCB还是很不方便的。

将缝衣针绑上做探针:

焊上7段数码管:

装上开关和电源连线:

作者用一个Arduino Nano来对其进行编程

使用Arduino的IDE:

f027f070-ff30-11eb-9bcf-12bb97331649.png

下面是这个逻辑分析探针的代码:

/************************************************************************** ATtiny1614 Logic Probe Schematic & PCB at https://www.hackster.io/john-bradnam/contact-digital-thermometer-ed18d2 2021-08-10 John Bradnam (jbrad2089@gmail.com) Create program for ATtiny1614 -------------------------------------------------------------------------- Arduino IDE: -------------------------------------------------------------------------- BOARD: ATtiny1614/1604/814/804/414/404/214/204 Chip: ATtiny1614 Clock Speed: 20MHz millis()/micros(): "Enabled (default timer)" Programmer: jtag2updi (megaTinyCore) ATTiny1614 Pins mapped to Ardunio Pins +--------+ VCC + 1 14 + GND (SS) 0 PA4 + 2 13 + PA3 10 (SCK) 1 PA5 + 3 12 + PA2 9 (MISO) (DAC) 2 PA6 + 4 11 + PA1 8 (MOSI) 3 PA7 + 5 10 + PA0 11 (UPDI) (RXD) 4 PB3 + 6 9 + PB0 7 (SCL) (TXD) 5 PB2 + 7 8 + PB1 6 (SDA) +--------+ **************************************************************************/ //Debug mode will use the TX pin to send serial messages. As this is also used//for Segment A, the display is disabled when DEBUG mode is enabled//#define DEBUG //Display Pins#define A_PIN 5 //PB2#define B_PIN 4 //PB3#define C_PIN 3 //PA7#define D_PIN 0 //PA4#define EF_PIN 1 //PA5#define G_PIN 2 //PA6 //Inputs#define VIN_PIN 9 //PA2#define PROBE_PIN 8 //PA1#define MODE_PIN 10 //PA3 #define ADC_PROBE ADC_MUXPOS_AIN1_gc#define ADC_VIN ADC_MUXPOS_AIN2_gc //Outputs#define SPKR_PIN 6 //PB1 //Frequency for different states#define VDD_TONE 1760#define HIGH_TONE 880#define LOW_TONE 220#define GND_TONE 110#define BTN_TONE 440 //Pin and mask mapping tabletypedef struct { int8_t pin; int8_t mask;} SEG; #define SEG_COUNT 6SEG segments[] = { {A_PIN, B00000001}, {B_PIN, B00000010}, {C_PIN, B00000100}, {D_PIN, B00001000}, {EF_PIN, B00010000}, {G_PIN, B00100000}}; //Character set#define CHAR_COUNT 10#define CHAR_SPACE 0#define CHAR_VDD 1#define CHAR_HIGH 2#define CHAR_FLOAT 3#define CHAR_LOW 4#define CHAR_GND 5#define CHAR_PULSE 6#define CHAR_CMOS 7#define CHAR_TTL 8#define CHAR_LS 9 uint8_t charset[] = { B00000000, //CHAR_SPACE B00000001, //CHAR_VDD B00000110, //CHAR_HIGH B00100000, //CHAR_FLOAT B00011111, //CHAR_LOW B00001000, //CHAR_GND B00110011, //CHAR_PULSE B00011001, //CHAR_CMOS B00111000, //CHAR_TTL B00011000 //CHAR_LS}; char debugset[] = { ' ', //CHAR_SPACE '+', //CHAR_VDD '1', //CHAR_HIGH '?', //CHAR_FLOAT '0', //CHAR_LOW '-', //CHAR_GND 'P', //CHAR_PULSE 'C', //CHAR_CMOS 'T', //CHAR_TTL 'L' //CHAR_LS}; typedef struct { float low; //Maximum voltage a LOW state can be (fixed voltage) float high; //Minumum voltage a HIGH state can be as a percentage of VDD uint8_t chr; //Character to display for this family} FAMILY; //This table defines the voltage levels for each family that the probe can measure#define NUMBER_OF_FAMILIES 3FAMILY families[NUMBER_OF_FAMILIES] = { {0.8,80,CHAR_CMOS}, //CMOS family with tones {0.4,48,CHAR_TTL}, //0.4, 2.4 (1987 - National LS S TTL Logic Databook) {0.5,54,CHAR_LS} //0.5, 2.7 (1987 - National LS S TTL Logic Databook)}; enum STATES { STATE_UNKNOWN, STATE_VDD, STATE_HIGH, STATE_FLOAT, STATE_LOW, STATE_GND, STATE_PULSE }; #define PULSE_PERIOD 100 //Maximum time between state changes to be detected as a pulse (1/2 the period => 5Hz) uint8_t activeFamily = 0; //Current chip family being testedSTATES lastState = STATE_UNKNOWN; //Last state measuredSTATES activeState = STATE_UNKNOWN; //Current state at probefloat supplyVoltage = 0; //VDD from 3V3 regulatorfloat probeVoltage = 0; //Last reading from probefloat vinVoltage = 0; //Last reading from VINlong pulseTimeout = 0; //Timer used to measure pulsesbool waitingOnChange = false; //Enabled when waiting on pulseTimeoutbool soundEnabled = false; //Whether tones are played for the states //-------------------------------------------------------------------------// Initialise Hardwarevoid setup(void){ for (int i = 0; i < SEG_COUNT; i++) { pinMode(segments[i].pin, OUTPUT); digitalWrite(segments[i].pin, LOW); } #ifdef DEBUG Serial.begin(115200); #endif pinMode(VIN_PIN, INPUT); pinMode(PROBE_PIN, INPUT); pinMode(MODE_PIN, INPUT_PULLUP); pinMode(SPKR_PIN, OUTPUT); //Setup ADC VREF.CTRLA = VREF_ADC0REFSEL_1V1_gc; ADC0.CTRLC = ADC_REFSEL_VDDREF_gc | ADC_PRESC_DIV256_gc; // 78kHz clock ADC0.CTRLA = ADC_ENABLE_bm; // Single, 10-bit measureSupplyVoltage();} //--------------------------------------------------------------------// Main program loopvoid loop(void){ if (buttonPressed()) { activeFamily++; if (activeFamily == NUMBER_OF_FAMILIES) { activeFamily = 0; soundEnabled = !soundEnabled; //Turn/off audio } showChar(families[activeFamily].chr); noTone(SPKR_PIN); if (soundEnabled) { tone(SPKR_PIN, BTN_TONE); } waitForButtonRelease(); noTone(SPKR_PIN); //Force an update waitingOnChange = false; lastState = STATE_UNKNOWN; } testProbe();} //--------------------------------------------------------------------// Test if button pressedbool buttonPressed(){ bool result = false; if (digitalRead(MODE_PIN) == LOW) { delay(10); //Debounce return (digitalRead(MODE_PIN) == LOW); } return result;} //--------------------------------------------------------------------// Wait until the button is releasedvoid waitForButtonRelease(){ while (digitalRead(MODE_PIN) == LOW) ;} //--------------------------------------------------------------------// Measure the voltages and dislay the results if changedvoid testProbe(){ //Voltages are feed through divide by 4 resistor voltage converter //so they need to multiplied by 4. probeVoltage = measureVoltage(ADC_PROBE) * 4; vinVoltage = measureVoltage(ADC_VIN) * 4; //Calculate HIGH and VDD thresholds from VIN voltage float vdd = vinVoltage - 0.1; float high = families[activeFamily].high * vinVoltage / 100; bool pulse = false; //Workout state if (probeVoltage < 0.1) { activeState = STATE_GND; } else if (probeVoltage <= families[activeFamily].low) { activeState = STATE_LOW; } else if (probeVoltage < high) { activeState = STATE_FLOAT; } else if (probeVoltage <= vdd) { activeState = STATE_HIGH; } else { activeState = STATE_VDD; } if (activeState != lastState) //Only do something if state changes { #ifdef DEBUG Serial.println("p=" + String(probeVoltage) + ", vin=" + String(vinVoltage) + ", vdd=" + String(supplyVoltage)); delay(200); #endif if ((activeState == STATE_HIGH) ^ (lastState == STATE_HIGH)) //Change in state from either LOW to HIGH or HIGH to LOW { pulse = (waitingOnChange && millis() < pulseTimeout); //If state change within PULSE_PERIOD signal it as a pulse pulseTimeout = millis() + PULSE_PERIOD; //Set next timeout waitingOnChange = true; //and signal we are waiting on a state change } else { //This isn't a pulse waitingOnChange = false; pulse = false; } //Turn off any sound from the last state noTone(SPKR_PIN); //Show the result int chr = (pulse) ? CHAR_PULSE : (uint8_t)activeState; showChar(chr); if (soundEnabled) //Play sound if enabled { switch(chr) { case CHAR_VDD: tone(SPKR_PIN, VDD_TONE); break; case CHAR_HIGH: tone(SPKR_PIN, HIGH_TONE); break; case CHAR_LOW: tone(SPKR_PIN, LOW_TONE); break; case CHAR_GND: tone(SPKR_PIN, GND_TONE); break; } } //Record last state lastState = activeState; }} //--------------------------------------------------------------------// Display character on 7 segment display// chr - character to show (0 <= chr < CHAR_COUNT)void showChar(uint8_t chr){ if (chr < CHAR_COUNT) { #ifdef DEBUG Serial.println(debugset[chr]); #else uint8_t mask = charset[chr]; for (int i = 0; i < SEG_COUNT; i++) { digitalWrite(segments[i].pin, (mask & segments[i].mask) ? HIGH : LOW); } #endif } } //--------------------------------------------------------------------------// Measure supply voltage// Source: David Johnson-Davies - www.technoblogy.com - 13th April 2021void measureSupplyVoltage() { ADC0.MUXPOS = ADC_MUXPOS_INTREF_gc; // Measure INTREF ADC0.COMMAND = ADC_STCONV_bm; // Start conversion while (ADC0.COMMAND & ADC_STCONV_bm); // Wait for completion uint16_t adc_reading = ADC0.RES; // ADC conversion result supplyVoltage = 1126.4 / adc_reading;} //--------------------------------------------------------------------------// Measure voltage of a given pin// adcMux - ADC_Ax constant for the pin to measurefloat measureVoltage(uint8_t adcMux) { ADC0.MUXPOS = adcMux; // Measure Analog pin ADC0.COMMAND = ADC_STCONV_bm; // Start conversion while (ADC0.COMMAND & ADC_STCONV_bm); // Wait for completion uint16_t adc_reading = ADC0.RES; // ADC conversion result return supplyVoltage * adc_reading / 1024;}

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • CMOS
    +关注

    关注

    58

    文章

    5724

    浏览量

    235674
  • pcb
    pcb
    +关注

    关注

    4320

    文章

    23113

    浏览量

    398404
  • 稳压器
    +关注

    关注

    24

    文章

    4243

    浏览量

    93883
  • TTL
    TTL
    +关注

    关注

    7

    文章

    503

    浏览量

    70293

原文标题:手工打造的逻辑分析探头

文章出处:【微信号:DBDevs,微信公众号:数据分析与开发】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    什么是频谱分析仪

    分析示波器、谐波分析器、频率特性分析仪或傅里叶分析仪等。现代频谱分析仪能以模拟方式或数字方式显示分析
    发表于 07-02 07:21

    逻辑分析仪的使用

    逻辑分析仪的使用 本文主要介绍逻辑分析仪的使用步骤与方法,从探头与被测系统连接、设置时钟模式和触发功能、捕获、分析、显示波
    发表于 11-27 08:50 2220次阅读

    网络分析仪基础

    什么是网络分析仪? 史密斯圆图 散射参数 高频器件特性 什么是网络分析仪 网络分析仪硬件结构 网络分析仪内部框图 激励源 信号分离装置 接收机 显示处理单元 网络
    发表于 01-17 17:08 97次下载
    网络<b class='flag-5'>分析仪</b>基础

    音频信号分析仪简介

    音频信号分析仪 音频信号分析仪 音频信号分析仪 音频信号分析仪 音频信号分析仪
    发表于 11-13 14:58 0次下载

    什么是频谱分析仪,频谱分析仪的工作原理是什么,频谱分析仪怎样使用?

    示波器、跟踪示波器、分析示波器、谐波分析器、频率特性分析仪或傅里叶分析仪等。现代频谱分析仪能以模拟方式或数字方式显示
    发表于 05-09 14:03 1.6w次阅读

    逻辑分析仪的作用_逻辑分析仪怎么用_逻辑分析仪的使用方法(教程)

    逻辑分析仪是一种类似于示波器的波形测试设备,它可以监测硬件电路工作时的逻辑电平(高或低),并加以存储,用图形的方式直观地表达出来,便于用户检测,分析电路设计(硬件设计和软件设计) 中的
    发表于 12-20 16:23 5.1w次阅读

    功率分析仪作用_功率分析仪分类

    功率分析仪主要用来测量电机、变频器、变压器等功率转换装置的功率、效率等参量。被广泛用于混合动力电动汽车、电动车、太阳发电、风力发电、变频器、变频电机和燃料电池等的测试。部分分析仪,如WP4000变频功率
    发表于 12-19 13:57 3965次阅读

    如何选择频谱分析仪和维修频谱分析仪的故障分析

    以下内容中,小编将对频谱分析仪的相关内容进行着重介绍和阐述,主要内容在于如何选择一款频谱分析仪和如何解决频谱分析仪的失锁故障。希望本文帮您增进对频谱
    的头像 发表于 02-13 17:27 4292次阅读
    如何选择频谱<b class='flag-5'>分析仪</b>和维修频谱<b class='flag-5'>分析仪</b>的故障<b class='flag-5'>分析</b>

    逻辑分析仪是干啥用的 逻辑分析仪的主要用途 逻辑分析仪的应用场景

    。它主要用于对数字信号进行采样、分析、存储,这样可以帮助工程师快速找到电路中出现的问题,提高测试效率,降低开发成本。 逻辑分析仪的主要用途: 1.电子产品设计和开发:逻辑分析仪是电子产
    的头像 发表于 09-19 16:03 3185次阅读

    逻辑分析仪如何使用 逻辑分析仪使用教程

    逻辑分析仪如何使用 逻辑分析仪使用教程  逻辑分析仪是一种用来监测和分析数字信号的工具。它可以用来识别和解决电路故障,帮助做出可靠的设计决策
    的头像 发表于 09-19 16:03 2953次阅读

    音频分析仪的原理

    公司主营出售/回收:示波器、频谱分析仪、网络分析仪、信号发生器、万用表/示波器校准、手机综合测试、噪声系数分析仪、数据采集器、NI-GP
    的头像 发表于 03-29 11:12 802次阅读

    逻辑分析仪可以当示波器用吗

    测量和分析数字信号的电子测量仪器。它可以同时测量多个数字信号,并以图形或波形的形式显示测量结果。 功能 逻辑分析仪的主要功能包括: (1)测量多个数字信号:逻辑分析仪可以同时测量多个数字信号,如
    的头像 发表于 07-17 16:55 1032次阅读

    逻辑分析仪multisim的应用

    电子电路。 逻辑分析仪是一种用于测试和分析数字电路的仪器,它可以捕获和显示数字信号的波形,帮助用户诊断电路问题。Multisim中也包含了逻
    的头像 发表于 07-18 09:13 938次阅读

    Keysight 频谱分析仪(信号分析仪

    Keysight频谱分析仪(信号分析仪)足够的性能和卓越的可靠性,帮助您更轻松、更快速地应对常见的射频-微波测试测量挑战。可靠的频谱分析仪和信号分析仪提供准确可信的测量结果无论您是要在
    的头像 发表于 09-12 08:10 491次阅读
    Keysight 频谱<b class='flag-5'>分析仪</b>(信号<b class='flag-5'>分析仪</b>)

    频谱分析仪与信号分析仪的区别

    在现代电子通信领域,频谱分析仪和信号分析仪是两种不可或缺的测试工具。它们都用于测量和分析信号的特性,但它们的功能、应用和工作原理存在显著差异。 一、定义与基本原理 频谱分析仪 是一种用
    的头像 发表于 11-27 15:26 560次阅读