我知道互联网上有很多例子,但什么需要这些代码才能工作?
频率振荡器=4mhz
周期=0.25us
duty_cicle=250
预缩放=16
PR2=124
#include <xc.h>
#include <stdio.h>
#include <stdlib.h>
#include <pic16f88.h>
#pragma config FOSC = HS // Oscillator Selection bits (INTOSC oscillator: I/O function on RA6/OSC2/CLKOUT pin, I/O function on RA7/OSC1/CLKIN)
#pragma config WDTE = OFF // Watchdog Timer Enable bit (WDT disabled)
#pragma config PWRTE = OFF // Power-up Timer Enable bit (PWRT disabled)
#pragma config MCLRE = OFF // RA5/MCLR/VPP Pin Function Select bit (RA5/MCLR/VPP pin function is digital input, MCLR internally tied to VDD)
#pragma config BOREN = ON // Brown-out Detect Enable bit (BOD enabled)
#pragma config LVP = OFF // Low-Voltage Programming Enable bit (RB4/PGM pin has digital I/O function, HV on MCLR must be used for programming)
#pragma config CPD = OFF // Data EE Memory Code Protection bit (Data memory code protection off)
#pragma config CP = OFF // Flash Program Memory Code Protection bit (Code protection off)
void main ()
{
while (1)
{
CCP1CON = 0x2C; /*activate PWM mode*/
PR2 = 0x7C; /*124 (DECIMAL)*/
T2CON = 0X06; /*prescale 16 */
CCPR1L = 0X3E;
}
}
我想看看:
PWM周期=2ms
Dutyicle=1ms
SincerillyNIN
第一个主题:不包括pic16f88.h,它由xc.h包含。
稍微偏离主题:如果您使用更现代的零件(例如PIC16f1619),您可以使用MPLAB代码配置程序为您生成TMR2和CCP代码。它的成本也会更低,并且有更多的闪存/内存。这个设备在好奇心板上(20美元)。
主题:您的第一站是数据表。
PWM部分具有PWM操作的设置。
第1步:计时器2将Fosc/4作为输入,在您的情况下为1mhz。目标频率为500Hz。1e6/500=2k。我建议预分频器为16,pr值为125。这将给你精确的500Hz。
第2步:我们想要50%的工作循环。CCP1L层(125/2)=62。CCP1X:CCP1Y=0.5*4=2。
步骤3:清除tris位。
第4步和第5步:打开
// Step 1
TMR2ON = 0;
TOUTPS = 0;
T2CKPS = 2;
PR2 = 250U;
// Step 2
CCP1L = 62U;
CCP1X = 1;
CCP1Y = 0;
// Step 3
TRISB3 = 0;
// Step 4
TMR2ON = 1;
// Step 5
CCP1M = 0xC;
希望能有所帮助。
数据表显示:
在脉宽调制(PWM)模式下,CCP1引脚产生高达10位分辨率的PWM输出。自从CCP1引脚与PORTB数据锁存器多路复用,必须清除TRISB位以使CCP1引脚输出。
因此,您必须设置CCP1引脚的TRIS位以输出:
TRISB &= ~(1 << 3); //Clear bit RB3/CCP1 in TRISB, makes PORTB3/CCP1 output.
这假设配置字中的CCPMX: CCP1 Pin Selection bit
是清楚的。如果设置了,那么CCP1在RB0而不是RB3上,但由于我在您的配置pragma中没有提到CCPMX,我认为它已被清除。