-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtemp.c
55 lines (55 loc) · 1.4 KB
/
temp.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
double temperatura(void) //očitavanje temperature
{
FILE *ft;
char tekst[100];
ft=fopen("/sys/bus/w1/devices/28-00000a41dec3/w1_slave","r");
if(ft==NULL) return 0;
int i=0;
for(i=0;i<22;i++) //samo temperatura
fscanf(ft,"%s", tekst);
fclose(ft);
//obrisati „t=”
for(i=0;i<10;i++) tekst[i]=tekst[i+2];
int temp=atoi(tekst); //prebaci u double
double tem=(double)temp/1000;
return tem;
};
void zapis(double temp) //log metod
{
FILE * log;
log=fopen("log","a+"); //otvoriti datoteku
if(log==NULL) return;
fprintf(log, "\n%.3f", temp);
fclose(log);
};
int main(void)
{
FILE * log;
int cz=0, j=0;
struct timespec ts1, ts2; //merenje vremena
long czas;
log=fopen("log","w");
if(log==NULL) return 0;
fprintf(log, "\n\t\t***Temperatura***\nIzmerena temperatura = %.3f \xC2\xB0 C\t C\n",temperatura());
fclose(log);
printf("\n\nPočetna Temp = %.3f \xC2\xB0 C", temperatura());
while(1)
{
j++; //broj iteracija
clock_gettime(CLOCK_REALTIME, &ts1);
printf("\nMerenje br. %d.\tTemp = %.3f\xC2\xB0 C", j, temperatura());
clock_gettime(CLOCK_REALTIME, &ts2);
//trajanje pojedinacnog //merenja
czas = (ts2.tv_nsec - ts1.tv_nsec)/1000000;
if(czas<=0) czas=czas+999;
/* Prethodni red koriguje povremenu gresku pri merenju
kada se dobija rezultat koji je manji za 999ms u odnosu
na stvarni */
printf("\tTrajanje merenja: %ld ms.", czas);
zapis(temperatura()); //upis u datoteku
}
return 0;
}