我知道互联网上有很多例子,但是这个代码需要做些什么呢?
频率振荡器= 4mhz
periode = 0.25us
duty_cicle = 250
Prescale = 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
Dutycicle = 1ms
Sincerilly NIN
答案 0 :(得分:1)
首先是主题: 不包括pic16f88.h,它包含在xc.h中。
主题更多: 如果使用更现代的部件(例如PIC16f1619),则可以使用MPLAB代码配置器为您生成TMR2和CCP代码。它也会花费更少,闪存/内存更多。该设备位于curiosity board($ 20)。
关于主题: 您的第一站是datasheet。
PWM部分有setup for PWM operation。
步骤1: timer 2将Fosc / 4作为输入,在您的情况下为1mhz。 目标频率为500Hz。 1e6 / 500 = 2k。 我建议预分频器为16,pr值为125.这将给你正好500Hz。
步骤2: 我们想要50%的工作周期。 CCP1L floor(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;
希望有所帮助。
答案 1 :(得分:0)
数据表说明:
在脉冲宽度调制(PWM)模式下,CCP1引脚 产生高达10位分辨率的PWM输出。以来 CCP1引脚与PORTB数据锁存器复用, 必须清零TRISB位才能产生CCP1 固定输出。
因此必须将CCP1引脚的TRIS位置1:
if
这假定配置字中的temp <- data.frame(temp)
是明确的。如果置位,则CCP1在RB0上而不是RB3,但由于我没有在配置编译中提及CCPMX,我认为它已被清除。