msp 430 pwm怎么控制

msp 430 pwm怎么控制,第1张

// MSP430F149

// -----------------

// /|\| XIN|-

// | | | HF XTAL (455k - 8MHz)

// --|RST XOUT|-

// | |

// | P41/TB1|--> CCR1 - 75% PWM

// | P42/TB2|--> CCR2 - 25% PWM

#include <msp430x14xh>

void main(void)

{

volatile unsigned int i;

WDTCTL = WDTPW +WDTHOLD; // Stop WDT

BCSCTL1 |= XTS; // ACLK= LFXT1 = HF XTAL

do

{

IFG1 &= ~OFIFG; // Clear OSCFault flag

for (i = 0xFF; i > 0; i--); // Time for flag to set

}

while ((IFG1 & OFIFG)); // OSCFault flag still set

BCSCTL2 |= SELM_3; // MCLK= LFXT1 (safe)

P4DIR |= 0x06; // P41 and P42 output

P4SEL |= 0x06; // P42 and P42 TB1/2 otions

TBCCR0 = 128; // PWM Period/2

TBCCTL1 = OUTMOD_6; // CCR1 toggle/set

TBCCR1 = 32; // CCR1 PWM duty cycle

TBCCTL2 = OUTMOD_6; // CCR2 toggle/set

TBCCR2 = 96; // CCR2 PWM duty cycle

TBCTL = TBSSEL_1 + MC_3; // ACLK, up-down mode

_BIS_SR(CPUOFF); // Enter LPM0

}

应该不难写的,你是要做什么

我看看哈

#include <MSP430X14Xh> // 恩 头文件

void main(void) // 主函数

{

1,设置一下定时器的初始化把(定时器关闭状态) // 刚刚下在了一个430程序 里头没见定时器,这个比较尴尬

P1DIR |= SCL; //将SCL管脚(P12)设置为输出管脚 用这个管脚接超声波的控制端吧

P1DIR &= ~(SDA); //将SDA设置为输入方向 用它来接受超声波的接受信号把(超声波剩下的两个引脚是电源了)

P1OUT &= ~(SDA); //SDA管脚输出为低电平

while(1)

{

P1OUT |= SCL; //SCL管脚输出为高电平

延时20us

P1OUT &= ~(SCL); //一个20us的脉冲

2 打开定时器

while(!SDA); // 等待消息

3关闭定时器

4读定时器的数

5计算一下得出meter

if(meter>1) // 你就再随便找个引脚接蜂鸣器给她高点平好了

}

不是为了分是希望你少copy点代码 这样会比较好

}

请采纳。

波形生成只是产生一段信号(信号长度=采样数/采样率),信号生成则是产生连续的波形信号,不断的对信号进行采样,然后产生输出数据

信号生成的是一个拥有N(N=采样数)项数组,他是通过对指定波形的量化来采集数据的,他的X轴不是时间而是量化的最小单位,其产生数据的快慢由D/A转换的速度决定的。当无法获得实际信号时,(例如没有DAQ板卡来获得实际信号或者受限制无法访问实际信号),信号发生功能可以产生模拟信号测试程序。

你自己简单做一个对比程序就可以理解了

注意建立时要用常量

不要用输入控件

直接在接线端创建常量

玩过D/A吗?你没有发现信号生成的参数和D/A很像吗?

生成的数据一个是1维数组

一个是波形数据,不是2维数组,它类似于簇

在LabVIEW中,有两处地方可以用来生成模拟信号,一是Signal Generation模板,一是Waveform Generation模板。

Signal Generation模板和Waveform Generation模板的功能大同小异,生成的信号类型差不多,主要区别是Waveform Generation模板包含了信号的时间信息,波形是时间的函数;而Signal Generation模板则不包括。Waveform Generation模板中各模块参数设置更为灵活,功能更强大,其中的许多模块是在Signal Generation模板的基础上进一步开发的。

(所以说Sine Wave和Sine Pattern<在Signal Generation模板中>这两个VI是不包含时间信息的,只有Sine Waveform<在Waveform Generation模板中>包含了信号的时间信息。)

Wave VI 和Pattern VI运行过程的根本不同在于这个特定的VI是否在内部记录了生成信号的相位轨迹。Wave VI在内部记录了相位轨迹,而Pattern VI则没有。可以通过识别VI名称中包含的单词是Wave 还是Pattern来区分这两类VI。

Wave VI使用的是归一化了的单位周期数/每采样。Pattern VI中仅有Chrip Pattern VI使用归一化单位。

由于Wave VI在内部记录了相位,因此允许用户控制初始相位的取值。phase in指明了首次采样生成波形时的初始相位(以度为单位),而phase out则指明了下一次采样生成波形时的相位。除此之外,reset phase用来说明调用该波形时所生成的首次采样相位是在phase in中指明的相位,还是当VI最后执行时出现在phase out中的相位。reset phase为TRUE时,将初始相位设置为phase in,为FALSE时将其设置为VI最后执行时的phase out值。

(补充说明一下:下列VI使用由归一化单位指定的频率: 1)Sine Wave  2)Square Wave  3)Sawtooth Wave  4)Triangle Wave  5)Arbitrary Wave  6)Chrip Pattern

使用这些VI时,需要将给定问题中的频率单位转换为归一化频率单位,即周期数/每采样。

在给定周期数(cycles)的情况下,周期数除以采样数就得到归一化频率;在给定以Hz(周期数/每秒)为单位的频率的情况下,如果用以Hz为单位的频率除以以Hz为单位的采样率,就可以得到归一化频率。)

关于你说的端子配置不同,输出不同。可能是由于你没有考虑归一化频率的问题。举一个简单的例子,就能更清楚明白这个两个VI的区别。之后你就可以根据自己的需要选用它们了。

程序框图和程序运行后的前面板如下图所示。Sine Wave和Sine Pattern这两个VI的采样数(samples)的默认值都是128。其他各参数设置如前面板中所示。

对于Sine Pattern来说,采样数为128,周期为5,需要大概25(128/5=256)个采样点生成一个周期的正弦波。

对于Sine Wave来说,归一化频率(周期数/采样数)为5/50=01,需要10个采样点来生成一个周期的正弦波,数字10由归一化频率的倒数计算得到。采样数为128,每周期采样数为10,因此在Sine Wave波形显示中,有128个周期。

波形发生器是一种常用的信号源,广泛地应用于电子电路、自动控制系统和教学实验等领域。本次课程设计使用的AT89S51 单片机构成的发生器可产生锯齿波、三角波、正弦波等多种波形,波形的周期可以用程序改变,并可根据需要选择单极性输出或双极性输出,具有线路简单、结构紧凑等优点。在本设计的基础上,加上按钮控制和LED显示器,则可通过按钮设定所需要的波形频率,并在LED上显示频率、幅值电压,波形可用示波器显示。

二、系统设计

波形发生器原理方框图如下所示。波形的产生是通过AT89S51 执行某一波形发生程序,向D/A转换器的输入端按一定的规律发生数据,从而在D/A转换电路的输出端得到相应的电压波形。在AT89S51的P2口接5个按扭,通过软件编程来选择各种波形、幅值电压和频率,另有3个P2口管脚接TEC6122芯片,以驱动数码管显示电压幅值和频率,每种波形对应一个按钮。此方案的有点是电路原理比较简单,实现起来比较容易。缺点是,采样频率由单片机内部产生故使整个系统的频率降低。

1、波形发生器技术指标

1)波形:方波、正弦波、锯齿波;

2)幅值电压:1V、2V、3V、4V、5V;

3)频率:10HZ、20HZ、50HZ、100HZ、200HZ、500HZ、1KHZ;

2、 *** 作设计

1)上电后,系统初始化,数码显示6个‘-’,等待输入设置命令。

2)按钮分别控制“幅值”、“频率”、“方波”、“正弦波”、“锯齿波”。

3)“幅值“键初始值是1V,随后再次按下依次增长1V,到达5V后在按就回到1V。

4)“频率“键初始值是10HZ,随后在按下依次为20HZ、50HZ、100HZ、200HZ、500HZ、1000HZ循环。

三、硬件设计

本系统由单片机、显示接口电路,波形转换(D/A)电路和电源等四部分构成。电路图2附在后

1、单片机电路

功能:形成扫描码,键值识别、键处理、参数设置;形成显示段码;产生定时中断;形成波形的数字编码,并输出到D/A接口电路和显示驱动电路。

AT89S51外接12M晶振作为时钟频率。并采用电源复位设计。复位电路采用上电复位,它的工作原理是,通电时,电容两端相当于短路,于是RST引脚上为高电平,然后电源通过对电容充电。RST端电压慢慢下降,降到一定程序,即为低电平,单片机开始工作。

AT89S51的P2口作为功能按钮和TEC6122的接口。P1口做为D/A转换芯片0832的接口。用定时/计数器作为中断源。不同的频率值对应不同的定时初值,允许定时器溢出中断。定时器中断的特殊功能寄存器设置如下:

定时控制寄存器TCON=20H;

工作方式选择寄存器TMOD=01H;

中断允许控制寄存器IE=82H。

2、显示电路

功能:驱动6位数码管显示,扫描按钮。

由集成驱动芯片TEC6122、6位共阴极数码管和5个按钮组成。当某一按钮按下时,扫描程序扫描到之后,通过P2口将数字信号发送到 TEC6122芯片。TEC6122是一款数字集成芯片。它的外接电压也是+5V,并且由于数码管的载压较小,为了保护数码管,必须在两者间接电阻,大约是560欧。

扫描利用软件程序实现,当某一按键按下时,扫描程序立即检测到,随后调用子程序,执行相应的功能。

3、D/A电路

功能:将波形样值的编码转换成模拟值,完成双极性的波形输出。

由一片0832和两块LM358运放组成。DAC0832是一个具有两个输入数据寄存器的8位DAC。目前生产的DAC芯片分为两类,一类芯片内部设置有数据寄存器,不需要外加电路就可以直接与微型计算机接口。另一类芯片内部没有数据寄存器,输出信号随数据输入线的状态变化而变化,因此不能直接与微型计算机接口,必须通过并行接口与微型计算机接口。DAC0832是具有20条引线的双列直插式CMOS器件,它内部具有两级数据寄存器,完成8位电流D/A转换,故不需要外加电路。0832是电流输出型,示波器上显示波形,通常需要电压信号,电流信号到电压信号的转换可以由运算放大器LM358实现,用两片LM358可以实现双极性输出。

单片机向0832发送数字编码,产生不同的输出。先利用采样定理对各波形进行抽样,然后把各采样值进行编码,的到的数字量存入各个波形表,执行程序时通过查表方法依次取出,经过D/A转换后输出就可以得到波形。假如N个点构成波形的一个周期,则0832输出N个样值点后,样值点形成运动轨迹,即一个周期。重复输出N个点,成为第二个周期。利用单片机的晶振控制输出周期的速度,也就是控制了输出的波形的频率。这样就控制了输出的波形及其幅值和频率。

四、 软件设计

主程序和子程序都存放在AT89S51单片机中。

主程序的功能是:开机以后负责查键,即做键盘扫描及显示工作,然后根据用户所按的键转到相应的子程序进行处理,主程序框图如图1所示。

子程序的功能有:幅值输入处理、频率输入处理、正弦波输出、锯齿波输出、方波输出、显示等。

下面是程序

include <reg51h>

#define uchar unsigned char

#define uint unsigned int

sbit LCP=P2^2;

sbit SCP=P2^1;

sbit SI=P2^0;

sbit S1=P2^3;

sbit S2=P2^4;

sbit S3=P2^5;

sbit S4=P2^6;

sbit S5=P2^7;

sbit DA0832=P3^3;

sbit DA0832_ON=P3^2;

uchar fun=0,b=0,c=0,d=0,tl,th;

uchar code tab[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};

uchar code tosin[256]={0x80,0x83,0x86,0x89,0x8d,0x90,0x93,0x96,0x99,0x9c,0x9f,0xa2,0xa5,0xa8,0xab,0xae,0xb1,0xb4,0xb7,0xba,0xbc,0xbf,0xc2,0xc5

,0xc7,0xca,0xcc,0xcf,0xd1,0xd4,0xd6,0xd8,0xda,0xdd,0xdf,0xe1,0xe3,0xe5,0xe7,0xe9,0xea,0xec,0xee,0xef,0xf1,0xf2,0xf4,0xf5

,0xf6,0xf7,0xf8,0xf9,0xfa,0xfb,0xfc,0xfd,0xfd,0xfe,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfe,0xfd

,0xfd,0xfc,0xfb,0xfa,0xf9,0xf8,0xf7,0xf6,0xf5,0xf4,0xf2,0xf1,0xef,0xee,0xec,0xea,0xe9,0xe7,0xe5,0xe3,0xe1,0xde,0xdd,0xda

,0xd8,0xd6,0xd4,0xd1,0xcf,0xcc,0xca,0xc7,0xc5,0xc2,0xbf,0xbc,0xba,0xb7,0xb4,0xb1,0xae,0xab,0xa8,0xa5,0xa2,0x9f,0x9c,0x99

,0x96,0x93,0x90,0x8d,0x89,0x86,0x83,0x80,0x80,0x7c,0x79,0x76,0x72,0x6f,0x6c,0x69,0x66,0x63,0x60,0x5d,0x5a,0x57,0x55,0x51

,0x4e,0x4c,0x48,0x45,0x43,0x40,0x3d,0x3a,0x38,0x35,0x33,0x30,0x2e,0x2b,0x29,0x27,0x25,0x22,0x20,0x1e,0x1c,0x1a,0x18,0x16

,0x15,0x13,0x11,0x10,0x0e,0x0d,0x0b,0,0x09,0x08,0x07,0x06,0x05,0x04,0x03,0x02,0x02,0x01,0x00,0x00,0x00,0x00,0x00,0x00

,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x02 ,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0,0x0b,0x0d,0x0e,0x10,0x11,0x13,0x15

,0x16,0x18,0x1a,0x1c,0x1e,0x20,0x22,0x25,0x27,0x29,0x2b,0x2e,0x30,0x33,0x35,0x38,0x3a,0x3d,0x40,0x43,0x45,0x48,0x4c,0x4e

,0x51,0x55,0x57,0x5a,0x5d,0x60,0x63,0x66 ,0x69,0x6c,0x6f,0x72,0x76,0x79,0x7c,0x80 };

void display(unsigned char command)

{

unsigned char i;

LCP=0;

for(i=8;i>0;i--)

{

SCP=0;

if((command & 0x80)==0)

{

SI=0;

}

else

{

SI=1;

}

command<<=1;

SCP=1;

}

LCP=1;

}

void key1(void)

{

fun++;

if(fun==4)

fun=0x00;

}

void key2(void)

{

tl++;

if(tl==0x1f)

th++;

}

void key3(void)

{

tl--;

if(tl==0x00)

th--;

}

void key4(void)

{

double t;

int f;

TR0=0;

t=(65535-th256-tl)04;

f=(int)(1000/t);

S3=tab[f%10];

f=f/10;

S2=tab[f%10];

f=f/10;

if(f==0)

S1=0;

else

S1=tab[f];

TR0=1;

}

void key5(void)

{

tl--;

if(tl==0x00)

th++;

}

void judge(void)

{

uchar line,row,de1,de2,keym;

P1=0x0f;

keym=P1;

if(keym==0x0f)return;

for(de1=0;de1<200;de1++)

for(de2=0;de2<125;de2++){;}

P1=0x0f;

keym=P1;

if(keym==0x0f)return;

P1=0x0f;

line=P1;

P1=0xf0;

row=P1;

line=line+row; /存放特征键值/

if(line==0xde)key1();

if(line==0x7e)key2();

if(line==0xbd)key3();

if(line==0x7d)key4();

}

void time0_int(void) interrupt 1 //中断服务程序

{

TR0=0;

if(fun==1)

{

DA0832=tosin[b]; //正弦波

b++;

}

else if(fun==2) //锯齿波

{

if(c<128)

DA0832=c;

else

DA0832=255-c;

c++;

}

else if(fun==3) // 方波

{

d++;

if(d<=128)

DA0832=0x00;

else

DA0832=0xff;

}

TH0=th;

TL0=tl;

TR0=1;

}

void main(void)

{

TMOD=0X01;

TR0=1;

th=0xff;

tl=0xd0;

TH0=th;

TL0=tl;

ET0=1;

EA=1;

while(1)

{

display();

judge();

}

}

五、心得体会

开始的时候由于没有经验,不知如何下手,所以就去图书管找了一些书看,尽管有许多的设计方案,可是总感觉自己还是有许多的东西弄不太清楚,于是就请教同学。他常做一些设计,有一些经验。经过他的解释分析各方案之后,决定用查表的方法来做。这样可以降低一些硬件设计的难度,初次设计应切合自己的水平。用8031需要扩展ROM,这样还要进行存储器扩展。而且现在8031实际中已经基本上不再使用,实际用的AT89S51芯片有ROM,这样把经过采样得到的数值制成表,利用查表来做就简单了。我认为程序应该不大,片内ROM应该够用的。用LED显示频率和幅值,现有集成的接口驱动芯片,波形可通过示波器进行显示,单片机接上D/A转换芯片即可,这样硬件很快就搭好了。

我以为这些做好了,构思也有了,写程序应该是相对容易的。谁知道,写起程序来,才想到功能键要有扫描程序才行呀,我真的感到很难。那时真的有点想放弃?于是就去请教了老师,老师帮忙分析了一下,自己又查阅了一些资料,终于明白了扫描程序怎么写。

于是在自己的努力下,程序很快就写好了。这次是我的第一个设计器件,尽管经历了不少的艰辛,但给我积累了一点设计的经验,最后也有点小小的成就感。后面的路还很长,我还的努力!

参考文献

[1] 童诗白,华成英模拟电子技术基础〔M〕北京:高等教育出版社,2003345-362

[2] 潘永雄,沙河,刘向阳电子线路CAD实用教程〔M〕西安:西安电子科技大学出版社,200113-118

[3] 张毅刚,彭喜源,谭晓昀,曲春波MCS-51单片机应用设计[M]哈尔滨:哈

尔滨工业大学出版社,199753-61

ORG 0000H

LJMP MAIN

ORG 0100H ;主程序地址

MAIN: JNB P10,P10 ;哪个键按下,显示哪个波形

JNB P11,P11

JNB P12,P12

JNB P13,P13

LJMP MAIN ;没有键按下返回主程序循环

P10: MOV R7,#00H ;方波波形,R7为特征码,放00,表示方波

LCALL SQU ;调用方波波形函数

LJMP MAIN ;调用完返回主程序循环

P11: MOV R7,#01H ;01表示SAW波

LCALL SAW

LJMP MAIN

P12: MOV R7,#02H

LCALL TRI

LJMP MAIN

P13: MOV R7,#03H

LCALL SIN

LJMP MAIN

SQU: JNB P11,N1 ;方波函数,如果有其他键按下

JNB P12,N2 ;退出程序

JNB P13,N3

LJMP SSQU ;没有键按下,到SSQU函数产生方波

N1: MOV R7,#01H ;哪个键按下就在R7中记下特征码

LJMP TC0

N2: MOV R7,#02H

LJMP TC0

N3: MOV R7,#03H

LJMP TC0

SSQU: CJNE R7,#00H,TC0 ;R7不为0退出

MOV R0,#00H ;R0中放00

MOV DPTR,#7FFFH ;这个应该是DAC0832的地址

K00: MOV A,#0FFH ;A中放FF,高电平

MOVX @DPTR,A ;A到0832转换

MOV P0,#0FFH ;这一句不怎么懂,感觉可以去掉

MOV P2,#0FFH ;值P2输入方式,P2是通过拨码按钮改

MOV A,P2 ;变数值,P2越大,波形周期越小

CPL A

MOV R3,A

L00: DEC R3

CJNE R3,#255,L00 ;这个循环改变周期

INC R0

INC R0

CJNE R0,#254,K00 ;高电平波循环127次

MOV R0,#00H

K01: MOV A,#00H ;低电平,跟高电平差不多

MOVX @DPTR,A

MOV P0,#00H

MOV P2,#0FFH

MOV A,P2

CPL A

MOV R3,A

L01: DEC R3

CJNE R3,#255,L01

INC R0

INC R0

CJNE R0,#254,K01

LJMP SQU ;显示完一个波形,回到方波函数开始,判断有无其他按键

TC0: RET ;返回主函数

SAW: JNB P10,N4 ;判断有无其他按键,同方波

JNB P12,N5

JNB P13,N6

LJMP SSAW

N4: MOV R7,#00H

LJMP TC1

N5: MOV R7,#02H

LJMP TC1

N6: MOV R7,#03H

LJMP TC1

SSAW: CJNE R7,#01H,TC1 ;特征码不是01 退出

MOV R0,#0FFH ;RO中放即将输出的值

MOV DPTR,#7FFFH

K10: MOV A,R0 ;锯齿波的每个值

MOVX @DPTR,A ;输出

MOV P0,R0

MOV P2,#0FFH ;通过P2改变周期

MOV A,P2

CPL A

MOV R3,A

L10: DEC R3

CJNE R3,#255,L10

INC R0 ;通过R0加1 来显示锯齿波的斜坡

CJNE R0,#255,K10 ;RO不等于255,循环锯齿波的每个值

LJMP SAW ;等于255,完成一个锯齿波周期,回锯齿波开始

TC1: RET ;退出

TRI: JNB P10,N7 ;三角波,类似于两个相反的锯齿波

JNB P11,N8

JNB P13,N9

LJMP TTRI

N7: MOV R7,#00H

LJMP TC2

N8: MOV R7,#01H

LJMP TC2

N9: MOV R7,#03H

LJMP TC2

TTRI: CJNE R7,#02H,TC2

MOV R0,#00H

MOV DPTR,#7FFFH

K20: MOV A,R0

MOVX @DPTR,A

MOV P0,R0

MOV P2,#0FFH

MOV A,P2

CPL A

MOV R3,A

L20: DEC R3

CJNE R3,#255,L20

INC R0

INC R0

CJNE R0,#254,K20

K21: MOV A,R0

MOVX @DPTR,A

MOV P0,R0

MOV P2,#0FFH

MOV A,P2

CPL A

MOV R3,A

L21: DEC R3

CJNE R3,#255,L21

DEC R0

DEC R0

CJNE R0,#0,K21

LJMP TRI

TC2: RET

SIN: JNB P10,N10 ;正弦波,是通过存储在代码区的一个数

JNB P11,N11 ;组来显示值的

JNB P12,N12

LJMP SSIN

N10: MOV R7,#00H

LJMP TC3

N11: MOV R7,#01H

LJMP TC3

N12: MOV R7,#02H

LJMP TC3

SSIN: CJNE R7,#03H,TC3

MOV R0,#00H

MOV DPTR,#7FFFH

K30: MOV A,R0

MOV DPTR,#TAB ;数组的地址

MOVC A,@A+DPTR ;把第R0个数放到A中

MOV DPTR,#7FFFH

MOVX @DPTR,A ;输出A

MOV P0,A

INC R0 ;RO加1

MOV P2,#0FFH ;周期

MOV A,P2

CPL A

MOV R3,A

L30: DEC R3

CJNE R3,#255,L30

CJNE R0,#255,K30 ;不等于255表示一个周期内,跳到K30

LJMP SIN ;等于表示显示完一个周期,到SIN开始

TC3: RET ;退出

TAB: DB ;定义正弦函数的各个值

看了你的图和你的程序,感觉你的图画得简单了一点,特别是0832地址,控制信号都没接,看起来还在调试,建议P2口做地址总线,这样,编程比较方便,你可以把P3口做周期或者把P1口的其他口做控制总线,这样要对0832时序比较熟悉才行

我平时是用C开发的,很少用汇编,如果有什么错误,可以共同探讨

给你看下程序吧,C语音: if(state==1)//正弦波

{for(k=0;k<100;)

{

if(P1!=0xf0)

{ sweep();}

if(FLAG==1)

{out=sin[k];

FLAG=0;

//P2_4=0;

//delay(255);

P0=out;

k++; }

} }

else if(state==2) //三角波

{for(k=0;k<100;)

{

if(P1!=0xf0)

{ sweep();}

if(FLAG==1)

{out=shn[k];

FLAG=0;

//P2_4=0;

//delay(255);

P0=out;

k++; }

} }

else if(state==3) //方波

{for(k=0;k<100;)

{

if(P1!=0xf0)

{ sweep();}

if(FLAG==1)

{out=fan[k];

FLAG=0;

//P2_4=0;

//delay(255);

P0=out;

k++; }

} }

1、持续短路通常会发热吧。LDO应该保护才对,首先取下出33V的LDO。

2、测试板子是否短路依旧。有短路情况,除149外,取下功率部分电路元件。正常情况芯片一般不会轻易短路,即使发生了也应该会烧毁开路。

3、换上新的LDO。

以上就是关于msp 430 pwm怎么控制全部的内容,包括:msp 430 pwm怎么控制、MSP430F149超声波测距C语言编程,距离小于1M则用蜂鸣器发出警报,距离越近,蜂鸣器声响越高。。求程序、信号生成和波形生成等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zz/10137699.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-05
下一篇2023-05-05

发表评论

登录后才能评论

评论列表(0条)

    保存