![]() |
Chương trình đèn giao thông tại sao bạn NHN lại tốn nhiều chân để điều khiển 2 led 7 thanh thế nhỉ? Sao bạn không dùng phương pháp quét led để quét 2 led này. Khi đó dùng 7 chânPORTD (a->g) và thêm 2 chân điều khiển nữa như vậy chỉ mất có 9 chân tất cả. Như vậy tiết kiệm các chân hơn.
Thực tế đèn giao thông này là rất đơn giản. Bạn có thể phát triển thành sơ đồ đền giao thông hiện đại mới trong thực tế không? Đứng ở ngã tư một lúc xem thế nào :D. Bạn đưa ra mô hình đi mình lập trình bằng HTPIC xem thế nào. Vì làm bằng ASM đúng là mình mệt lắm:D. chúc mọi người thành công. |
Cảm ơn ngohaibac!
Ban đầu mình cũng nghĩ ghép chung dữ liệu cho hai led 7 seg,làm như vậy thì khi viết chương trình quét led có hơi phức tạp hơn một chút.Chương trình này mình dùng để tìm hiểu ngắt timer0 thôi chứ ko có ý định tiết kiệm chân VDK.:D ngohaibac cứ mắc mạch như ntc: Trích:
Chào! |
Trích:
Hy vọng sớm hoàn thành!:D Chào! |
Mình đã viết chương trình quét 4 led 7 thanh rùi bằng HTPIC. Tại luồng này bên dientuvietnam.net. xin mời các bạn cho ý kiến về giải thuật và cấu trúc:
http://dientuvietnam.net/forums/show...6&page=1&pp=10 Mình quen về lập trình bằng C nên có vấn đề gì về các câu lệnh về C thì các bạn cứ hỏi. Còn về ASM thì chào thua. Không dám lập trình vì dài lắm, khó chữa lỗi. chúc các bạn thành công. |
Còn về chú ý mà ntc nói thì đúng rồi. Nhưng mình hoàn toàn có thể làm được 2 công việc một lúc là vừa quét led vừa làm đầu vào Analog được. Điều này đã được nói trong App Note của bọn Microchip rồi.
Tài liệu AP557d: http://ww1.microchip.com/downloads/e...tes/00557d.pdf Bọn này chỉ dùng có con 16C71 với 18 chân mà làm được khối việc. Anh BA đã nói đến trong bài một số kiểu tiết kiệm chân vđk rồi tại luồng http://dientuvietnam.net/forums/showthread.php?t=5 Đây là hình vẽ minh họa: http://i36.photobucket.com/albums/e4.../PVN_00015.gif Các bạn thấy thế nào. Mình nghĩ là nên lập một luồng để đưa lại các App Note của bọn Microchip để mọi người cùng học tập thì chắc chắn là hay hơn nhiêu. Vì bọn nó có nhiều chú ý về các vấn đề như I/O, về display led, LCD, PID, ... Các bạn thấy thế nào? |
Trích:
|
Các bác cho em hỏi một tí:tại sao người ta phải sử dụng đến 10bit phân giải
CCPR1L:CCP1CON<5:4> để làm gì, mà không dùng 8 bit CCPR1L thôi? À, còn cái này nữa. Nếu như dùng 10bit như thế thì làm thế nào để thay đổi giá trị đặt vào chúng(mục đích của em là dùng cái thằng PWM module tạo ra xung thay đổi liên tục) Bác nào có thể giúp em tí không? thank các bác nhiều! |
em có đoạn chương trình này!
// Period of square-wave (chu kì của một sóng vuông)
/*Variables for capture and interrupt*/ static volatile bit flag=0; static volatile unsigned int t1=0,t2=0; void capture_setup(void) { CCPR1L=0; CCPR1H=0; //Clear capture registers TMR1H=0; TMR1L=0; //Clear timer1 registers CCP1CON = 0b00000111; //Capture every 16th rising edge on CCP1(RC2) T1CON = 0b00100101; //Configure Timer1 module in timer mode with 1:4 prescale and start Timer1 CCP1IE=1; //Enable CCP interrupts TMR1IE=0; //Disable Timer1 interrupts PEIE=1; GIE=1; //Enable global interrupts } static void t1func(void) { t1=CCPR1L; t1+=(CCPR1H << 8); } static void t2func(void) { t2=CCPR1L; t2+=(CCPR1H << 8); t2-=t1; } static void interrupt isr(void) { if (CCP1IF && CCP1IE) //Clock line every 16th rising edge on CCP1IF, RC2, pin 13 on micro { CCP1IF=0; if(flag==1) //Save value to t1 on every even interrupt { t1func(); flag = 0; } else //Save value to t2 on every odd interrupt { t2func(); flag = 1; } } } Nhà mình có bác nào dảnh thì giải thích giúp em cái này cái: :D static volatile bit flag=0; static volatile unsigned int t1=0,t2=0; Khai báo biến kiểu này là kiểu gì thế? |
To Pb1!
Bạn đang tìm hiểu về module PWM,đây là một module cùng với ADC,...được sử dụng rất nhiều.Rất hoanh nghênh bạn nhưng trong luồng này mọi người thảo luận bằng ASM.Pb1 nên mở hẳn một luồng bàn về vấn đề này nhưng phải ở mục các ngôn ngữ lập trình khác CCS C, HTPIC,.. Tớ sẽ ủng hộ cậu mở luồng mới! |
Digital clock
Ý tưởng viết chương trình cho cái này như sau:
Các chân a > g của led 7 đoạn nối chung dữ liệu và nối đến PortD ,các chân cathode nối đến PortB,... > Khởi tạo các chân I/O,ngắt TMR0 1s > Quét 6 LED,kiểm tra có bật Switch chỉnh thời gian?Nếu có thì tắt ngắt toàn cục,chỉnh xong set cờ GIE và quay lại quét LED,chờ ngắt Khi có ngắt > Tăng đếm LED1 lên 1,kiểm tra xem > 9 ?Chưa thì thoát ngắt,rồi thì xóa đếm LED1 về 0,tăng đếm LED2 thêm 1 > Kiểm tra đếm LED2 >6 ?Chưa thì thoát ngắt,rồi thì xóa đếm LED2 về 0,tăng đếm LED2 thêm 1 > Tiếp cho LED3,4,5 > Kiểm tra đếm LED6 = 2 & đếm LED5 > 4 ?Chưa thì thoát ngắt,rồi thì xóa đếm LED5,6 và thoát ngắt. Viết như thế này thì hơi rắc rối và phức tạp,vừa dài,vừa dai lại vừa dở,quá nhiều nhược điểm luôn: 1.Do call,ngắt,...nếu không cẩn thận khi vào ngắt dễ bị tràn Stack thì đi tong ngay (Ban đầu mình mô phỏng Pro thì toàn hiện 0,coi lại code mờ mắt mà không phát hiện sai ở đâu cả,nhảy sang dùng PIC Sim thì bị báo tràn Stack ầm ầm luôn!Pó tay!) 2.Ngắt TMR0 bên trên chỉ rất rất gần 1s,có thể âm thầm dùng delay bù vào ở giây 60,nhưng do làm biếng tính,mình no bù! 3.Cẩn thận với ORG dành cho dữ liệu bảng,khi chương trình dài có thể chồng dữ liệu lên vùng này thì cũng đi tong luôn 4.Khi dùng bảng tra dài hơn 255,bảng đặt ở 2 page khác nhau,...cần thay đổi cách tra,cụ thể nên xem trong tutorial Kỹ thuật bảng. He he...!Đồng hồ thời gian thực chẳng ma nào dại mà làm như thế này cả....Chỉ mỗi cái này mà loạn cả lên thì qua mấy cái module phức tạp khác,chắc ngủm khi viết bằng ASM quá! Trên đây là những gì mình vot được, mod Chính ý kiến thế nào?Chia sẻ kinh nghiệm cho bà con tí ! |
Code:
;======================================== |
Code:
:020000040000FA |
nhh ơi, bạn gửi file .hex thì nên gửi bằng cách gửi kèm file, nhìn phía bên dưới khi bạn viết bài trả lời á, phần Chức Năng, có mục Tải file từ máy. Lúc đó bạn tải file .hex lên, hoặc tải file .zip lên, như vậy sẽ thuận tiện hơn cho người đọc.
Chúc vui. |
Trích:
Kiểu dữ liệu volatile được dùng để báo cho trình dịch biết rằng đối tượng được khai báo kiểu volatile có thể không cần lưu trữ lại giá trị giữa các lần truy cập liên tiếp. Điều đó làm cho chương trình có sự tối ưu hoá từ việc là những dư thừa rõ ràng đang được loại ra khi sử dụng một đối tượng có kiểu volatile bởi ví đối tượng đó có thể thay đổi tuỳ theo chương trình hoạt động như thế nào. Tất cả các port I/O và tất cả các biến mà bị thay đổi giá trị trong trình phục vụ ngắt nên khai báo kiểu volatile. Ví dụ: Code:
volatile static near unsigned char PORTA @ 0xF80; Kết luận: như vậy là khai báo volatile được dùng với biến phải sử dụng liên tục. Khi khai báo như thế thì tiết kiệm được địa chỉ của RAM. Khi các bạn mở các file include ra sẽ thấy được rằng bọn nó khai báo địa chỉ cho các port đều theo kiểu này :D |
hehe, làm ăn phải như thế chứ :D
cảm ơn bác Bắc nhé, em hiểu rùi |
Múi giờ GMT. Hiện tại là 01:03 PM. |
Tên diễn đàn: vBulletin Version 3.8.11
Được sáng lập bởi Đoàn Hiệp.
Copyright © PIC Vietnam