① 半橋全橋驅動電路的作用是什麼
半橋全橋的驅動電路是使功率管產生交流電的觸發信號,並不是將交流信號變直流信號。即使單片機可以輸出直流信號,但是它的驅動能力也是有限的,所以單片機一般做驅動信號,驅動大的功率管,來產生大電流從而才能驅動電機。
② 如何用3.3V單片機驅動mos管
用三極體不如用ULN2803,一個ULN2803可以驅動8隻MOS管。沒有其他電路。 直接可以連接,簡單方便。 做H橋的話,可以控制2路,如果只控制一路,也可以用ULN2003.
補充:你肯定沒有看這兩個IC,輸出12V沒有問題,最高輸出電壓50V,最高輸出電流500mA,內部集成了續流二極體,基極電阻。直接上一個片子即可。其實這個片子裡面就是集成的達林頓管,和用三極體是一樣的道理。 可靠性比分立元件高。
③ 用AVR單片機Atmega16產生兩路互補的PWM波去控制全橋逆變電路的程序
#include <avr/io.h>
void main(void)
{
PORTB=0x00;
DDRB=0x0E;
// T/C1 初始化
TCCR1A=0xA1;
TCCR1B=0x09; //匹配時清零,TOP:255,頻率:8M/256=31.25K
OCR1A=85; //占空比:1/3
OCR1B=128; //占空比:1/2
// T/C2 初始化
TCCR2=0x69; /則察碧/匹配時清零,沒棚TOP:255,頻率:31.25K
OCR2=170; //占空比:2/3
while (1);
}
使用M16產生三路PWM的程序,參考一下基本OK
還有個是可調節的PWM程序,我做過模擬了,需要全部留下郵箱傳給你;
/*****************************************************
#define KEY PINC.0
#define PWMA PORTB.3 //17號腳孫舉
#define PWMB PORTB.4 //18號腳
#include <mega8.h>
#include <delay.h>
#include <math.h>
unsigned int m=0;
unsigned char xiangxian=0;
bit INIT2=0; //判斷是否象限2已經初始化;
bit INIT3=0;
bit INIT4=0;
/*下面為四個象限中處理函數,參數為45度平分為255段角度*/
inline panan()
{
if(m<=255)
{
xiangxian=1;
}
else if((m>255)&&(m<511))
{
xiangxian=2;
if(m==256)
{
INIT2=1;
PWMA=0;
OCR1A=0x00;
OCR1B=0xff;
PWMB=1;
}
}
else if((m>=511)&&(m<767))
{
xiangxian=3;
}
else if((m>=767)&&(m<1024))
{
xiangxian=4;
}
else if(m>1024)
{
m=0;
}
}
void xiangxian1(unsigned char degree)
{
PWMA=0;
PWMB=0;
OCR1BL=m;
OCR1AL=255-m;
}
void xiangxian2(unsigned char degree)
{ unsigned char temp;
temp=m-255;
OCR1AL=temp;
OCR1BL=temp;
}
void xiangxian3(unsigned char degree)
{
unsigned char temp;
temp=m-511;
PWMA=1;
PWMB=1;
OCR1BL=255-temp;
OCR1AL=temp;
}
void xiangxian4(unsigned char degree)
{unsigned char temp=0;
temp=m-767;
PWMA=1;
PWMB=0;
OCR1BL=255-temp;
OCR1AL=255-temp;
}
/*角度計算函數,負責計算在各個象限中角度對應的PWM輸出*/
void SET_ANGLE( unsigned char degree)
{
switch (xiangxian)
{
case 1: xiangxian1(degree);break;
case 2: xiangxian2(degree);break;
case 3: xiangxian3(degree);break;
case 4: xiangxian4(degree);break;
default:break;
}
}
void main(void)
{
unsigned char temp;
unsigned char xiangxian=0;
// Declare your local variables here
PORTB=0x187;
DDRB=0x1e;
// Port C initialization
// Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State6=T State5=T State4=T State3=T State2=T State1=T State0=P
PORTC=0x01;
DDRC=0x00;
// Port D initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=Out Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=0 State1=T State0=T
PORTD=0x00;
DDRD=0x04;
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
TCCR0=0x00;
TCNT0=0x00;
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: 1000.000 kHz
// Mode: Fast PWM top=01FFh
// OC1A output: Inverted
// OC1B output: Inverted
// Noise Canceler: Off
// Input Capture on Falling Edge
// Timer 1 Overflow Interrupt: Off
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
TCCR1A=0xF1;
TCCR1B=0x01;
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
// Timer/Counter 2 initialization
// Clock source: System Clock
// Clock value: Timer 2 Stopped
// Mode: Normal top=FFh
// OC2 output: Disconnected
ASSR=0x00;
TCCR2=0x00;
TCNT2=0x00;
OCR2=0x00;
// External Interrupt(s) initialization
// INT0: Off
// INT1: Off
MCUCR=0x00;
// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x00;
// Analog Comparator initialization
// Analog Comparator: Off
// Analog Comparator Input Capture by Timer/Counter 1: Off
ACSR=0x80;
SFIOR=0x00;
PWMA=0;
PWMB=0;
OCR1AL=0xff;
OCR1BL=0x00;
while (1)
{
if(KEY==0)
{
delay_ms(20);
if(KEY==0)
{
m=m+1;
panan();
SET_ANGLE(m);
PORTD.2=!PORTD.2;
}
}
};
}