Articles by "Tài liệu robocon"

10 4.104 8051 9 Acquy adc pic All datasheet ALTIUM Altium Designer AM-FM Arduino ARM ARM là gì Ấn Tượng Bản tin công nghệ Bản tin Thiết Bị Số Barobo bất động sản biến Binary Bit board lpc2378 Bộ chuyển đổi ADC Bộ Đếm Bộ điều khiển cửa cuốn Bộ Định Thời Buy Khóa Số Điện Tử Buy Mạch đếm sản phẩm Buy Mạch giao thông Buy Mạch nạp Buy Matrix Byte C cho AVR các hàm vào ra các loại lõi arm các mạch DAC cơ bản các ngắt trong pic Cách đọc điện trở Cách Đọc Giá Trị Điện Trở Cách đọc giá trị tụ điện Cách hàn linh kiện dán cách làm mạch khóa số cách tạo linh kiện dán cad/cam Cài Đặt cài đặt proteus 8 cảm biến Cấu Kiện Logic Khả Trình cấu tạo cấu trúc arm cấu trúc lệnh CCS Chân chân Transistor Chip Khả Trình chuyển đổi Chuyển đổi số tương tự Chuyển Đổi Tương Tự/Số - ADC Chuyển động số chương trình City Clip Điện Tử Code 8051 - ASM Code 8051 - C Code 8051-C code ASM code ASM mẫu 8086 Code AVR - C code C Code Lập Trình Code led sao băng code maupic code mẫu 8051 Code Mẫu 8086 Code Mẫu cho ARM - LPC1343 code mẫu pic Code PIC - C codemaupic Counter Cổng Vào Ra Cơ Bản Cuộn Cảm Cửa cuốn DA DAC Debug Decimal Delay8051 Dev-C++ Diode DIY Dò đường Do It Yourself doanh nghiệp Download DTMF Mobile đảo chiều động cơ Điện Trở Điện Tử Điện Tử Cơ Bản điều chế độ rộng xung điều chế xung PWM điều khiển bằng điện thoại Điều khiển cửa cuốn Điều khiển cửa cuốn bằng điện thoại điều khiển động cơ đo điện áp đo nhiệt độ đo nhiệt độ hiển thị lên lcd trên 8051 Đo Nhiệt Độ LM35 + LCD Đo Nhiệt Độ LM35 + Led 7 thanh đọc màu điện trở đồ chơi động cơ chân không Động cơ nhiên liệu Động cơ robo đồng hồ thời gian thực Ebook Đại Học ebook điện tử Ebook đồ án Ebook Tin Học Encoder Encoder là gì Full Giải Thuật Giải thuật PID Giáo Dục giao tiếp i2c pic 16f877a giao tiếp i2c pic16f877a với ic ds1307 giao tiếp máy tính qua rs232 Giao Tiếp Máy Tính VB6 giao tiếp rs232 giao tiếp spi giữa 2 pic giao tiếp spi trong pic Giáo Trình Điện Tử Giới thiệu 8051 Giới thiệu cơ bản GPIO Graphic Design hàm Hàn linh kiện dán Hexadecimal Hệ Hexa Hệ Nhị Phân Hệ Thập Lục Phân Hệ Thập Phân hiển thị lên lcd 16x2 Hoạt Động Học Học 8051 qua các ví dụ đơn giản Học ALtium Designer học AVR Học Corel Draw X3 Học Eagle HỌC LẬP TRÌNH 16F877A Học Lập Trình 8051 Học Lập Trình C Học Orcad Học Protues hoc-lam-robot-do-duong-qua-video Hồng ngoại hướng dẫn hướng dẫn Altium Designer hướng dẫn đo đồng hồ VOM hướng dẫn keil - C lập trình 8051 hướng dẫn làm led sao băng hướng dẫn làm led trái tim hướng dẫn lập trình ARM Hướng Dẫn Lập Trình ARM - LPC1343 hướng dẫn lập trình ARM-LPC2378 hướng dẫn lập trình CCS hướng dẫn lập trình PIC Hướng Dẫn Led Trái Tim hướng dẫn module sim548c hướng dẫn sử dụng keil hướng dẫn sử dụng proteus 8 Hyper Terminal hercules 3.2.4 I/O IC 555 IC 7447 IC 74HC151 IC 74HC154 IC 74HC245 IC 74HC595 IC 74LS138 IC DS1307 IC đồng hồ thời gian thực IC LM324 IC LM342 IC LM7805 IC số IC số opamp LM324 IC Thông Dụng IC555 Interrupt Keil 4 Full keil arm Keil C Keil uVision3 kế toán kiểm toán khái niệm Khái Niệm Cơ Bản Kho Vật Liệu khóa điện tử khóa số dùng 8051 khóa số dùng 89s52 Khóa Số Điện Tử khuếch đại kiểm tra Kinh doanh maketing kinh tế quản lí Kỹ Thuật Kỹ Thuật Vi Xử Lý làm mạch điện lý thú Làm quen AVR Lap Trinh Dieu Khien Robot Lập Trình lập trình 8051 Lập Trình AVR Lập Trình C lập trình c++ Lập Trình Led Quảng Cáo Lập Trình Nhúng Lập trình pic Lập trình Robot Lập Trình Vi Điều Khiển Lập Trình Với AVR Studio LCD 16x2 Lcd16x2 Led Clock Led Quay led sao băng led trai tim Led Trái Tim Lịch sử ra đời Linh Kiện Cơ Bản linh kiện điện tử Loa LPC 2378 LSB lý thú Mã AVR - C Mạch 7seg Mạch Amply.Mạch Loa Mạch Autorobo Mạch bảo vệ Mạch Cảm Biến mạch cảm ứng sờ tay Mạch Cầu H Mạch cube Mạch Đếm Sản Phẩm Mạch điện cơ bản Mạch điện hay Mạch Điện Ứng Dụng Mạch Điều khiển động cơ Mạch Động Cơ Mạch đồng hồ Mạch đồng hồ 4 led Mạch giao thông Mạch IC số Mạch in mạch khóa số mạch khuếch đại thuật toán mạch led chúc mừng năm mới mạch led đẹp Mạch Led đơn Mạch Led Quảng Cáo mach led trai tim mạch led trái tim Mạch Led Vumeter mạch lý thú Mạch Ma trận Phím Mạch Matrix Mạch nạp Mạch nguồn Mạch Nút Bấm mạch sóng rf mạch tăng áp Mạch thu phát Mạch tổ hợp MSI Mạch trái tim Mạch Vi điều khiển Microbicho module module GSM/GPS Module Sim548 Module Sim548 giao tiếp với vi điều khiển PIC Module Sim548C Mosfet Motor Mô Phỏng Phần Cứng Mô Tả Phần Cứng MSB mua led sao băng News Ngắt Ngắt Trong LPC23xx ngân hàng Ngôn Ngữ Ngôn Ngữ C Ngôn Ngữ Tự Học Lập Trình C Ngôn Ngữ VHDL Nguyên Lý nguyên lý ic 555 Nguyên Tắc nháy led Nhập môn C Nhỏ Gọn Nibble opamp People Phần Mềm phần mềm altium Designer Phần mềm điện tử Phần Mềm Điện Tử Phần Mềm Điện Tử Hay Phần Mềm Hay Phần Mềm Led Quảng Cáo phần mềm proteus 8 Phần mềm vi tính Phần Mền Phương pháp hàn linh kiện dán PIC pic16f877a Print Design Proteus Proteus 7.8 SP2 FULL PWM quà tặng bạn gái quà tặng độc đáo quản trị doanh nghiệp quản trị kinh doanh quét led 7 đoạn Relay robocon Robot ROBOT DÒ ĐƯỜNG rút gọn mạch logic tổ hợp Sach Dien Tu Sản Phẩm Thú Vị Sản Phẩm Thương Mại Sáng tạo Short Smart Home SMD sơ đồ nguyên lý spi Sports Sử Dụng Sử Dụng Đồng Hồ sử dụng đồng hồ VOM sử dụng ngắt trong pic sự khác nhau Sức mạnh số Tải tài chính tài chính doanh nghiệp tài chính ngân hàng Tài Khoản Chia Sẻ Tài Liệu Tài Liệu 8051 tài liệu avr Tài liệu Điện Tử Tài Liệu Pic Tài liệu robocon tài liệu về ngân hàng Tài Liệu Vi Điều Khiển tailieuvn Tạo cổng Com ảo Tạo cổng nối tiếp ảo tạo dự án trong keil arm Tạo Project trong Vi Xử Lý ARM tạo thư viện altium designer tạo xung vuông Tạp chí Tạp Chí Hay tăng áp Tập lệnh AT Team Support TEAMPLATE PROTEUS Test thị trường tài chính Thiết Bị Thú Vị Thiết kế robot Thiết lập Fuse Bits Thiết Lập Pin Thuật Toán Thuật Toán Điều Khiển PID Thuật Toán Quine MCCluskey Thư viện Protues Thực Hành Thyristor Timer Timer/Counter Tin Học Chia Sẻ Tổ Chức Bộ Nhớ tổng quan về proteus 8 Transistor Tranzito Tranzitor Trao đổi học tập Travel Trình Biên Dịch Trình Dịch Trong Suốt Truyền Thông Nối Tiếp Không Đồng Bộ- UART truyền thông nối tiếp RS232 Tụ điện TUT - 8051 - ASM TUT - 8051 - KeilC tự hành Tự Học C Tự Học Lập Trình C Tý hon UART Update USB Ứng Dụng Led Quảng Cáo ứng dụng mạch khuếch đại thuật toán vẽ mạch in vẽ mạch nguyên lý VHDL Vi Điều Khiển Vi điều khiển - Ứng dụng vi điều khiển PIC Vi mạch số Vi Xử Lý Vi Xử Lý 8051 Vi Xử Lý 8086 Vi Xử Lý ARM Vi Xử Lý PIC Video Video Mach Điện Virtual Serial Port Driver VOM vxl Web Design xác định góc quay động cơ xử lý chuỗi
Hiển thị các bài đăng có nhãn Tài liệu robocon. Hiển thị tất cả bài đăng

I.TIMER – COUNTER TRÊN ATMEGA8.

-Vi điều khiển Atmega8 gồm có 3 bộ Timer – Counter:

Ø 2 bộ Timer – Counter 8 bit: TIMER0TIMER2.
Ø1 bộ Timer – Counter 16 bit: TIMER1.
-Timer – Counter có các chế độ hoạt động chính :
ØChế độ định thời.
ØChế độ đếm sự kiện.
ØChế độ tạo xung điều rộng PWM (chỉ có trong bộ TIMER1 và TIMER2).
ØChế độ Input Capture (trong bộ TIMER1).
-Các thanh ghi dùng để điều khiển các bộ TIMER: TCNTx, TCCRx, TIMSK...
(các bạn tham khảo thêm ở datasheet của Atmega8 để biết về các chế độ và thanh ghi của các bộ TIMER).
Trên đây là khái quát chung về các bộ Timer trong vi điều khiển Atmega8, để hiểu rõ cách điều khiển và sử dụng chúng, ta sẽ đi vào các bài toán cụ thể.

II.CÁC CHẾ ĐỘ HOẠT ĐỘNG CỦA TIMER – COUNTER.

Ở đây, chúng tôi sẽ nói rõ với các bạn 2 chế độ: định thời và đếm sự kiện của các bộ Timer (cụ thể với TIMER1). Chế độ tạo PWM và Input Capture chúng tôi xin viết vào 2 bài riêng biệt để giúp các bạn nắm rõ, qua đó áp dụng vào các bài toán điều khiển thực tế.
1.CHẾ ĐỘ ĐỊNH THỜI.
-Ở chế độ này, TIMER1 hoạt động như sau: khi có tín hiệu kích, thanh ghi đếm TCNT1 sẽ tăng từ 0 đến 65535 tức là 0xFFFF (TCNT0 tăng từ 0 đến 0xFF), khi xảy ra tràn TCNT1 quay về 0. Dựa vào cơ chế này chúng ta sẽ tạo ra được những khoảng thời gian mong muốn.
-Bài toán đặt ra: điều khiển nhấp nháy LED với khoảng thời gian 1s được tạo bởi TIMER1.
Để thực hiện bài toán này chúng ta phải:
ØThiết lập chế độ thường (normal) cho TIMER1 bằng 2 thanh ghi TCCR1A, TCCR1B.
ØThiết lập bộ chia tần số hoạt động cho TIMER1 (chính là tín hiệu kích) bằng các bit CS1x trên thanh ghi TCCR1B.
[IMG]
ØTính toán giá trị cho thanh ghi TCNT1:
Giá trị TCNT1 được thiết lập: TCNT1 = 65535 – T*(F/n).
Trong đó:
·65535 là giá trị lớn nhất mà thanh ghi TCNT1 có được (TCNT0 là 255).
·F: tần số của vi điều khiển. vd : 8000
·N: bộ chia tần số cho Timer. vd : TCCR1B=0x04 ( 256)
·T: thời gian cần định thời. vd : 1000ms
 => TCNT1 = 65535 - 1000*(8000/256) = 34285 (đổi ra HEX = 85ED)
(các bạn tính toán tương tự đối với TIMER0)
Như vậy, TCNT1 sẽ tăng từ giá trị khởi tạo đến 0xFFFF và tràn về 0, khoảng thời gian đó chính là thời gian định thời mà các bạn cần. Khi bộ đếm Timer tràn, 1 ngắt tràn sẽ xảy ra (khi đã được kích hoạt), tại trình phục vụ ngắt các bạn cho trạng thái LED thay đổi.
Code mẫu:
HTML:
#include 
// TRINH PHUC VU NGAT TRAN TIMER1 interrupt [TIM1_OVF] void timer1_ovf_isr(void) { TCNT1H=0x85ED >> 8; // Khoi tao lai gia tri cho TCNT1 TCNT1L=0x85ED & 0xff; LED=~LED; // Thay doi trang thai cua LED khi TIMER1 tran(sau 1s) // Place your code here } // Declare your global variables here void main(void) { // Declare your local variables here // Ket noi LED voi PORTB.0 // Port B initialization // Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=Out // State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=1 PORTB=0x00; DDRB=0x01; // KHOI TAO TIMER1 TCCR1A=0x00; TCCR1B=0x04; // Chia tan so cho 256 TCNT1H=0x85; // Khoi tao gia tri cho thanh ghi TCNT1, tao khoang thoi gian 1s TCNT1L=0xED; ICR1H=0x00; ICR1L=0x00; OCR1AH=0x00; OCR1AL=0x00; OCR1BH=0x00; OCR1BL=0x00; // Timer(s)/Counter(s) Interrupt(s) initialization TIMSK=0x04; // Kich hoat ngat tran TIMER1 // Global enable interrupts #asm("sei") // Kich hoat ngat toan cuc while (1) { // Place your code here } }
Cách thiết lập chế độ định thời của TIMER1 với CodeVisionAVR:
Tạo Project mới à chọn CodewizardAVR à chọn Timers à chọn Timer1
[IMG]
Các bạn chọn:
-Tần số chia ở Clock Value.
-Chế độ ở Mode.
-Kích hoạt ngắt tràn ở Interrupt on.
-Giá trị khởi tạo cho TCNT1 ở Value.
2.CHẾ ĐỘ ĐẾM SỰ KIỆN.
Như đã nói ở trên, các bộ Timer còn được sử dụng để đếm “sự kiện”, tức là khi có sự thay đổi của tín hiệu ngoài trên chân T1 đối với TIMER1 (T0 đối với TIMER0), thanh ghi TCNT1 sẽ tăng lên 1 đơn vị.
Để sử dụng chế độ này, các bạn phải thiết lập sử dụng nguồn xung bên ngoài với các bit CS1x trên thanh ghi TCCR1B (bảng trên).
Bài toán: Đếm sản phẩm trên một dây chuyền sản xuất, hiển thị lên 4 LED 7 thanh.
Các bạn có thể tham khảo Code mẫu để hiểu rõ hơn chế độ đếm sự kiện của bộ TIMER.
CHÚC CÁC BẠN THÀNH CÔNG!
Các bạn có thể xem Code mẫu và mô phỏng tại đây:

Với các bài viết được THIETKEMACHDIENTU.NET vẽ sẵn, kèm với code mẫu, giúp các bạn học lập trình Pic được nhanh hơn, giúp các bạn tránh khỏi chi phí mua linh kiện thực hành. Các bài vẽ gồm có điều khiển led ma trận. Chúc các bạn học tốt, các bạn tải file vẽ ở cuối bài.




Khi nhấn nút "Tải Về Máy", bạn sẽ vào trang quảng cáo, vui lòng chờ 5 giây. Nút hiện ra ở góc phải phía trên, nhấn vào để đến trang download

Với các bài viết được chúng tôi vẽ sẵn, kèm với code mẫu, giúp các bạn học lập trình Pic được nhanh hơn, giúp các bạn tránh khỏi chi phí mua linh kiện thực hành. Các bài vẽ gồm có điều khiển 8 led đơn kết hợp phím nhấn. Chúc các bạn học tốt, các bạn tải file vẽ ở cuối bài.

Với các bài viết được chúng tôi vẽ sẵn, kèm với code mẫu, giúp các bạn học lập trình Pic được nhanh hơn, giúp các bạn tránh khỏi chi phí mua linh kiện thực hành. Các bài vẽ gồm có điều khiển 8 Led đơn. Chúc các bạn học tốt, các bạn tải file vẽ ở cuối bài.

                                                                      TẢI XUỐNG

Với các bài viết được chúng tôi vẽ sẵn, kèm với code mẫu, giúp các bạn học lập trình Pic được nhanh hơn, giúp các bạn tránh khỏi chi phí mua linh kiện thực hành. Các bài vẽ gồm có điều khiển LCD 16x2 , LCD 20x4. Chúc các bạn học tốt, các bạn tải file vẽ ở cuối bài.








ĐIỆN TỬ CHIA SẺ

Với các bài viết được THIẾT KẾ MẠCH vẽ sẵn, kèm với code mẫu, giúp các bạn học lập trình Pic được nhanh hơn, giúp các bạn tránh khỏi chi phí mua linh kiện thực hành. Các bài vẽ gồm có điều khiển 8 led, điều khiển led ma trận, điều khiển LCD với tín hiệu được nhập vào từ ma trận phím  4x4. Chúc các bạn học tốt, các bạn tải file vẽ ở cuối bài.



Khi nhấn nút "Tải Về Máy", bạn sẽ vào trang quảng cáo, vui lòng chờ 5 giây. Nút hiện ra ở góc phải phía trên, nhấn vào để đến trang download
THIẾT KẾ MẠCH ĐIỆN TỬ
Phạm Văn Ngọc Anh- 01644326695

Với các bài viết được THIẾT KẾ MẠCH vẽ sẵn, kèm với code mẫu, giúp các bạn học lập trình Pic được nhanh hơn, giúp các bạn tránh khỏi chi phí mua linh kiện thực hành. Các bài vẽ mẫu có đa hợp, không đa hơp, giải đa hợp, cũng như ngõ vào 7 đoan, ngõ vào BCD. Giải đa hợp bằng phần cứng cũng như phần mềm.
Sau đây là 1 số hình ảnh mô phỏng kèm file tải bên dưới.








Khi nhấn nút "Tải Về Máy", bạn sẽ vào trang quảng cáo, vui lòng chờ 5 giây. Nút hiện ra ở góc phải phía trên, nhấn vào để đến trang download
THIẾT KẾ MẠCH ĐIỆN TỬ
Phạm Văn Ngọc Anh- 01644326695

Với các bài viết được THIẾT KẾ MẠCH vẽ sẵn, kèm với code mẫu, giúp các bạn học lập trình Pic được nhanh hơn, giúp các bạn tránh khỏi chi phí mua linh kiện thực hành. Các bài vẽ mẫu có đa hợp, không đa hơp, giải đa hợp, cũng như ngõ vào 7 đoan, ngõ vào BCD. Giải đa hợp bằng phần cứng cũng như phần mềm.
Sau đây là 1 số hình ảnh mô phỏng kèm file tải bên dưới.


Khi nhấn nút "Tải Về Máy", bạn sẽ vào trang quảng cáo, vui lòng chờ 5 giây. Nút hiện ra ở góc phải phía trên, nhấn vào để đến trang download
THIẾT KẾ MẠCH ĐIỆN TỬ
Phạm Văn Ngọc Anh- 01644326695

Bấm xem ảnh ở cửa sổ mới

Robocon đã được tổ chức từ năm 2002.Cuộc thi này đã cuốn hút rất nhiều bạn sinh viên có niềm đam mê khoa học kĩ thụât.Cuộc thi này đã đem lại cho chúng ta rất nhiều những kiến thức về kĩ thuật ,rèn luyện đức tính kiên trì ,bền bỉ ,dám  đối mặt với gian khổ .Hơn nữa ,cuộc thi  đã  để lại những kỉ niệm đẹp về một thời sinh viên.

Giáo  trình này được biên soạn nhằm giúp các bạn có được một cái nhìn tổng quan về robot ,sự định hướng cụ thể và những kinh nghiệm quý báu khi tham gia robocon
Giáo trình gồm 8 bài :
Bài 1: Giới thiệu về Robot Các Modul của robot.
Bài 2: Mạch điều khiển robot bằng tay.
Bài 3: Mạch cảm biến dò đường.
Bài 4: Mạch công suất điều khiển động cơ .
Bài 5: Mạch vi điều khiển.
Bài 6: Lập trình và kỹ thuật dò đường .
Bài 7: Lập trình các thao tác khác và chiến thuật. 




Thuật Toán Quine MCCluskey


Mạch logic tổ hợp là một phần công cụ để chúng ta thiết kế các mạch điện tử. Bởi thế các phương pháp rút gọn mạch logic tổ hợp là một phần quan trọng trong kiến thức môn học Điện tử số. Nó có nhiều ứng dụng lớn trong nhiều lĩnh vực của điện tử.
Phương pháp Quine MC Cluskey là phương pháp rút gọn mạch logic tổ hợp có thể tối thiểu được hàm nhiều biến và có thể tiến hành rút gọn nhờ chương trình lập trình được trên máy tính.

Các bước tối thiểu hóa: 
Gồm 4 bước cơ bản sau:
1. Lập bảng liệt kê các hạng tích dưới dạng nhị phân theo từng nhóm với số bit 1 giống nhau và xếp chúng theo số bit 1 tăng dần.
2. Gộp 2 hạng tích của mỗi cặp nhóm chỉ khác nhau 1 bit để tạo các nhóm mới. Trong mỗi nhóm mới, giữ lại các biến giống nhau, biến bỏ đi thay bằng một dấu ngang (-).
3. Lặp lại cho đến khi trong các nhóm tạo thành không cịn khả năng gộp nữa. Mỗi lần rút gọn, ta đánh dấu  #  vào các hạng ghép cặp được. Các hạng không đánh dấu trong mỗi lần rút gọn sẽ được tập hợp lại để lựa chọn biểu thức tối giản.
4. Lập bảng lựa chọn hàm.
Ta thiết lập các số hạng có thể có trong biểu thức bằng cách thay dấu gạch ngang bằng các giá trị 0 và 1 sau đó đánh dấu ký hiệu “x” dưới vị trí mà nó chứa số hạng đó.
Sau đó ta xem xét các cột chỉ chứa một dấu “x”. Các dấu “x” này đã bao quát hết tất cả các hạng tích của hàm đã cho. Do vậy, các biểu thức đó là các hạng tích đã tối giản.

Chương trình giải quyết được các bài toán phức tạp một cách nhanh chóng, kết quả được lưu trong file *.txt cùng thư mục của chương trình.

Mã nguồn:


#include<stdio.h>
#include<conio.h>
#include<math.h>
#include<string.h>
#define line printf("\n===================\n");
void doinhiphan(int x,int n,int minterm[],int nhiphan[][100]);
void nhap(int n,int minterm[]);
void sosanh(int x,int n,int nhiphan[][100],int &a,int &b);
void hienthi(int x,int nhiphan[][100],int b);
void ketqua(int x,int n,int nhiphan[][100],int a,int b,int &d);
void inraFILEhamnhap(int minterm[],int x,int n);
void inraFILErutgon(int nhiphan[][100],int b,int x);
void inraFILECACNHOM(int nhiphan[][100],int a,int b,int x,int d);
void inraFILEkq(int nhiphan[][100],int a,int b,int x,int d);

int main()
{
  int x,n;
  printf("Nhap vao so bien cua ham: ");
  scanf("%d",&x);
  printf("Nhap vao so minterm cua ham: ");
  scanf("%d",&n);
  int minterm[n],nhiphan[1000][100],a=0,b=n;//2 bien a,b danh dau lai khoang dau va cuoi mang sau 1 lan sosanh
  int d=0;//dem so thu tu cac NHOM TUY CHON co the dai dien het cac phan tu con sot lai.
 
         nhap(n,minterm);
 inraFILEhamnhap(minterm,x,n);
         doinhiphan(x,n,minterm,nhiphan);
  line;
    hienthi(x,nhiphan,b);
       sosanh(x,n,nhiphan,a,b);
  line;
    hienthi(x,nhiphan,b);
    inraFILErutgon(nhiphan,b,x);
  line;
       ketqua(x,n,nhiphan,a,b,d);
  inraFILECACNHOM(nhiphan,a,b,x,d);
  line;
   hienthi(x,nhiphan,b);
    inraFILEkq(nhiphan,a,b,x,d);
 getch(); 
}


void doinhiphan(int x,int n,int minterm[],int nhiphan[][100])
{
     for(int i=0;i<n;i++)
   for(int j=0;j<x+1;j++)
   {
          nhiphan[i][j]=0;
     }

  for(int i=0;i<n;i++)
  for(int j=0;minterm[i]>0;j++)
  {
          nhiphan[i][x-1-j]=minterm[i]%2;
          minterm[i]=minterm[i]/2;       
     }
}


void nhap(int n,int minterm[])
{
     for(int i=0;i<n;i++)
     {
          printf("Nhap minterm %d: ",i+1);
          scanf("%d",&minterm[i]);
     }
}


void hienthi(int x,int nhiphan[][100],int b)
{
     for(int i=0;i<b;i++)
  {
          for(int j=0;j<x+1;j++)
          {
                   printf("%d ",nhiphan[i][j]);
             }
             printf("\n");
          if(nhiphan[i][x]==3) printf("\n----\n");
    } 
}


void sosanh(int x,int n,int nhiphan[][100],int &a,int &b)
{
     int g,count2,kt=0,i,count2B/*khai bao o day de dung dc cho while*/;
     do
     {
          count2B=0;//chi dung trong 1 chu ky cua vong for(i),neu count2B>0 tuc la van phai rut gon tiep
          count2=0;//de dem so luot ghi lai 2minterm chi #nhau 1bit,sau do thay b=b+count2;
       for(i=a;i<b;i++)
       {
               int count4=0;//kt minterm sot hay ko
               for(int j=a;j<b;j++)
         {
              int count=0;//kiem tra 2 day minterm khac nhau 1 hay nhieu bit.      
              for(int k=0;k<x;k++)
              {
                if(nhiphan[i][k]!=nhiphan[j][k])
                {
                                    g=k;//danh dau k bang g, g chi co y nghia trong TH count==1.
                                    count++;
                               }
    
                       }
                       if(count>1) count4++;
                      
                       //truong hop # nhau 1 bit:             
                       if(count==1)//lenh if trong vong for cua 'j'.
              {    
              for(int k=0;k<x;k++)//coppy minterm da rut gon vao cuoi mang nhiphan[][].
              {
                                   if(k!=g)
                                     nhiphan[b+count2][k]=nhiphan[i][k]; 
                         else nhiphan[b+count2][g]=2;//=2 thay cho dau '-', nhiphan[j][g] ko can phai =2.
                             }
     
                              //kiem tra xem da ton tai minterm nao giong no chua:
                              for(int m=b;m<b+count2;m++)
                  {
                              int count3=0;//kt ton tai minterm giong nhau ko.
                           for(int n=0;n<x;n++)
                           {
                               if(nhiphan[m][n]==nhiphan[b+count2][n])
                               count3++;
                                      }
                            if(count3==x)
                       nhiphan[b+count2][g]=3;
                              }
                if(nhiphan[b+count2][g]!=3)//neu ko co cai nao giong thi tang cac chi so len<=>luu no.
                {
                                   count2++;
                 count2B++;
                                 nhiphan[b-1][x]=3;/*chu y trong vai TH*/   //danh dau cho~ cuoi cua 1 chu trinh ss de ham deplay chia khoang cho dep^^.
                              }
                }//ket thuc TH #1. 
        }//ket thuc for(j)
       
               //TH con sot minterm trong luot ss dau tien vi sai # >1 bit voi tat ca cac minterm con lai:        
         if(count4==b-a-1) //de dam bao: minterm nay #>2bit voi tat ca.
         {
                    for(int k=0;k<x;k++)
         {
                   nhiphan[b+count2][k]=nhiphan[i][k];//coppy minterm (#nhau 2bit tro len)nay vao cuoi mang nhiphan[][].
                    }
        count2++;
               }
    }//ket thuc for(i)
   
    if(count2!=0&&count2B>0)//dam bao luc ket thuc chu trinh (tuc count2==0&&count2B==0) thi ko can thay doi a,b
    {
            a=b;//2 bien a,b danh dau lai khoang dau va cuoi mang sau 1 lan sosanh
         b=b+count2;
       }
     }while(count2B>0);//neu sau 1 chu ky sosanh ma count2B van =0 => ket thuc.
}

void ketqua(int x,int n,int nhiphan[][100],int a,int b,int &d)
{
     int i,j,k,count;
     printf("%d_%d_%d\n",n,a,b);

     //1.reset cac minterm nhiphan[0->b][x]=0:
     for(i=0;i<b;i++)
          nhiphan[i][x]=0;

     //2.danh dau cac cot chi chua 1 dau X:
     for(i=a;i<b;i++)
     {
          for(j=0;j<n;j++)
          {
               count=0;
               for(k=0;k<x;k++)
               {
                    if(nhiphan[i][k]!=2&&nhiphan[i][k]!=nhiphan[j][k])
                    count++;
               }
               if(count==0)
               nhiphan[j][x]++;//DANH DAU = SO LAN LAP LAI PHAN TU DO
          }
     }
     //3.tu cac cot chi chua 1 dau X tim lai cac minterm tao ra dau X do:
     for(i=0;i<n;i++)
     {
          if(nhiphan[i][x]==1)
          for(j=a;j<b;j++)
          {
               count=0;
               for(k=0;k<x;k++)
               {
                    if(nhiphan[j][k]!=2&&nhiphan[i][k]!=nhiphan[j][k])
                    count++;
               }
               if(count==0)
               nhiphan[j][x]=3;//DANH DAU (=3)
          }
     }

     //4.DANH DAU CAC PHAN TU XUAT HIEN >1 LAN, NHUNG DA NAM TRONG CAC NHOM BAT BUOC:
     for(i=a;i<b;i++)
     {
          if(nhiphan[i][x]==3)
      for(j=0;j<n;j++)
      {
         count=0;
            for(k=0;k<x;k++)
            {
                 if(nhiphan[i][k]!=2&&nhiphan[i][k]!=nhiphan[j][k])
                 count++;
               }
            if(count==0)
               nhiphan[j][x]=77;//DANH DAU: THUOC NHOM BAT BUOC (=77)
          }
      }   

      //5.TU CAC PHAN TU CON SOT LAI - CHUA NAM TRONG NHOM BAT BUOC(#77), DANH DAU TAM THOI CAC NHOM CO THE DAI DIEN CHO NO(=4):
      for(i=0;i<n;i++)
      {
           if(nhiphan[i][x]!=77)
           for(j=a;j<b;j++)
           {
                count=0;
                for(k=0;k<x;k++)
                {
                     if(nhiphan[j][k]!=2&&nhiphan[i][k]!=nhiphan[j][k])
                     count++;
                }
                if(count==0)
                nhiphan[j][x]=4;//DANH DAU TAM THOI(=4), DE KT TIEP XEM CO DU DK DAI DIEN KO!
           }
      }

      //6.KIEM TRA LAI CAC NHOM VUA DANH DAU (=4) XEM CO DAI DIEN HET CHO CAC PHAN TU CON SOT LAI KO:  
      for(i=a;i<b;i++)
      {
           if(nhiphan[i][x]==4)
           {
                count=0;
                for(j=0;j<n;j++)
                {
                     if(nhiphan[j][x]!=77)
                     for(k=0;k<x;k++)
                     {
                          if(nhiphan[i][k]!=2&&nhiphan[i][k]!=nhiphan[j][k])
                          count++;
                     }
                }
                if(count==0)
                {
                  d++;
                     nhiphan[i][x]=30+d;//neu NHOM do dai dien dc het, thi danh dau (=3X) de tien sau nay in ra het cac TH KQ co the co.
                }
           }
      }

      //+++++++++++++++++++++++++++
      //7A.hien thi cac minterm vua danh dau xong(CA NHOM BAT BUOC VA TUY CHON):
      if(d==0)
      {
           count=0;
           for(i=a;i<b;i++)
           {
                if(nhiphan[i][x]==3)
                {
                     if(count==1) printf(" + ");
                     for(j=0;j<x;j++)
                     {
                          if(nhiphan[i][j]==1)
                    {
                printf("%c",65+j);
                count=1;
                          }
                       if(nhiphan[i][j]==0)
                    {
                printf("%c",97+j);
                count=1;
                          }
                     }
                }  
           }
      }
      if(d!=0)
      {
           for(int e=1;e<=d;e++)
           {
                //7B.HIEN THI CAC NHOM BAT BUOC:
                count=0;
                for(i=a;i<b;i++)
                {
                     if(nhiphan[i][x]==3)
                     {
                          if(count==1) printf(" + ");
                          for(j=0;j<x;j++)
                          {
                               if(nhiphan[i][j]==1)
                         {
                     printf("%c",65+j);
                     count=1;
                               }
                            if(nhiphan[i][j]==0)
                         {
                         printf("%c",97+j);
                     count=1;
                               }
                          }
                     }  
                }
                //7C.HIEN THI CAC NHOM TUY CHON:
                for(i=a;i<b;i++)
                {
                     if(nhiphan[i][x]==30+e)
                     {
                          printf(" + ");
                          for(j=0;j<x;j++)
                          {
                               if(nhiphan[i][j]==1)
                         {
                     printf("%c",65+j);
                     count=1;
                               }
                            if(nhiphan[i][j]==0)
                         {
                     printf("%c",97+j);
                     count=1;
                               }
                          }
                     }  
                }  
                if(e!=d) printf("\nHOAC:\n");
           }
      }
}


void inraFILEhamnhap(int minterm[],int x,int n)
{
     FILE *dtv;
     dtv=fopen("DTV.txt","a+");
          fprintf(dtv,"\n\nF(");
          for(int i=0;i<x;i++)
          {
                if(i>0) fprintf(dtv,",");
                  fprintf(dtv,"%c",65+i);
          }
          fprintf(dtv,")= {");
          for(int i=0;i<n;i++)
          {   
                if(i>0) fprintf(dtv,",");
                  fprintf(dtv,"%d",minterm[i]);
          }
          fprintf(dtv,"}\n");
     fclose(dtv);
}


void inraFILErutgon(int nhiphan[][100],int b,int x)
{
     FILE *dtv;
     dtv=fopen("DTV.txt","a+");
          for(int i=0;i<b;i++)
       {
               if(i+1<10) fprintf(dtv,"0%d  ",i+1);
               if(i+1>=10) fprintf(dtv,"%d  ",i+1);
               for(int j=0;j<x;j++)
               {
                       if(nhiphan[i][j]==2) fprintf(dtv,"-");
                       else
                    fprintf(dtv,"%d",nhiphan[i][j]);
                  }
            fprintf(dtv,"\n");
            if(nhiphan[i][x]==3) fprintf(dtv,"----\n");
          }
          //fprintf(dtv,"========================\n");
     fclose(dtv);  
}


void inraFILECACNHOM(int nhiphan[][100],int a,int b,int x,int d)
{
     FILE *dtv;
     dtv=fopen("DTV.txt","a+");
          if(d==0)
          {
               fprintf(dtv,"----\n");
               fprintf(dtv,"NHOM BAT BUOC:  ");         
         for(int i=a;i<b;i++)
            {
                    for(int j=0;j<x;j++)
                    {
                            if(nhiphan[i][x]==3)
                            if(nhiphan[i][j]==2) fprintf(dtv,"-");
                            else fprintf(dtv,"%d",nhiphan[i][j]);
                       }
                    if(nhiphan[i][x]==3&&i!=b-1) fprintf(dtv," ; ");
               }
          }
          if(d!=0)
          {
               fprintf(dtv,"----\n");
               fprintf(dtv,"NHOM BAT BUOC:  ");         
         for(int i=a;i<b;i++)
            {
                    for(int j=0;j<x;j++)
                    {
                            if(nhiphan[i][x]==3)
                            if(nhiphan[i][j]==2) fprintf(dtv,"-");
                            else fprintf(dtv,"%d",nhiphan[i][j]);
                       }
                 if(nhiphan[i][x]==3&&i!=b-1) fprintf(dtv," ; ");
               }
               fprintf(dtv,"\nNHOM TUY CHON:  ");
         for(int i=a;i<b;i++)
            {
                    for(int j=0;j<x;j++)
                    {
                            if(nhiphan[i][x]>=31)
                            if(nhiphan[i][j]==2) fprintf(dtv,"-");
                            else fprintf(dtv,"%d",nhiphan[i][j]);
                       }
                 if(nhiphan[i][x]>=31&&nhiphan[i][x]!=30+d) fprintf(dtv," ; ");
               }         
          }
          fprintf(dtv,"\n========================\n");
     fclose(dtv);
}


void inraFILEkq(int nhiphan[][100],int a,int b,int x,int d)
{
     FILE *dtv;
     dtv=fopen("DTV.txt","a+");
          //TH CHI CO CAC NHOM BAT BUOC, KO CO NHOM TUY CHON!                    
          if(d==0)
          {
               fprintf(dtv,"F(");
               for(int i=0;i<x;i++)
               {
                     if(i>0) fprintf(dtv,",");
                       fprintf(dtv,"%c",65+i);
               }
               fprintf(dtv,")= ");
               int count=0;
               for(int i=a;i<b;i++)
               {
                       if(nhiphan[i][x]==3)
                       {
                            if(count==1) fprintf(dtv," + ");
                            for(int j=0;j<x;j++)
                            {
                                    if(nhiphan[i][j]==1)
                              {
                                fprintf(dtv,"%c",65+j);
                          count=1;
                                    }
                                 if(nhiphan[i][j]==0)
                              {
                                fprintf(dtv,"%c",97+j);
                          count=1;
                                    }
                            }
                       }
               }
          }
          //TH CO CA NHOM BAT BUOC VA NHOM TUY CHON!
          if(d!=0)
          {
               for(int e=1;e<=d;e++)
               {
                       fprintf(dtv,"F(");
                       for(int i=0;i<x;i++)
                       {
                             if(i>0) fprintf(dtv,",");
                               fprintf(dtv,"%c",65+i);
                       }
                       fprintf(dtv,")= ");
                       //HIEN THI CAC NHOM BAT BUOC:
                       int count=0;
                       for(int i=a;i<b;i++)
                       {
                               if(nhiphan[i][x]==3)
                               {
                                    if(count==1) fprintf(dtv," + ");
                                    for(int j=0;j<x;j++)
                                    {
                                            if(nhiphan[i][j]==1)
                                      {
                                  fprintf(dtv,"%c",65+j);
                                  count=1;
                                            }
                                         if(nhiphan[i][j]==0)
                                      {
                                  fprintf(dtv,"%c",97+j);
                                  count=1;
                                            }
                                    }
                               }  
                       }
                       //HIEN THI CAC NHOM TUY CHON:
                       for(int i=a;i<b;i++)
                       {
                               if(nhiphan[i][x]==30+e)
                               {
                                    fprintf(dtv," + ");
                                    for(int j=0;j<x;j++)
                                    {
                                            if(nhiphan[i][j]==1)
                                      {
                                  fprintf(dtv,"%c",65+j);
                                  count=1;
                                            }
                                         if(nhiphan[i][j]==0)
                                      {
                                  fprintf(dtv,"%c",97+j);
                                  count=1;
                                            }
                                    }
                               }  
                       }
                       if(e!=d) fprintf(dtv,"\nHOAC:\n");
               }  
          }
          fprintf(dtv,"\n========================\n");
     fclose(dtv);  
}

Author Name

{picture https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjN0PUWA2genMqX3Sm26mBTX_30OJgDenoIi4K6BR-E1vl3nI7LALp0X759QZgzqrMcGBB7jEbdZnubJbp4n2ZZ22KT196CWCg9DLs3MfEivocdmkjZEPEn-A42hyphenhyphen9dmsca0VIDQr_LjqM/s512-Ic42/pham-van-ngoc-anh.jpg}

Tôi là Ngọc Anh. Tôi đến từ Nghệ An. Tôi tốt nghiệp một trường đại học tại Sài Gòn. Hiện tôi đang phát triển công ty riêng. Liên lạc với tôi qua:

{facebook https://www.facebook.com/phamvanngocanh}
{twitter https://twitter.com/nghiphong1993}
{google https://plus.google.com/+dientuchiase/posts}
{youtube https://www.youtube.com/channel/UCeJKhA_goBNFmDw6RKNtmYQ}

Biểu mẫu liên hệ

Tên

Email *

Thông báo *

Được tạo bởi Blogger.