Điều khiển tốc độ động cơ điện một chiều

Chương 1: Động cơ điện một chiều 1

1.1. Giới thiệu chương 1

1.2. Nội dung 1

1.2.1 Giới thiệu động cơ DC 1

1.2.2 Mô hình hóa động cơ DC 1

1.2.3 Phương pháp điều khiển tốc độ động cơ: 3

1.2.4 Khảo sát hàm truyền 4

1.2.4.1 Hàm truyền lý tưởng: 4

1.2.4.2 Hàm truyền gần đúng tìm được bằng thực nghiệm 5

1.2.5 Phương pháp ổn định động cơ dùng thuật toán PID 6

1.2.5.1 Thuật toán PID 6

1.2.5.2 Phương pháp hiệu chỉnh thông số bộ PID Ziegler-Nichols: 7

1.3. Kết chương 8

Chương 2 : Giới thiệu vi điều khiển PIC16F887 9

2.1. Giới thiệu chương 9

2.2. Nội dung 9

2.2.1 Một vài chi tiết chính của vi điều khiển PIC16F887 9

2.2.2 Bộ dao động của PIC16F887 11

2.2.3 Các Port I/O 12

2.2.4 Hoạt động của khối giao tiếp EUSART 13

2.2.5 Cấu tạo và hoạt động của khối điều xung PWM 15

2.2.6 Ngắt ngoài trên chân RB0 17

2.2.7 Cấu tạo và hoạt động của bộ Timer1 18

2.2.8 Cách nạp cho PIC16F887 18

2.3. Kết chương 20

Chương 3: Thiết kế và thi công phần cứng 21

3.1. Mở chương 21

3.2. Nội dung 21

3.2.1 Sơ đồ khối phần cứng 21

3.2.2 Sơ đồ nguyên lý và hoạt động của các khối mạch 22

3.2.3 Tính toán các thông số của mạch 24

3.2.3.1 Mạch đảo chiều động cơ 24

3.2.3.2 Tính toán cho FET 25

3.2.3.3 Tính toán mạch lái cho FET 27

3.3.4 Layout và thi công mạch 30

3.3. Kết chương 31

Chương 4 : Thiết kế phần mềm 32

4.1. Mở chương 32

4.2. Nội dung 32

4.2.1 Phần mềm cho vi điều khiển PIC16F887 32

4.2.1.1 Thuật toán chương trình chính 32

4.2.1.2 Thuật toán chương trình xử lý phím 35

4.2.1.3 Thuật toán chương trình đo tốc độ động cơ 37

4.2.1.4 Thuật toán chương trình phục vụ ngắt nhận UART 39

4.2.2 Phần mềm trên máy vi tính giao tiếp với mạch điều khiển 41

4.3. Kết luận chương 46

4.4. Nhận xét đánh giá hệ thống 46

4.5. Hướng phát triển đề tài 46

 

doc55 trang | Chia sẻ: lethao | Lượt xem: 5868 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Điều khiển tốc độ động cơ điện một chiều, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
i mạch điều khiển. Phần này sẽ được giới thiệu trong chương 4. Kết chương Chương này đã giới thiệu cơ sở lý thuyết về động cơ, phương pháp điều khiển động cơ và thuật toán điều khiển PID. Chương tới sẽ giới thiệu vi điều khiển PIC16F887, trong đề tài này PIC16F887 được sử dụng làm khối điều khiển trung tâm, điều khiển động cơ dùng thuật toán PID và giao tiếp với máy tính theo chuẩn giao tiếp RS232 cho phép người sử dụng giám sát trạng thái của động cơ. Chương 2 : Giới thiệu vi điều khiển PIC16F887 Giới thiệu chương Chương này giới thiệu cơ bản về vi điều khiển PIC16F887 của hãng Microchip và hoạt động của nó bao gồm nội dung về cách cấu hình xung clock, hoạt động khối giao tiếp UART, khối PWM, ngắt ngoài trên chân RB, cấu tạo và hoạt động của các bộ timer, và cách nạp chương trình cho PIC16F887. Nội dung 2.2.1 Một vài chi tiết chính của vi điều khiển PIC16F887 PIC16F887 là vi điều khiển 8-bit có kiến trúc Harvard của Microchip có những thông số kỹ thuật như sau: Clock hoạt động tối đa 20MHz. Chu kỳ máy bằng bốn lần chu kỳ xung clock. Chip có nhiều dạng vỏ khác nhau, loại chip được sử dụng trong đề tài là loại 40 chân PDIP. Điện áp hoạt động rộng từ 2V đến 5.5V. Bộ nhớ dữ liệu và bộ nhớ chương trình tách biệt nhau, bus địa chỉ cũng như bus dữ liệu là riêng biệt. Bộ nhớ chương trình Flash 8K ô nhớ cho phép ghi 100,000 lần. Mỗi ô nhớ có 14 bit. Bộ nhớ dữ liệu RAM có 512 Byte gồm các thanh ghi chức năng đặc biệt và các thanh ghi đa mục đích. Ngoài ra PIC16F887 được tích hợp 256 Byte EEPROM cho phép ghi đến 1,000,000 lần. 35 chân I/O của 5 port điều khiển là PortA, PortB, PortC, PortD, PortE. Bộ chuyển đổi ADC 10-bit với 14 kênh. 3 bộ timer. Bộ timer0 8-bit, bộ timer1 16-bit và bộ timer2 8-bit. Module Capture, Compare và PWM Module Enhanced USART hỗ trợ RS-485, RS-232. Những chi tiết trên được thể hiện cụ thể trong hình 2.1. Hình 2.1 Sơ đồ khối của PIC16F887 2.2.2 Bộ dao động của PIC16F887 Sơ đồ khối của bộ dao động được minh họa trong hình 2.2. Hình 2.2 Sơ đồ khối bộ dao động của PIC16F887 Clock hệ thống của PIC16F887 có thể được chọn từ hai nguồn dao động nội (Internal Oscillator) hoặc dao động ngoại (External Oscillator) nhờ bộ chọn kênh MUX. Bộ MUX được điều khiển bởi các bit FOSC (bit 2, bit 1, bit 0 của thanh ghi CONFIG1 16-bit định vị tại địa chỉ 2007H và 2008H trong bộ nhớ chương trình) và bit SCS (bit 0 của thanh ghi OSCCON). Nếu SCS = 1, clock hệ thống được chọn từ INTOSC. Nếu SCS = 0, clock hệ thống được chọn từ bộ dao động ngoại. Các bit FOSC được sử dụng để cấu hình bộ dao động ngoại là LP, XT, HS, RC, RCIO hay EC. Bộ dao động nội gồm 2 bộ dao động HFINTOSC 8MHz và LFINTOSC 31kHz. Clock 8MHz của bộ HFINTOSC được chia thành các tần số 8MHz, 4MHz, 2MHz, 1MHz, 500kHz, 250kHz, 125kHz nhờ bộ chia tần số postscaler. Các bit IRCF điều khiển bộ MUX chọn kênh cho INTOSC. Bộ dao động ngoại (được tích hợp bên trong PIC) cần được kết nối với các bộ lọc tại các chân OSC1, OSC2. Trong đề tài, tôi sử dụng thạch anh 12MHz và 2 tụ 33pF kết nối như hình 2.3. Bộ dao động ngoại được hoạt động ở chế độ HS. Tín hiệu dao động được qua bộ đệm Trigger theo sườn xuống và tạo thành xung clock HS 12MHz cung cấp cho clock hệ thống. Hình 2.3 Bộ dao động ngoại ở chế độ HS. 2.2.3 Các Port I/O PIC16F887 tất cả 35 chân I/O mục đích thông thường (GPIO: General Purpose Input Ouput) có thể được sử dụng. Tùy theo những thiết bị ngoại vi được chọn mà một vài chân có thể không được sử dụng ở chức năng GPIO. Thông thường, khi một thiết bị ngoại vi được chọn, những chân liên quan của thiết bị ngoại vi có thể không được sử dụng ở chức năng GPIO. 35 chân GPIO được chia cho 5 Port: PortA gồm 8 chân, PortB gồm 8 chân, PortC gồm 8 chân, PortD gồm 8 chân và PortE gồm 3 chân. Mỗi port được điều khiển bởi 2 thanh ghi 8-bit, thanh ghi Port và thanh ghi Tris. Thanh ghi Tris được sử dụng để điều khiển port là nhập hay xuất. Mỗi bit của Tris sẽ điều khiển mỗi chân của port đó, nếu giá trị của bit là 1 thì chân liên quan là nhập, ngược lại nếu giá trị của bit là 0 thì chân liên quan là xuất. Thanh ghi Port được sử dụng để chứa giá trị của port liên quan. Mỗi bit của thanh ghi Port sẽ chứa giá trị của chân liên quan. Cấu trúc của chân GPIO được thể hiện trong hình 2.4 Hình 2.4 Cấu tạo của chân GPIO 2.2.4 Hoạt động của khối giao tiếp EUSART Khối giao tiếp nối tiếp EUSART (Enhanced Universal Synchronous Asynchronous Receiver Transmitter) cho phép cấu hình hoạt động ở chế độ giao tiếp nối tiếp đồng bộ và không đồng bộ. Trong đề tài này, chế độ giao tiếp không đồng bộ được sử dụng. Phần này sẽ tập trung mô tả hoạt động của module EUSART ở chế độ không đồng bộ. Hoạt động truyền: Sơ đồ khối bộ truyền được thể hiện trong hình 2.5. Hình 2.5 Sơ đồ khối bộ truyền của module EUSART Bộ phận chính của khối truyền là thanh ghi truyền TSR. Thanh ghi này không thể truy cập bằng phần mềm, mà được truy cập gián tiếp qua thanh ghi đệm truyền TXREG. Bộ truyền được kích hoạt khi cấu hình các bit TXEN=1, SYNC=0, SPEN=1. TXEN=1 kích hoạt bộ truyền của EUSART. SYNC=0 cấu hình EUSART hoạt động ở chế độ không đồng bộ. SPEN=1 cho phép bộ EUSART hoạt động và cấu hình chân TX/CK là chân xuất. Quá trình truyền được khởi tạo bằng cách ghi dữ liệu truyền vào thanh ghi TXREG. Nếu đây là dữ liệu truyền đầu tiên hoặc dữ liệu truyền trước đã truyền hoàn tất thì dữ liệu trong TXREG ngay lập tức sẽ được truyền vào thanh ghi TSR. Nếu thanh ghi TSR vẫn còn chứa dữ liệu của ký tự truyền trước thì dữ liệu mới trong TXREG sẽ được giữ cho đến khi bit Stop của ký tự đang truyền hoàn tất. Sau đó dữ liệu chờ trong TXREG sẽ được truyền vào TSR. Các bước thiết lập quá trình truyền: Khởi tạo cặp thanh ghi SPBRGH, SPBRG và các bit BRGH, BRG16 để cấu hình tốc độ Baud. Thiết lập bit SYNC=0, và bit SPEN=1. Gởi dữ liệu cần truyền vào TXREG, quá trình truyền sẽ bắt đầu. Hoạt động nhận: Sơ đồ khối bộ nhận được thể hiện trong hình 2.6. Dữ liệu được nhận trên chân RX/DT và đẩy vào khối Data Recovery. Khi tất cả 8 hoặc 9 bit của ký tự nhận đã được dịch vào, chúng sẽ ngay lập tức được chuyển vào bộ đệm 2 ký tự FIFO. Bộ đệm FIFO và thanh ghi RSR không thể truy cập trực tiếp bằng phần mềm mà được truy cập gián tiếp thông qua thanh ghi RCREG. Dữ liệu trong bộ đệm nhận được đọc bằng cách đọc thanh ghi RCREG. Bộ nhận được kích hoạt khi cấu hình các bit CREN=1, SYNC=0, SPEN=1. CREN=1 kích hoạt bộ nhận của EUSART. SYNC=0 cấu hình EUSART hoạt động ở chế độ không đồng bộ. SPEN=1 cho phép bộ EUSART hoạt động và cấu hình chân RX/DT là chân nhập. Cờ ngắt nhận RCIF=1 khi bộ nhận EUSART được kích hoạt và có một ký tự đã được nhận trong bộ đệm nhận FIFO và chưa được đọc. Bit RCIF là bit chỉ đọc, không thể ghi bằng phần mềm. Ngắt nhận được kích hoạt khi cấu hình các bit sau: RCIE=1, PEIE=1 và GIE=1. Sau khi đã thiết lập các bit như trên, ngắt nhận xảy ra ngay khi nhận xong một ký tự trong bộ đệm nhận. Cờ RCIF được xóa bằng phần cứng khi không có ký tự nào chưa đọc trong bộ đệm nhận. Hình 2.6 Sơ đồ khối bộ nhận USART. 2.2.5 Cấu tạo và hoạt động của khối điều xung PWM PIC16F887 có hai bộ điều xung, hai bộ này sẽ tạo ra các tín hiệu điều xung trên các chân CCP1 và CCP2. Độ rộng, chu kỳ, và độ phân giải được xác định bởi các thanh ghi PR2, T2CON, CCPR1L, CCPR2L, CCP1CON, CCP2CON. Để các chân CCPx (CCP1 và CCP2) hoạt động ở chế độ PWM, cần xóa bit TRIS tương ứng của các chân đó. Sơ đồ khối của các bộ điều xung được mô tả trong hình 2.7. Chú thích (1) trong hình 2.7 biểu thị rằng thanh ghi 8-bit TMR2 được kết hợp với 2-bit prescaler của bộ dao động nội để tạo ra bộ định thời 10-bit. Các thanh ghi CCPRxH là các thanh ghi chỉ đọc, kết hợp với 2 bit 5 và 4 của các thanh ghi CCPxCON có vai trò định độ rộng của xung, các thanh ghi này được ghi gián tiếp thông qua các thanh ghi CCPRxL. Thanh ghi 8-bit PR2 định chu kỳ cho xung ra. Hình 2.7 Sơ đồ khối bộ PWM. Sóng điều xung tại các chân CCPx có giản đồ thời gian như hình 2.8. Hình 2.8 Giản đồ thời gian của sóng điều xung tại chân CCPx Thanh ghi TMR2 kết hợp với 2 bit prescaler sẽ đếm lên nhờ xung clock của hệ thống. Khi giá trị của TMR2 nhỏ hơn giá trị của CCPRxL:CCPxCON, chân CCPx ở mức cao. Khi giá trị của TMR2 bằng với giá trị này, bộ so sánh sẽ đảo chân CCPx xuống mức 0. Khi giá trị của TMR2 bằng với PR2, TMR2 sẽ được xóa về 0 đồng thời kết thúc chu kỳ xung, chân CCPx lại được thiết lập mức cao. Chu kỳ của xung được tính theo công thức sau: Chu kỳ PWM = [(PR2)+1].4.TOSC.(giá trị Prescale của TMR2) Ở đây TOSC là chu kỳ của clock hệ thống. TOSC = 1/FOSC. Độ rộng xung được tính theo công thức sau: Độ rộng xung = (CCPxL:CCPxCON).TOSC.(giá trị Prescale của TMR2) 2.2.6 Ngắt ngoài trên chân RB0 Hình 2.9 là sơ đồ khối logic của hệ thống ngắt trong PIC16F887. Hình 2.9 Sơ đồ khối logic của hệ thống ngắt trong PIC16F887. Ngắt ngoài trên chân RB0 được kích khởi theo sườn. Sườn lên nếu như bit INTEDG=1 (bit 6 của thanh ghi OPTION_REG), sườn xuống nếu INTEDG=0. Khi một sườn thích hợp xuất hiện trên chân RB0, cờ INTF được bật lên 1. Ngắt này có thể được cho phép nếu bit INTE=1, không cho phép nếu INTE=0. Cờ INTF cần được xóa bằng phần mềm trong trình phục vụ ngắt trước khi cho phép ngắt trở lại. 2.2.7 Cấu tạo và hoạt động của bộ Timer1 Bộ timer1 là bộ định thời 16-bit có cấu tạo như hình 2.10. Hình 2.10 Sơ đồ khối của bộ timer1. Bộ timer1 là bộ đếm lên 16-bit được truy xuất gián tiếp thông qua cặp thanh ghi TMR1H, TMR1L. Đọc hoặc ghi các thanh ghi này sẽ cập nhật trực tiếp giá trị cho bộ timer. Khi được sử dụng với nguồn clock nội, bộ timer 1 sẽ có vai trò là bộ định thời. Khi được sử dụng với nguồn clock ngoại, nó sẽ có vai trò là định thời hoặc bộ đếm. Sử dụng bit TMR1CS để chọn nguồn clock. Các bit T1CKPS định giá trị cho bộ chia tần số Prescaler. Khi bộ TMR1 tràn (từ FFFFh đến 0000h) cờ ngắt TMR1IF sẽ được thiết lập lên 1. Nếu lúc này cờ TMR1IE =1, cờ PEIE=1 và GIE=1 thì ngắt timer1 sẽ xảy ra. Cờ TMR1IF cần được xóa trong trình phục vụ ngắt timer1. 2.2.8 Cách nạp cho PIC16F887 Có nhiều cách nạp cho chip PIC16F887, trong đề tài này sử dụng cách nạp bằng mạch nạp ezPIC Programmer của Sunrom và phần mềm nạp PICPgm Programmer. Mạch nạp được kết nối qua cổng COM của máy vi tính. Sơ đồ nguyên lý, mạch thực tế của mạch nạp ezPIC Programmer của Sunrom được cho ở hình 2.11 và 2.12. Hình 2.11 Sơ đồ nguyên lý mạch nạp ezPIC Programmer của Sunrom. Hình 2.12 Mạch nạp ezPIC Programmer của Sunrom. Phần mềm nạp PICPgm Programmer được viết bởi Christian Stadler, phần mềm này giao tiếp được với nhiều mạch nạp, trong đó có ezPIC Programmer của Sunrom. Đặc biệt PICPgm Programmer nạp được hầu hết các dòng PIC của Microchip. Phần mềm này rất dễ sử dụng và hoạt động rất ổn định, giao diện được thể hiện trong hình 2.13. Hình 2.13 Giao diện phần mềm PICPgm Programmer. Kết chương Chương này đã mô tả sơ lược cấu tạo của PIC16F887, hoạt động của một vài thiết bị ngoại vi được sử dụng trong đề tài, cách nạp cho PIC16F887 bằng mạch nạp ezPIC và chương trình nạp PICPgm Programmer. Chương tới sẽ trình bày quá trình thiết kế và thi công phần cứng. Chương 3: Thiết kế và thi công phần cứng Mở chương Chương này sẽ trình bày cách thiết kế và thi công phần cứng, tính toán và chọn lựa các linh kiện sử dụng. Nội dung 3.2.1 Sơ đồ khối phần cứng Sơ đồ khối phần cứng được mô tả như hình 3.1. Khối điều khiển trung tâm PIC16F887 Khối điều khiển công suất Động cơ Encoder Bộ phận hiển thị LCD 16x2 MAX232 chuyển đổi mức điện áp Khối sửa dạng xung Các phím điều khiển PWM Cổng DB9 UART RS232 Đảo chiều Hình 3.1 Sơ đồ khối phần cứng. Khối điều khiển trung tâm sẽ kết nối với khối điều khiển công suất qua chân điều xung CCP1, điều khiển khối công suất đảo chiều động cơ. Khối điều khiển công suất điều khiển công suất cung cấp cho động cơ. Khối Encoder đọc tốc độ động cơ và xuất ra các xung đếm, các xung này được sửa thành xung vuông và đưa vào chân ngắt ngoài RB0 của vi điều khiển PIC16F887 cho phép PIC16F887 giám sát được tốc độ của động cơ. Các phím điều khiển cho phép người dùng cài đặt các thông số của hệ thống. Khối hiển thị sử dụng LCD cho phép người dùng theo dõi hoạt động của động cơ và các thông số của hệ thống. Khối giao tiếp máy tính theo chuẩn giao tiếp nối tiếp không đồng bộ sử dụng IC chuyển đổi điện áp MAX232. 3.2.2 Sơ đồ nguyên lý và hoạt động của các khối mạch Sơ đồ nguyên lý trong hình 3.2 được thiết kế dựa trên sơ đồ khối trên. Chip PIC16F887 điều khiển trung tâm làm nhiệm vụ tính toán, xuất ra xung điều khiển cho khối điều khiển động cơ, điều khiển đảo chiều động cơ. Điều khiển hiển thị LCD và giao tiếp với máy tính. Khối giao tiếp máy tính gồm Max232 chuyển mức tín hiệu RS232 với mức logic 0 (+3V đến +15V) sang TTL 0V, và mức logic 1 (-15V đến -3V) thành 5V. Nhờ khối này, vận tốc hiện thời của động cơ sẽ được cập nhật lên máy tính và các từ máy tính ta có thể điều khiển tốc độ động cơ, thay đổi các thông số của bộ điều khiển PID. Giá trị của các tụ trên sơ đồ mạch là 10u được chọn theo datasheet của nhà sản xuất. Khối điều khiển công suất (mạch Drive cho FET) kích cho FET hoạt động theo tín hiệu PWM từ PIC16F887. Để đảm bảo cho FET chuyển mạch nhanh ở đây ta dùng mạch kích kiểu totem-pole gồm 2 BJT 2SD414 và 2SB548. Khối đảo chiều động cơ dùng 2 tiếp điểm để đảo điện áp đặt vào động cơ. Khối hiển thị dùng LCD 16x2 để hiện thị thông số Ki, Kp, Kd tốc độ hiện thời, tốc độ cài đặt. Khối nguồn cung cấp: mạch ổn áp dùng IC 7805 cấp điện áp 5V cho mạch hoạt động. Hình 3.2 Sơ đồ nguyên lý. 3.2.3 Tính toán các thông số của mạch 3.2.3.1 Mạch đảo chiều động cơ Hình 3.3 Phần mạch đảo chiều động cơ. Để điều khiển chiều quay của động cơ điện 1 chiều, ta có thể dùng mạch cầu H, hoặc có thể dùng Relay. Vì dùng relay chi phí thấp hơn nên trong đồ án này chúng tôi đã lựa chọn giải pháp này. Nguyên lý của mạch này như sau: Khi chân dir ở mức thấp, BJT Q2 tắt, tiếp điểm 3 nối đến 4, tiếp điểm 6 nối đến 8, khi đó Vcc nối tới chân 2 của CON2, cực D của FET nối tới chân 2 của CON2 động cơ chạy theo chiều thuận (chiều quy ước). Khi có tín hiệu kích 5V tại chân dir, BJT Q2 dẫn, tiếp điểm 3 nối đến 5, tiếp điểm 6 nối đến 7, lúc đó nguồn cung cấp cho động cơ đảo ngược so với trường hợp trên, do đó động cơ quay theo chiều ngược lại. Ta tính chọn với dòng cực đại qua động cơ là 5A, Chọn Relay 10A. Công suất của relay 530mW, -> dòng qua relay 0.530/12 = 44mA. Công suất tổn hao trên BJT Q2 chủ yếu là công suất dẫn: P = Vcesat xIcsat = 0.25x44mA = 11mW. Vậy chọn BJT 2SC1815 có: Ic = 150mA, Vce = 50V, công suất 400mW, hfemin = 70. Để BJT dẫn bảo hòa thì Ibmin = Ic/hfemin = 44/70 = 0.63mA. Chọn dòng qua R13 khoảng 0.7mA, => R13 = 0.7V/0.7mA = 1k. Chọn dòng Ib ~ 1.5Ibmin => chọn Ib = 1mA Dòng qua R11 = Ib + IR13 = 1.7mA R11 = (5V-0.7V)/1.7 = 2.53k =>chọn R11 = 2k2. 3.2.3.2 Tính toán cho FET Tính dòng tối đa qua động cơ: Ta có phương trình của động cơ ở trạng thái xác lập: Ứng với tải cụ thể ta có thể xác định được TL từ đó ta có thể xác định được dòng Ia cực đại qua động cơ. Giả sử ta tính với dòng tối đa qua động cơ là 5 A Ta phải chọn MOSFET có VDS >2Vđộng cơ, dòng >1.5 -> 2lần Imax, khoảng10A, công suất tiêu tốn trên MOSFET tùy thuộc vào từng loại FET, ở đây ta chọn các thông số của IRF540 để tham khảo sau đó kiểm tra lại công suất có đảm bảo hay không.. Công suất tiêu tán trên MOSFET bao gồm 2 thành phần: công suất tiêu tán khi FET dẫn và công suất chuyển mạch: Ptt = Pd + Psw Công suất tiêu tán khi FET dẫn được tính theo công thức: Theo datasheet của IRF540, RDsonMax = 2.5Ω (Tj=150oC), Imax = 2.5 A, max = 1 Pdmax = 52x2.5 = 62.5W Công suất tiêu tán khi MOSFET hoạt động chuyển mạch: Hình 3.4 Dạng sóng VDS và VGS khi FET chuyển mạch. Tổn hao trong quá trình chuyển từ off sang on E1 = Tương tự như trên tổn hao khi từ on sang off: E2 = Psw = Tần số điều xung được sử dụng ở đây là 24khz, trong phần mềm sử dụng 2000 mức điều xung, tuy nhiên, ta chỉ cần mạch đáp ứng 100 mức điều xung (vì thời gian đáp ứng càng nhanh thì giá trị dòng đỉnh nạp cho tụ ngõ vào của FET càng lớn, ta không muốn dòng đỉnh này quá lớn). Thời gian của 1 mức điều xung lúc này là: 1/(24.1000.100) = 0.417µs =417ns. Tổng thời gian nạp và xả tụ ngõ vào tại cực G phải nhỏ hơn giá trị này. Ta chọn tr + tf =200ns Psw = 30.5. 200.10-9.24.103 = 720 mW. Trong đó fsw là tần số chuyển mạch. Công suất tổng cộng lớn nhất: 63.2W Vậy MOSFET IRF540 có các thông số: VDSS = 100V, IDS = 33A, Pmax = 130W thỏa mãn các yêu cầu đề ra. 3.2.3.3 Tính toán mạch lái cho FET Sơ đồ mạch Driver: Hình 3.5 Mạch lái cho FET. Mạch lái được mắc theo kiểu totem-pole gồm 2 BJT 2SD414 và 2SB548 để đảm bảo tần số chuyển mạch nhanh cho FET. Tính công suất của Q3 và Q4: Ta tính dựa vào điện tích cần nạp cho tụ CGS. PDRI = V.QG.fsw = 12.72.10-9.24.3 = 21mW. QG :tổng điện tích nạp hoặc xả cho cực G. Theo datasheet, QG = 72nC Mà: tx = QG/IG => IG = QG/tx Tx thời gian nạp hoặc xả tụ ngõ vào, 2.tx =200ns=(tr + tf) IG > 72.2/200 = 720mA Chọn BJT Q3,Q4: có Vce > 2Vcc, P>2.21mW. Chọn BJT 2SD414 và 2SB548. Tính R14: R14 = (24V-0.7V).60/720mA = 1.94k -> chọn 1k8 Tính chọn Q6: Dạng sóng chuyển mạch của BJT có dạng như sau: Hình 3.6 Dạng sóng chuyển mạch trên Q6. Công suất tổn hao trong BJT ở chế độ chuyển mạch gồm công suất tổn hao khi dẫn bão hòa và công suất tổn hao chuyển mạch. P = Psw + Pdẫn (1) Dựa vào đồ thị ta thấy : trong quá trình chuyển đổi trạng thái làm việc, dòng điện cực góp ic(t) và thời gian t có quan hệ tuyến tính : Ic = Kt Với K= Icoff có thể bỏ qua => K= => ic=t Trong quá trình của mỗi lần chuyển đổi trạng thái làm việc, năng lượng tiêu hao của BJT có thể tính theo công thức : Trong mỗi chu kỳ, BJT chuyển đổi trạng thái làm việc 2 lần, trong 2 lần chyển đổi đó, năng lượng tiêu hao là như nhau. Như vậy năng lượng tiêu hao trong quá trình chuyển mạch là : Esw= 2E =Tsw.Icsat.Vcc Công suất tiêu tán trong quá trình chuyển mạch : Psw=Icsat.Vcc. (2) Từ (1) và (2) ta có : Ptt= + Icsat.Vcc. Yêu cầu thời gian chuyển mạch Tsw của BJT phải nhỏ hơn thời gian chuyển mạch của khóa điện tử. Thời gian tsw của BJT thông thường khoảng vài chục đến vài trăm ns, ở đây ta lấy tsw=100ns. Với BJT Q5, icsat = Vcc/R14 = 12/1k8= 6.7mA. Ton/T max =1, 1/T = f =24kHz thay vào công thức trên ta được : Pttmax = 0.2x6.7 + 6.7x12x100x10-9x24x10-3 = 1.36mW. Chọn BJT Q6 có Vce > 12x2 =24V, Ic>6.7x2, Ptt>1.36mW, chọn BJT Q6 là C1815. Để Q6 dẫn bão hòa dòng ibQ6 > icQ6/βmin = 6.7/70 ~0.1mA. Chọn ibQ6 = 0.2mA. R15 có tác dụng giảm thời gian tắt của BJT. Chọn dòng qua R15 khoảng 0.7mA. R15 = Vbe/Ir15 = 0.7V/0.7mA =1k. R6 = (5V-0.7V)/(0.7mA+0.2mA) = 4k78. Chọn R6 = 4k7. 3.3.4 Layout và thi công mạch Layout và sơ đồ nguyên lý được thiết kế bằng phần mềm Orcad của hãng Cadence. Mạch in được thiết kế như hình 3.7. Mạch in được thi công bằng phương pháp ủi mạch lên board đồng và hàn gắn các linh kiện theo sơ đồ nguyên lý. Hình ảnh mạch hoàn chỉnh được thể hiện trong hình 3.8. Hình 3.7 Layout của phần mạch điều khiển. Hình 3.8 Mạch điều khiển sau khi thi công xong. Kết chương Trong chương này, phần cứng đã được mô tả, thiết kế và tính toán một cách chi tiết. Các IC được sử dụng là PIC16F887, LM324, MAX232, LCD16x2. Ngoài ra còn có các linh kiện khác như tụ, điện trở, relay, nút nhấn, cổng DB9, BJT, FET, cầu diode và các connector. Chương 4 : Thiết kế phần mềm Mở chương Việc thiết kế phần mềm là công đoạn khó nhất của đồ án này bởi hệ thống yêu cầu xử lý phức tạp. Do đó, em quyết định chọn ngôn ngữ bậc cao C để thiết kế phần mềm. Phần mềm được biên soạn và biên dịch trên phần mềm CCS. Phần mềm được chia thành hai phần: - Thiết kế phần mềm cho vi điều khiển PIC16F887. - Thiết kế phần mềm trên máy vi tính giao tiếp với mạch điều khiển. Phần mềm này được viết bằng Visual Basic. Cuối chương sẽ là phần nhận xét về đề tài và định hướng phát triển đề tài. Nội dung 4.2.1 Phần mềm cho vi điều khiển PIC16F887 Phần này trình bày những thuật toán chính của chương trình nạp cho PIC16F887 gồm những lưu đồ thuật toán sau: - Lưu đồ thuật toán tổng quát. - Lưu đồ chương trình xử lý phím. - Lưu đồ chương trình đo tốc độ động cơ. - Lưu đồ chương trình ngắt nhận UART. 4.2.1.1 Thuật toán chương trình chính Thuật toán chương trình chính được thể hiện trong hình 4.1 (trang 33). Chương trình khai báo các biến toàn cục là Ki, Kp, Kd, Sp. Các biến Ki, Kp, Kd đóng vai trò là các tham số của bộ xử lý PID. Biến Sp là biến chứa vận tốc thực của động cơ đo được nhờ đếm xung encoder. Sp: vận tốc của động cơ. Ki: hệ số tích phân. Kp: hệ số tuyến tính. Kd: hệ số vi phân. Tiếp theo ta khởi tạo các thiết bị ngoại vi cho PIC16F887: Cài đặt bộ timer2 hoạt động ở chế độ PWM. Cấu hình chân RB1 hoạt động ở chế độ PWM. Thiết lập thanh ghi Trisa là 0xFF. Với thiết lập này thì porta sẽ được cấu hình là port nhập. Porta được sử dụng để kết nối với các phím. Thiết lập thanh ghi Trisd là 0. Với thiết lập này thì portd là port xuất. Portd được sử dụng để kết nối với 8 chân dữ liệu của LCD. Thiết lập thanh ghi Trise là 0. Với thiết lập này thì porte là port xuất. Porte được sử dụng để kết nối với 3 chân điều khiển của LCD. Cài đặt cho bộ UART hoạt động ở tốc độ Baud 9600kbits/s. Bộ UART được sử dụng để giao tiếp nối tiếp không đồng bộ với máy tính, cho phép mạch điều khiển truyền dữ liệu lên máy tính, và nhận dữ liệu từ máy tính. Ở đây, bộ UART truyền hoạt động ở chế độ thăm dò. Còn bộ UART nhận hoạt động ở chế độ ngắt. Cho phép ngắt timer1. Bộ timer1 kết hợp với ngắt ngoài trên chân RB0 được sử dụng để đo tốc độ động cơ. Cho phép ngắt sườn lên trên chân RB0, chân RB0 kết nối với chân tín hiệu của encoder. Khi có sườn lên tại chân RB0, ngắt RB0 sẽ xảy ra. Sau khi khởi tạo cho các thiết bị ngoại vi, chương trình sẽ thực hiện vòng lặp vô hạn. Bắt đầu vòng lặp, chương trình gọi hàm quét phím. Thuật toán nhận phím của hàm quét phím sẽ kiểm tra phím nhấn, loại bỏ quá trình rung của phím. Tiếp theo chương trình sẽ kiểm tra có phím nhấn hay không. Nếu không có, chương trình sẽ quay trở về đầu vòng lặp. Nếu có, chương trình sẽ gọi hàm xử lý phím nhấn. Sau đó quay trở về đầu vòng lặp. Như vậy, chương trình chính sẽ khởi tạo cho các thiết bị ngoại vi, sau đó kiểm tra phím nhấn. Khi xảy ra các ngắt, chương trình sẽ thực hiện chương trình phục vụ ngắt của ngắt tương ứng. Chương trình phục vụ ngắt timer1 được phân tích trong mục 4.2.1.3. Chương trình phục vụ ngắt nhận UART được phân tích trong mục 4.2.1.4. Chương trình phục vụ ngắt RB0 chỉ làm một nhiệm vụ là tăng biến đếm xung encoder. Chương trình này sẽ không được phân tích trong đề tài. Do tính phổ biến, các thuật toán của các hàm giao tiếp LCD sẽ không được phân tích trong đề tài. Bắt đầu Khai báo các biến toàn cục Kp, Ki, Kd, SP Cài đặt Timer2 ở chế độ PWM Cài đặt UART tốc độ Baud 9600kbits/s Chọn chân RB1 hoạt động ở chế độ PWM Thiết lập thanh ghi TRISA là 0xFF.(porta là port nhập, kết nối với phím) Thiết lập thanh ghi TRISD là 0 (portd là port xuất, kết nối với chân dữ liệu LCD) Thiết lập thanh ghi TRISE là 0(porte là port xuất, kết nối với chân điều khiển LCD) Cho phép ngắt nhận UART Cho phép ngắt timer1. Timer1 được dùng để đo tốc độ. Cho phép ngắt ngoài trên chân RB0 Có phím nhấn? Gọi hàm quét phím Gọi hàm xử lý phím nhấn Đúng Sai Hình 4.1 Lưu đồ thuật toán chương trình chính. 4.2.1.2 Thuật toán chương trình xử lý phím Thuật toán hàm xử lý phím được thể hiện trong hình 4.2 Sau khi hàm quét phím xác nhận có phím nhấn, hàm xử lý phím sẽ gán giá trị porta cho biến phim. Biến phim được so sánh với các giá trị để xác định phím nào được nhấn. Chương trình định nghĩa các macro cho được sử dụng cho các phím như sau: #define INC 0x3E //Phím tăng (increase) #define DEC 0x3D //Phím giảm (decrease) #define SHIFT 0x3B //Phím dịch thông số cài đặt (increase) #define OK 0x37 //Phím chấp nhận giá trị cài đặt #define CANCEL 0x2F //Phím không chấp nhận giá trị cài đặt #define ON_OFF 0x1F //Phím tắt mở động cơ #define INV_DIR 0x3C //Phím đảo chiều, kết hợp nhấn cả hai //phím INC và DEC cùng lúc. Chương trình sẽ tùy vào phím nào nhấn mà xử lý các tác vụ tương ứng, sau đó kết thúc chương trình. Với phím OK: chương trình sẽ gán giá trị vừa nhập cho biến tương ứng với thông số đang cài đặt. Sau đó hiển thị ra LCD dòng chữ “setup” ở vị trí 0x80 và thông số vừa cài đặt ở vị trí 0xC8. Với phím CANCEL: chương trình sẽ Hiển thị ra LCD dòng chữ “setup” ở vị trí 0x80 và “cancel” ở vị trí 0xC8. Với phím INC: chương trình sẽ tăng biến nhap_value lên một đơn vị. Biến này chứa giá trị đang cài đặt. Với phím DEC: chương trình sẽ giảm biến nhap_value một đơn vị. Với phím ON_OFF: nếu động cơ đang mởàtắt động cơ và ngược lại. Với phím SHIFT: chương trình sẽ dịch chuyển thông số cài đặt theo vòng sau: Kpà Kià Kdà Sp. Sau đó gán thông số muốn thay đổi cho biến nhap_value . Với phím INV_DIR: chương trình sẽ đảo chân RB3. Sau đó hiển thị ra LCD dòng chữ “INV_DIR” ở vị trí 0xC8. Bắt đầu Gán giá trị porta cho biến phim Phím OK? Gán giá trị vừa nhập cho biến tương

Các file đính kèm theo tài liệu này:

  • docĐiều khiển tốc độ động cơ điện một chiều (ĐH Đà Nẵng).doc