1

我知道互联网上有很多例子,但是这段代码需要什么才能工作?

频率振荡器 = 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

任务周期 = 1ms

真诚的宁

4

2 回答 2

1

第一个主题:不要包含 pic16f88.h,它包含在 xc.h 中。

离题一点:如果您使用更现代的部件(例如PIC16f1619),您可以使用 MPLAB 代码配置器为您生成 TMR2 和 CCP 代码。它的成本也会更低,并且拥有更多的闪存/内存。该设备在好奇心板上(20 美元)。

主题:您的第一站是数据表

PWM 部分具有PWM 操作设置

Step1:定时器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;

希望有帮助。

于 2016-05-23T18:14:59.410 回答
0

数据表指出:

在脉宽调制 (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 上,但由于我在您的配置编译指示中没有看到 CCPMX,我认为它已被清除。

于 2016-05-06T18:18:32.643 回答