forked from AngeloCasi/FUGU-ARDUINO-MPPT-FIRMWARE
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path2_Read_Sensors.ino
89 lines (80 loc) · 4.38 KB
/
2_Read_Sensors.ino
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
void ADC_SetGain(){
if(ADS1015_Mode==true){ //FOR ADS1015 12-BIT ADC MODEL
if(ADC_GainSelect==0){ads.setGain(GAIN_TWOTHIRDS);ADC_BitReso=3.0000;} // Gain: 2/3x Range: +/- 6.144V
else if(ADC_GainSelect==1){ads.setGain(GAIN_ONE);ADC_BitReso=2.0000;} // Gain: 1x Range: +/- 4.096V
else if(ADC_GainSelect==2){ads.setGain(GAIN_TWO);ADC_BitReso=1.0000;} // Gain: 2x Range: +/- 2.048V
}
else{ //FOR ADS1115 16-BIT ADC MODEL
if(ADC_GainSelect==0){ads.setGain(GAIN_TWOTHIRDS);ADC_BitReso= 0.1875;} // Gain: 2/3x Range: +/- 6.144V
else if(ADC_GainSelect==1){ads.setGain(GAIN_ONE);ADC_BitReso= 0.125;} // Gain: 1x Range: +/- 4.096V
else if(ADC_GainSelect==2){ads.setGain(GAIN_TWO);ADC_BitReso= 0.0625;} // Gain: 2x Range: +/- 2.048V
}
}
void resetVariables(){
secondsElapsed = 0;
energySavings = 0;
daysRunning = 0;
timeOn = 0;
}
void Read_Sensors(){
/////////// TEMPERATURE SENSOR /////////////
if(sampleStoreTS<=avgCountTS){ //TEMPERATURE SENSOR - Lite Averaging
TS = TS + analogRead(TempSensor);
sampleStoreTS++;
}
else{
TS = TS/sampleStoreTS;
TSlog = log(ntcResistance*(4095.00/TS-1.00));
temperature = (1.0/(1.009249522e-03+2.378405444e-04*TSlog+2.019202697e-07*TSlog*TSlog*TSlog))-273.15;
sampleStoreTS = 0;
TS = 0;
}
/////////// VOLTAGE & CURRENT SENSORS /////////////
VSI = 0.0000; //Clear Previous Input Voltage
VSO = 0.0000; //Clear Previous Output Voltage
CSI = 0.0000; //Clear Previous Current
//VOLTAGE SENSOR - Instantenous Averaging
for(int i = 0; i<avgCountVS; i++){
VSI = VSI + ads.computeVolts(ads.readADC_SingleEnded(3));
VSO = VSO + ads.computeVolts(ads.readADC_SingleEnded(1));
}
voltageInput = (VSI/avgCountVS)*inVoltageDivRatio;
voltageOutput = (VSO/avgCountVS)*outVoltageDivRatio;
//CURRENT SENSOR - Instantenous Averaging
for(int i = 0; i<avgCountCS; i++){
CSI = CSI + ads.computeVolts(ads.readADC_SingleEnded(2));
}
CSI_converted = (CSI/avgCountCS)*1.3300;
currentInput = ((CSI_converted-currentMidPoint)*-1)/currentSensV;
if(currentInput<0){currentInput=0.0000;}
if(voltageOutput<=0){currentOutput = 0.0000;}
else{currentOutput = (voltageInput*currentInput)/voltageOutput;}
//POWER SOURCE DETECTION
if(voltageInput<=3 && voltageOutput<=3){inputSource=0;} //System is only powered by USB port
else if(voltageInput>voltageOutput) {inputSource=1;} //System is running on solar as power source
else if(voltageInput<voltageOutput) {inputSource=2;} //System is running on batteries as power source
//////// AUTOMATIC CURRENT SENSOR CALIBRATION ////////
if(buckEnable==0 && FLV==0 && OOV == 0){
currentMidPoint = ((CSI/avgCountCS)*1.3300)-0.003;
}
//POWER COMPUTATION - Through computation
powerInput = voltageInput*currentInput;
powerOutput = voltageInput*currentInput*efficiencyRate;
outputDeviation = (voltageOutput/voltageBatteryMax)*100.000;
//STATE OF CHARGE - Battery Percentage
batteryPercent = ((voltageOutput-voltageBatteryMin)/(voltageBatteryMax-voltageBatteryMin))*101;
batteryPercent = constrain(batteryPercent,0,100);
//TIME DEPENDENT SENSOR DATA COMPUTATION
currentRoutineMillis = millis();
if(currentRoutineMillis-prevRoutineMillis>=millisRoutineInterval){ //Run routine every millisRoutineInterval (ms)
prevRoutineMillis = currentRoutineMillis; //Store previous time
Wh = Wh+(powerInput/(3600.000*(1000.000/millisRoutineInterval))); //Accumulate and compute energy harvested (3600s*(1000/interval))
kWh = Wh/1000.000;
MWh = Wh/1000000.000;
daysRunning = timeOn/(86400.000*(1000.000/millisRoutineInterval)); //Compute for days running (86400s*(1000/interval))
timeOn++; //Increment time counter
}
//OTHER DATA
secondsElapsed = millis()/1000; //Gets the time in seconds since the was turned on and active
energySavings = electricalPrice*(Wh/1000.0000); //Computes the solar energy saving in terms of money (electricity flag rate)
}