PIC Vietnam

Go Back   PIC Vietnam > Microchip PIC > PIC - Thiết kế và Ứng dụng

Tài trợ cho PIC Vietnam
Trang chủ Đăng Kí Hỏi/Ðáp Thành Viên Lịch Tìm Kiếm Bài Trong Ngày Ðánh Dấu Ðã Ðọc Vi điều khiển

PIC - Thiết kế và Ứng dụng Ý tưởng cho các sản phẩm sử dụng PIC/dsPIC và các sản phẩm của Microchip

 
 
Ðiều Chỉnh Xếp Bài
Prev Previous Post   Next Post Next
Old 28-01-2015, 10:09 AM   #1
tvnghia91
Nhập môn đệ tử
 
Tham gia ngày: Dec 2014
Bài gửi: 5
:
HỎi vỀ pic

các bạn chỉ dùm mình vấn đề này với : mình làm mạch tính suất liều dùng pic 16f877a, f =4mhz, code mình viết xong rồi, kiểm tra không có lổi, nhưng khi chạy mô phỏng thử thì nó không chạy. các bạn ai biết do chổ nào thì giúp đở mình với

CODE:

#include <16F877A.h>
#device adc=8

#FUSES NOWDT //No Watch Dog Timer
#FUSES XT //Crystal osc <= 4mhz
#FUSES NOPUT //No Power Up Timer
#FUSES NOPROTECT //Code not protected from reading
#FUSES NODEBUG //No Debug mode for ICD
#FUSES NOBROWNOUT //No brownout reset
#FUSES NOLVP //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#FUSES NOCPD //No EE protection
#FUSES WRT_50% //Lower half of Program Memory is Write Protected

#use delay(clock=4000000)
#use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bi ts=8)

#include <float.h>
#include <math.h>
#include <stdio.h>
#include <string.h>

//#define SET RB1
//#define OK RB2

unsigned char ngan = 0, tram = 0, chuc = 0, dvi = 0, time, SET=0, OK =0, i;
unsigned int8 pulse = 0, secon = 0, ARM = 0;
unsigned int16 count = 0, sum = 0, B[3], so_xung;
float32 HS_gamma, Dose, average;
unsigned char ma_led[] = {0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xF8, 0x80, 0x90};

#int_RB
void ngat_RB(void)
{
for(SET=0;SET<3;SET++)
{
OK++;
}
}
#int_RDA
void RDA_isr(void)
{
//RS232
}
#int_TIMER1
void TIMER1_isr(void)
{
//count++;
}
// bo tao thoi gian 1s //
#int_TIMER2 // ngat tran timer2
void TIMER2_isr(void)
{
//set_timer2(0);
pulse++;
if(pulse>=255) // tao khoang thoi gian 1s
{
secon++;
//so_xung = count;
pulse = 0;
}
}
#int_TIMER0
void TIMER0_isr(void)
{
//
}
// HIEN THI LED 7 DOAN
void hienthiled(int32 number)
{
if (number > 9999)
{
number = 0;
}
else
// tinh cac so hang dvi, chuc, tram, ngan
dvi = number % 10;
number = number / 10;
chuc = number % 10;
number = number / 10;
tram = number % 10;
number = number / 10;
ngan = number;
// hien thi hang don vi
output_high (pin_b7);
output_D (ma_led[dvi]);
output_low (pin_b4);
delay_ms (1);

// hien thi hang chuc
output_high (pin_b4);
output_D (ma_led[chuc]);
output_low (pin_b5);
delay_ms (1);

// hien thi hang tram
output_high (pin_b5);
output_D (ma_led[tram]);
output_low (pin_b6);
delay_ms (1);

// hien thi hang ngan
output_high (pin_b6);
output_D (ma_led[ngan]);
output_low (pin_b7);
delay_ms (1);
}
void main()
{
//output_bit(PIN_B1,0);
//output_bit(PIN_B2,0);
set_tris_D (0xff);
setup_adc_ports (NO_ANALOGS);
setup_adc (ADC_OFF);
setup_psp (PSP_DISABLED);
setup_spi (SPI_SS_DISABLED);
setup_timer_0 (RTCC_INTERNAL|RTCC_DIV_1);
setup_timer_1 (T1_EXTERNAL|T1_DIV_BY_4|T1_CLK_OUT);
setup_timer_2 (T2_DIV_BY_16, 255, 1);
setup_comparator (NC_NC_NC_NC);
setup_vref (FALSE);
enable_interrupts (int_RB);
enable_interrupts (int_RDA);
enable_interrupts (int_TIMER1);
enable_interrupts (int_TIMER2);
enable_interrupts (int_TIMER0);
enable_interrupts (GLOBAL);

while (TRUE)
{
so_xung = get_timer1 (); // lay gia tri cua timer1 dem duoc
if (secon == time)
{
B[i] = so_xung;
i++;
if(i>5)i=0; // lay 6 gia tri ( 6 lan de tinh trung binh )
sum = 0;
for(i=0;i<6;i++)
sum+=B[i]; // lay tong 6 gia tri theo bien i chay
average = sum/6; // gia tri trung binh duoc tinh
Dose = (average* HS_gamma) / (time);
Setup_timer_1 (T1_INTERNAL|T1_DIV_BY_4);
Set_timer1 (0);

}
if((input((pin_b1)==0))&&(input((pin_b2)==0)))
{
// hienthiled(dose);
}
if((input((pin_b1)==1))&&(input((pin_b2)==0)))
{
ARM=50;
hienthiled(ARM);
}
if((input((pin_b1)==1))&&(input((pin_b2)==1)))
{
if((set==0)&&(ok==0))
{
ARM =50;
time = 30;
if(dose>=ARM)
{
output_high(PIN_C2);
}
else
hienthiled(dose);
}
if((set==1)&&(ok==1))
{
ARM=100;
time=45;
if(dose>=ARM)
{
output_high(PIN_C2);
}
else
hienthiled(dose);
}
if((set==2)&&(ok==2))
{
ARM=150;
time=60;
if(dose>=ARM)
{
output_high(PIN_C2);
}
else
hienthiled(dose);
}
}
}
}
Hình Kèm Theo
File Type: png so do 1.PNG (30.0 KB, 3 lần tải)
tvnghia91 vẫn chưa có mặt trong diễn đàn   Trả Lời Với Trích Dẫn
 

Ðiều Chỉnh
Xếp Bài

Quyền Sử Dụng Ở Diễn Ðàn
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is Mở
Smilies đang Mở
[IMG] đang Mở
HTML đang Tắt

Chuyển đến


Múi giờ GMT. Hiện tại là 07:33 PM.


Được sáng lập bởi Đoàn Hiệp
Powered by vBulletin®
Page copy protected against web site content infringement by Copyscape
Copyright © PIC Vietnam