PIC Vietnam

PIC Vietnam (http://www.picvietnam.com/forum/index.php)
-   Các ngôn ngữ lập trình khác (CCS C, HT PIC,...) (http://www.picvietnam.com/forum/forumdisplay.php?f=12)
-   -   Bác nào xem hộ cái code xem em tính trung bình thế này đúng chưa? (http://www.picvietnam.com/forum/showthread.php?t=6131)

vanlv 12-04-2010 01:32 PM

Bác nào xem hộ cái code xem em tính trung bình thế này đúng chưa?
 
Em đang lập trình cho con 877A bằng CCS 4.049 để nó đếm xung phóng xạ. Vì là xung phóng xạ nên nó xảy ra trong thời gian rất ngắn nên em chỉ sợ code của em lỗi ở phần tính TB. Đây là code của em, các bác xem giúp. Em mới chơi với con PIC này có trong thời gian ngắn mà lại phải làm đồ án tốt nghiệp luôn nên rất mong anh em giúp đỡ:


#include <16F877A.h>
#include <def_877a.h>
//#device *=16
#include <math.h>
#include <stdlib.h>
#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


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

#include <lcd_lib_4bit.c>

unsigned int32 count=0,tb=0,tong=0;
unsigned int32 a[11];
void hv();
void average();

//------------------------------------

#int_EXT
void EXT_isr()
{
count=get_timer1();
set_timer1(0);
//printf(" %6ld\n",count);
hv();
}

//-------------------------------------
void average() //Ctrinh con tinh gia tri trung binh
{
int8 i;
tong=0;
tb=0;
for(i=0;i<=10;i++)
{

a[i]=count;
tong+=a[i];
tb=tong/11; //Hoi ve phan nay
}

}
//=====================================

void main()
{

setup_adc_ports(NO_ANALOGS);
setup_adc(ADC_OFF);
setup_psp(PSP_DISABLED);
setup_spi(SPI_SS_DISABLED);
setup_timer_0(RTCC_DIV_256|RTCC_INTERNAL);
setup_timer_1(T1_DIV_BY_1|T1_EXTERNAL);
setup_timer_2(T2_DISABLED,0,1);
setup_vref(FALSE);

enable_interrupts(INT_EXT);
enable_interrupts(GLOBAL);
ext_int_edge(H_TO_L);

//set_timer0(5);
set_timer1(0);


TRISA=0x00;
TRISB=0x01;
TRISE=0x00;
TRISC=0x01;
// TODO: USER CODE!!
tong=0;
tb=0;
hv();
lcd_init();

while(TRUE)
{
hv();
average();
printf(" %6ld\n",tb);

lcd_putcmd(0x01);
lcd_putcmd(0x80);
lcd_putchar("START");
lcd_putcmd(0xC0);
lcd_putchar("GET VALUE");
delay_ms(500);
lcd_putcmd(0x01);

}
}

//====================================
void hv() //ctrinh con dieu khien cao ap
{

output_low(PIN_C1);
output_high(PIN_C1);
}
//------------------------------------

Nội dung cần làm như sau: khi có ngắt ngoài pic sẽ đếm bằng timer1 và gán vào biến count. giá trị của count vừa nhận được lại được gán cho 1 biến a[i] rồi tính trung bình của i giá trị của mảng vừa nhận được và reset mảng vể 0 để tiếp tục nhận giá trị mới.

vanlv 04-05-2010 11:56 PM

Không ai trả lời thì em nhờ MOD xóa giùm bài này với. Để đó cho chật đất của mọi người.

0903579509 05-05-2010 02:17 PM

Không ai trả lởi bạn cũng không nên nóng vội như vậy.
Tôi góp ý thế này:
Có lẻ mục đích của bạn là đếm số xung trong một thời gian nhất định, thực hiện 10 lần như vậy sau đó lấy giá trị trung bình? và cứ lặp lại như vậy.
Theo code trên thì a[i] có giá trị giống nhau trong average() , vì khi thực hiện average() count có giá trị không đổi, nó chỉ có thể thay đổi khi có ext_int. Vậy việc tính giá trị trung bình ở đây không có ý nghĩa.

Bạn nên thực hiện ý tưởng này:
Lấy T1 làm bộ đếm xung phóng xạ
lấy T0 làm bộ định khỏang thời gian ( thông thường là 1 giây hoặc 0.1 giây) và lấy mẫu
lấy một biến nào đó để đếm số lần lấy mẫu (n chẳng hạn).
Dùng ngắt T0 để lấy mẫu gán vao a[i] và tăng n, khi n = 10 thì thực hiện average()

Nếu bạn nêu rỏ ý tưởng và schema tôi sẽ giúp bạn, công việc này không khó lắm đâu.
Thân.


Múi giờ GMT. Hiện tại là 08:05 AM.

Tên diễn đàn: vBulletin Version 3.8.11
Được sáng lập bởi Đoàn Hiệp.
Copyright © PIC Vietnam