Nhập môn đệ tử
Tham gia ngày: Feb 2014
Bài gửi: 2
:
|
mọi người có ai lập trình tạo sin PWM cho pic 18f4431 chưa giậy? chỉ mình sai chổ nào trog code này đi. mình sửa mãi mà không chạy. trong đồ án nghịch lưu 3 pha... ;(((
code mình:
#include<htc.h>
//#include<stdio.h>
#include<math.h>
__CONFIG(1,HS);//HS
__CONFIG(2,WDTWINDIS);
__CONFIG(3,MCLREN,PWM4RB5,PWRTDIS);
__CONFIG(4,LVPDIS,STVRDIS,BORDIS);
#define _XTAL_FREQ 20000000
float Ta,Tb,To,U,V,W;
char sector;
unsigned int i,j;
unsigned int data[300]={0,40,81,121,161,202,242,282,322,363,403,443,
484,524,564,604,645,685,725,765,805,846,886,926,96 6,1006,1047,1087,1127,
1167,1207,1247,1287,1327,1367,1407,1447,1487,1527, 1567,1607,1647,1687,
1727,1767,1806,1846,1886,1926,1965,2005,2045,2084, 2124,2164,2203,2243,
2282,2322,2361,2401,2440,2480,2519,2558,2598,2637, 2676,2715,2754,2793,
2833,2872,2911,2950,2989,3027,3066,3105,3144,3183, 3222,3260,3299,3337,3376,
3415,3453,3491,3530,3568,3607,3645,3683,3721,3759, 3797,3835,3873,3911,3949,
3987,4025,4063,4100,4138,4176,4213,4251,4288,4326, 4363,4400,4437,4475,4512,
4549,4586,4623,4660,4697,4733,4770,4807,4843,4880, 4916,4953,4989,5026,5062,
5098,5134,5170,5206,5242,5278,5314,5350,5385,5421, 5457,5492,5527,5563,5598,
5633,5668,5704,5739,5774,5808,5843,5878,5913,5947, 5982,6016,6050,6085,
6119,6153,6187,6221,6255,6289,6323,6356,6390,6424, 6457,6490,6524,6557,6590,
6623,6656,6689,6722,6755,6787,6820,6852,6885,6917, 6949,6981,7013,7045,7077,
7109,7141,7172,7204,7235,7267,7298,7329,7360,7391, 7422,7453,7484,7514,
7545,7576,7606,7636,7666,7696,7726,7756,7786,7816, 7846,7875,7904,7934,7963,
7992,8021,8050,8079,8108,8136,8165,8193,8222,8250, 8278,8306,8334,8362,8390,
8417,8445,8472,8500,8527,8554,8581,8608,8635,8662, 8688,8715,8741,8767,8793,
8820,8846,8871,8897,8923,8948,8974,8999,9024,9049, 9074,9099,9124,9149,9173,
9198,9222,9246,9270,9294,9318,9342,9365,9389,9412, 9436,9459,9482,9505,9528,
9550,9573,9595,9618,9640,9662,9684,9706,9728,9749, 9771,9792,9814,9835,
9856,9877,9898,9918,9939,9959,9980};
/*unsigned int data[300]={127, 130, 132, 135, 138, 140, 143, 146, 148, 151, 153, 156,
159, 161, 164, 166, 169, 171, 174, 176, 179, 181, 183, 186, 188, 191, 193, 195, 197, 199, 202, 204, 206, 208, 210, 212, 214,
216, 218, 220, 221, 223, 225, 227, 228, 230, 231, 233, 234, 236, 237, 238, 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 249,
250, 251, 251, 252, 252, 253, 253, 253, 254, 254, 254, 254, 254, 254, 254, 254, 254, 253, 253, 253, 252, 252, 251, 251, 250, 249, 249,
248, 247, 246, 245, 244, 243, 242, 241, 240, 238, 237, 236, 234, 233, 231, 230, 228, 227, 225, 223, 221, 220, 218, 216, 214, 212, 210,
208, 206, 204, 202, 199, 197, 195, 193, 191, 188, 186, 183, 181, 179, 176, 174, 171, 169, 166, 164, 161, 159, 156, 153, 151, 148, 146,
143, 140, 138, 135, 132, 130, 127, 124, 122, 119, 116, 114, 111, 108, 106, 103, 101, 98, 95, 93, 90, 88, 85, 83, 80, 78, 75, 73, 71, 68,
66, 63, 61, 59, 57, 55, 52, 50, 48, 46, 44, 42, 40, 38, 36, 34, 33, 31, 29, 27, 26, 24, 23, 21, 20, 18, 17, 16, 14, 13, 12, 11, 10,9,8,7,6,
5,5,4,3,3,2, 2, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 2, 2, 3, 3, 4, 5, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 16, 17, 18, 20, 21, 23, 24, 26, 27, 29,
31, 33, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 55, 57, 59, 61, 63, 66, 68, 71, 73, 75, 78, 80, 83, 85, 88,
90, 93, 95, 98, 101, 103, 106, 108, 111, 114, 116, 119, 122, 124};*/
void main()
{
char m=0;
i=sector=0;
//khoi tao PWM tan so 5KHz, => T = 0.0002(s)
PTCKPS1= 0; PTCKPS0=0; // bo chia 1:1--------------------------------------
PTMOD1=1; PTMOD0 =0; // continuos up/down counting
PTEN =1; // PWM time base on
PWMEN2 = 1; PWMEN1 = PWMEN0 =0; // dung cac chan PWM0--5
PMOD0 = PMOD1 = PMOD2 = 1; // independent : chay doc lap
// complementary : chay bu tru nhau
SEVOPS3 = SEVOPS2 = SEVOPS1 = SEVOPS0 =0; // các bit co dãn ngõ ra PWM dac biet. : 1-1
//-------------------------------------------------------------
//tan so PWM 5KHz -> T = 1/5000 = 0.0002(s)
/*(PTPER.4+1).4.Pre/Fosc=1/T
=> (PTPER.4+1).4.Pre = 4000
chon Pre = 1.
=> PTPER = 250.
PTPER = PTPERH.256 + PTPERL
=> PTPERH = 0 , PTPERL =250
Ts = PTPER*4
*/
PTPERH =0; PTPERL =250;
// dead time 1us
DTCON = 0b00000001;
// interrupt PWM
PTIE =1; PTIF = 0; IPEN = 1; GIE = 1;
LATB6 =1; RB6 =1;
while(1)
{}
}
void interrupt ngat()
{
if(PTIF)
{
Ta=50.0*data[299-i]/150.0;
Tb=50.0*data[i]/150.0;
To=(250-Ta-Tb)/2.0;
i=i+3;
if(i>=300)
{
i=0;
sector++;
if(sector>6)
sector=1;
}
switch(sector)
{
case 1:
U= To;
V=To+Ta;
W=250-To;
RD0=1;
break;
case 2:
U= To+Tb;
V=To;
W=250-To;
RD0=0;
break;
case 3:
U= 250-To;
V=To;
W=To+Ta;
RD0=1;
break;
case 4:
U= 250-To;
V=To+Tb;
W=To;
RD0=0;
break;
case 5:
U= To+Ta;
V=250-To;
W=To;
RD0=1;
break;
case 6:
U= To;
V=250-To;
W=To+Tb;
RD0=0;
break;
}
PDC0H=(char)(U/256.0);PDC0L=(char)(U-PDC0H*256.0);
PDC1H=(char)(V/256.0);PDC1L=(char)(V-PDC1H*256.0);
PDC2H=(char)(W/256.0);PDC2L=(char)(W-PDC2H*256.0);
PTIF=0;
}
}
|