-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathtelemetry.cpp
executable file
·91 lines (74 loc) · 1.98 KB
/
telemetry.cpp
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/*
* telemetry.cpp
* FOXSI_GSE
*
* Created by Steven Christe on 10/7/11.
* Copyright 2011 NASA GSFC. All rights reserved.
*
*/
#include "telemetry.h"
#include "math.h"
float temperature_convert_ref(unsigned short int value)
{
return value*0.30517 - 255;
}
float voltage_convert_5v(unsigned short int value)
{
return 8.75 * ( value /4095.);
}
float voltage_convert_m5v(unsigned short int value)
{
return 2.5 - 15.0 * ( value / 4095.);
}
float voltage_convert_33v(unsigned short int value)
{
return 5. * ( value / 4095.);
}
float voltage_convert_15v(unsigned short int value)
{
return 2.5 * ( value / 4095.);
}
float temperature_convert_ysi44031(unsigned short int value)
{
// Take the reading of A/D Voltage from the YSI 44031 temperature
// sensor and convert to a temperature (in Celsius).
// Test input 1
// int value = 0x0FF4;
// answer should be -80.0
// Test input 2
// int value = 0x070D;
// answer should be 31.0
/* double resistance;
double temperature;
double frac;
double voltage;
const float c1 = 0.00099542549430017;
const float c2 = 0.000234788987236607;
const float c3 = 1.13519068800246E-07;
frac = value/4095.0;
voltage = 2.5*frac;
resistance = 10000.0 * frac/ ( 1.0 - frac );
//printf("%f\n",resistance);
temperature = 1 / (c1 + c2 * log(resistance) + c3 * (pow(log(resistance),3))) - 273.15 - 9.73;
//printf("%f\n", temperature);
*/
float th,temperature;
th = value;
th = 10000./((4095./th) -1.);
temperature = -273. + 1./(0.00102522746225986 + 0.000239789531411299*log(th) + 1.53998393755544E-07*pow(log(th),3));
return temperature;
}
float telemetry_hvvalue_convert_voltage(int value)
{
// Take the reading of the HV value and convert it to an actual voltage
// 256 is 31 V
// 1000 hv_value is 125 volts
// 2000 is 250 volts
return (float) value/8.0;
}
int telemetry_voltage_convert_hvvalue(float value)
{
// Take an actual voltage value and convert it to an HV value to send
// as a command
return (int) value*8;
}