Thông báo

Collapse
No announcement yet.

Tạo xung SIN PWM bằng ATMEGA 16 thông qua ngắt timer 1

Collapse
X
 
  • Lọc
  • Giờ
  • Show
Clear All
new posts

  • Tạo xung SIN PWM bằng ATMEGA 16 thông qua ngắt timer 1

    Chào các bác!
    Em đang viết chương trình tạo xung sin PWM tần số hài cơ bản 50Hz, tần số sóng mang 20kHz
    + nửa chu kỳ đầu tạo xung pwm cho chân 19, chân 18 = 0
    + nửa chu kỳ sau tạo xung pwm cho chân 18, chân 19 = 0
    Các thông số cài đặt cho các chân và thanh ghi
    chân 19: ngõ ra không đảo - Fast PWM - chế độ 14
    chân 18: ngõ ra không đảo - Fast PWM - chế độ 14
    thanh ghi ICR1=800
    Các bác xem giúp code của em bị gì nha.

    Code:
    #include <mega16.h>
    #define suon      PORTB.4 //suon=0/1 thi ham sin dang o suon trai/phai
    #define led_1     PORTB.5
    #define led_2     PORTB.6
    #define led_3     PORTB.7
                                      
    unsigned int index=0;
    unsigned int sin[201]={
    800, 800, 800, 800, 799, 799, 798, 798, 797, 796, 795, 794,
    793, 792, 790, 789, 787, 786, 784, 782, 780, 778, 776, 774,
    772, 770, 767, 765, 762, 759, 756, 754, 751, 747, 744, 741,
    738, 734, 731, 727, 724, 720, 716, 712, 708, 704, 700, 696,
    692, 687, 683, 678, 674, 669, 665, 660, 655, 650, 645, 640,
    635, 630, 625, 620, 614, 609, 604, 598, 593, 587, 582, 576,
    570, 565, 559, 553, 547, 541, 535, 530, 524, 518, 512, 506,
    499, 493, 487, 481, 475, 469, 463, 456, 450, 444, 438, 431,
    425, 419, 413, 406, 400, 394, 387, 381, 375, 369, 362, 356,
    350, 344, 337, 331, 325, 319, 313, 307, 301, 294, 288, 282,
    276, 270, 265, 259, 253, 247, 241, 235, 230, 224, 218, 213,
    207, 202, 196, 191, 186, 180, 175, 170, 165, 160, 155, 150,
    145, 140, 135, 131, 126, 122, 117, 113, 108, 104, 100, 96,
    92, 88, 84, 80, 76, 73, 69, 66, 62, 59, 56, 53, 49, 46, 44,
    41, 38, 35, 33, 30, 28, 26, 24, 22, 20, 18, 16, 14, 13, 11,
    10, 8, 7, 6, 5, 4, 3, 2, 2, 1, 1, 0, 0, 0, 0
    };
    // bảng sin của một nửa chu kỳ
    
    interrupt [TIM1_COMPA] void timer1_compa_isr(void)
    {
    if (index==0)
    {
    suon=1;
    };
    if (suon==1)
    {
    OCR1A=sin[index];
    index++;
    }
    else
    {
    OCR1A=sin[index];
    index--;
    };
    
    }
    interrupt [TIM1_COMPB] void timer1_compb_isr(void)
    {
    if (index==201)
    {
    suon=0;
    };
    if (suon==1)
    {
    OCR1B=sin[index];
    index++;
    }
    else
    {
    OCR1B=sin[index];
    index--;
    };
    }
    
    void main(void)
    
    {
    
    // Port B initialization
    // Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In 
    // State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T 
    PORTB=0x00;
    DDRB=0xFF;
    
    // Port D initialization
    // Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In 
    // State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T 
    PORTD=0x00;
    DDRD=0x30;
    index=0;
    led_1=1;
    suon=1;
    TCCR1B=(1<<4)|(1<<3)|(1<<0);// WGM13=1, WGM12=1, CS10=1
    OCR1A=sin[index];
    OCR1B=sin[index];
    TCNT1H=0x00;
    TCNT1L=0x00;
    ICR1H=0x03;
    ICR1L=0x20;// nap 800 vao thanh ghi ICR1
    #asm ("sei")
    while (1)
          {
          if (index<=100)
          {
           led_2=1;
           led_3=0;
           TCCR1A=0x32;
           TIMSK=(0<<4)|(1<<3);//cho phep ngat khi match xay ra khi so sanh OCR1B voi TCNT1 
          }
          else
          {
           led_2=0;
           led_3=1;
           TCCR1A=0x82;
           TIMSK=(1<<4)|(0<<3);//cho phep ngat khi match xay ra khi so sanh OCR1A voi TCNT1 
          } 
          };
    };
    Nhân tiện bác nào có tài liệu (công thức tính toán) mạch lọc LC cho em xin nha.
    Bất kỳ sự giúp đỡ nào của các bác em xin chân thành cảm ơn!!!
    Thân ái.

  • #2
    tính toán tự động cho mạch lọc LC
    http://circuitcalculator.com/lcfilter.htm

    b.r

    Comment


    • #3
      cho mình hỏi:
      nếu đưa ra giá trị cho IC DAC 12bit thì sao??
      tạo ngay sóng hình sin 50Hz í. ra DAC rồi cần những yêu cầu gì nữa để đạt sóng sin chuẩn?? vì khi ra DAC cũng chỉ là dạng điện áp trích mẫu, chưa phải liên tục.
      Last edited by dinh vy; 03-12-2014, 11:24.

      Comment


      • #4
        cái này bạn làm mạch thực tế chưa hồi sinh viên mình cũng ý tưởng như bạn mục đích làm cho thiết bị ko nóng nhưng....

        Comment

        Về tác giả

        Collapse

        physik Tìm hiểu thêm về physik

        Bài viết mới nhất

        Collapse

        • bqviet
          Trả lời cho Đấu tắt điện cho máy tính bảng
          bởi bqviet
          Bqv cáo lỗi vì chưa đủ khả năng diễn giải để người đọc hiểu. Người làm kỹ thuật sâu đôi khi như thế đó. Về việc nạp pin không vào dù cell mới, khả năng cái mạch quản lý đó đã hỏng - cũng chính là nguyên nhân đám cell cũ hỏng từ đầu.
          06-12-2025, 17:17
        • nguyendinhvan
          Trả lời cho Xin hỏi về mạch thu FM/AM trong catsette
          bởi nguyendinhvan
          Theo tôi, nó chỉ là cái Tuy- ê - nơ, hoặc là khối Trung Văn Tần, nó một phần trong cái Da đì ô thôi. Vì có thấy một chỗ có ba chân hàn, giiống như chân Cờ rít sờ tăng 455 ki nô hẹc. Còn khối Tuy ê nơ thì không nhìn thây cái Di ốt Va di cáp...
          05-12-2025, 19:59
        • afrendly
          Trả lời cho Đấu tắt điện cho máy tính bảng
          bởi afrendly
          Có vẻ ngoài hiểu biết của mình rồi. Cuối cùng mình quyết định tìm mua 2 pin trên Shopee, giá 200K thay vào. Tuy nhận pin được 1%, sạc mãi không vào nhưng cũng mở được máy lên. Vậy cũng tạm. Cảm ơn bạn đã hỗ trợ nhé....
          04-12-2025, 01:27
        • nick22
          Trả lời cho Máy điện châm ?
          bởi nick22
          Đúng như bạn nói, máy điện châm hiện nay trên thị trường đã khá đa dạng về mẫu mã, chức năng và giá thành.
          01-12-2025, 13:23
        Đang tải...
        X