2016-03-08 21:40:11 -08:00
/*
Speeduino - Simple engine management for the Arduino Mega 2560 platform
Copyright ( C ) Josh Stewart
A full copy of the license may be found in the projects root directory
*/
2016-06-10 05:38:05 -07:00
2016-03-08 21:40:11 -08:00
void instanteneousMAPReading ( )
{
//Instantaneous MAP readings
tempReading = analogRead ( pinMAP ) ;
tempReading = analogRead ( pinMAP ) ;
//Error checking
if ( tempReading > = VALID_MAP_MAX | | tempReading < = VALID_MAP_MIN ) { mapErrorCount + = 1 ; }
else { currentStatus . mapADC = tempReading ; mapErrorCount = 0 ; }
2016-10-05 09:53:11 -07:00
currentStatus . MAP = fastMap1023toX ( currentStatus . mapADC , configPage1 . mapMax ) ; //Get the current MAP value
2016-03-08 21:40:11 -08:00
}
void readMAP ( )
{
2016-06-10 05:38:05 -07:00
//MAP Sampling system
switch ( configPage1 . mapSample )
{
case 0 :
//Instantaneous MAP readings
instanteneousMAPReading ( ) ;
break ;
2016-03-08 21:40:11 -08:00
2016-06-10 05:38:05 -07:00
case 1 :
//Average of a cycle
if ( currentStatus . RPM < 1 ) { instanteneousMAPReading ( ) ; return ; } //If the engine isn't running, fall back to instantaneous reads
if ( ( MAPcurRev = = startRevolutions ) | | ( MAPcurRev = = startRevolutions + 1 ) ) //2 revolutions are looked at for 4 stroke. 2 stroke not currently catered for.
{
tempReading = analogRead ( pinMAP ) ;
tempReading = analogRead ( pinMAP ) ;
2016-03-08 21:40:11 -08:00
2016-06-10 05:38:05 -07:00
//Error check
if ( tempReading < VALID_MAP_MAX & & tempReading > VALID_MAP_MIN )
2016-03-08 21:40:11 -08:00
{
2016-06-10 05:38:05 -07:00
MAPrunningValue = MAPrunningValue + tempReading ; //Add the current reading onto the total
MAPcount + + ;
2016-03-08 21:40:11 -08:00
}
2016-06-10 05:38:05 -07:00
else { mapErrorCount + = 1 ; }
}
else
{
//Reaching here means that the last cylce has completed and the MAP value should be calculated
currentStatus . mapADC = ldiv ( MAPrunningValue , MAPcount ) . quot ;
2016-10-05 09:53:11 -07:00
currentStatus . MAP = fastMap1023toX ( currentStatus . mapADC , configPage1 . mapMax ) ; //Get the current MAP value
2016-06-10 05:38:05 -07:00
MAPcurRev = startRevolutions ; //Reset the current rev count
MAPrunningValue = 0 ;
MAPcount = 0 ;
}
break ;
case 2 :
//Minimum reading in a cycle
if ( currentStatus . RPM < 1 ) { instanteneousMAPReading ( ) ; return ; } //If the engine isn't running, fall back to instantaneous reads
if ( ( MAPcurRev = = startRevolutions ) | | ( MAPcurRev = = startRevolutions + 1 ) ) //2 revolutions are looked at for 4 stroke. 2 stroke not currently catered for.
{
tempReading = analogRead ( pinMAP ) ;
tempReading = analogRead ( pinMAP ) ;
//Error check
if ( tempReading < VALID_MAP_MAX & & tempReading > VALID_MAP_MIN )
2016-03-08 21:40:11 -08:00
{
2016-06-10 05:38:05 -07:00
if ( tempReading < MAPrunningValue ) { MAPrunningValue = tempReading ; } //Check whether the current reading is lower than the running minimum
2016-03-08 21:40:11 -08:00
}
2016-06-10 05:38:05 -07:00
else { mapErrorCount + = 1 ; }
}
else
{
//Reaching here means that the last cylce has completed and the MAP value should be calculated
currentStatus . mapADC = MAPrunningValue ;
2016-10-05 09:53:11 -07:00
currentStatus . MAP = fastMap1023toX ( currentStatus . mapADC , configPage1 . mapMax ) ; //Get the current MAP value
2016-06-10 05:38:05 -07:00
MAPcurRev = startRevolutions ; //Reset the current rev count
MAPrunningValue = 1023 ; //Reset the latest value so the next reading will always be lower
}
break ;
}
2016-03-08 21:40:11 -08:00
}
2016-03-23 04:09:04 -07:00
void readTPS ( )
{
2016-06-10 05:38:05 -07:00
currentStatus . TPSlast = currentStatus . TPS ;
currentStatus . TPSlast_time = currentStatus . TPS_time ;
analogRead ( pinTPS ) ;
2016-10-05 09:53:11 -07:00
byte tempTPS = fastMap1023toX ( analogRead ( pinTPS ) , 255 ) ; //Get the current raw TPS ADC value and map it into a byte
2016-06-10 05:38:05 -07:00
currentStatus . tpsADC = ADC_FILTER ( tempTPS , ADCFILTER_TPS , currentStatus . tpsADC ) ;
//Check that the ADC values fall within the min and max ranges (Should always be the case, but noise can cause these to fluctuate outside the defined range).
byte tempADC = currentStatus . tpsADC ; //The tempADC value is used in order to allow TunerStudio to recover and redo the TPS calibration if this somehow gets corrupted
if ( currentStatus . tpsADC < configPage1 . tpsMin ) { tempADC = configPage1 . tpsMin ; }
else if ( currentStatus . tpsADC > configPage1 . tpsMax ) { tempADC = configPage1 . tpsMax ; }
currentStatus . TPS = map ( tempADC , configPage1 . tpsMin , configPage1 . tpsMax , 0 , 100 ) ; //Take the raw TPS ADC value and convert it into a TPS% based on the calibrated values
currentStatus . TPS_time = currentLoopTime ;
2016-03-23 04:09:04 -07:00
}
void readCLT ( )
{
2016-06-10 05:38:05 -07:00
tempReading = analogRead ( pinCLT ) ;
2016-10-05 09:53:11 -07:00
tempReading = fastMap1023toX ( analogRead ( pinCLT ) , 511 ) ; //Get the current raw CLT value
2016-06-10 05:38:05 -07:00
currentStatus . cltADC = ADC_FILTER ( tempReading , ADCFILTER_CLT , currentStatus . cltADC ) ;
currentStatus . coolant = cltCalibrationTable [ currentStatus . cltADC ] - CALIBRATION_TEMPERATURE_OFFSET ; //Temperature calibration values are stored as positive bytes. We subtract 40 from them to allow for negative temperatures
2016-03-23 04:09:04 -07:00
}
void readIAT ( )
{
2016-06-10 05:38:05 -07:00
tempReading = analogRead ( pinIAT ) ;
2016-10-05 09:53:11 -07:00
tempReading = fastMap1023toX ( analogRead ( pinIAT ) , 511 ) ; //Get the current raw IAT value
2016-06-10 05:38:05 -07:00
currentStatus . iatADC = ADC_FILTER ( tempReading , ADCFILTER_IAT , currentStatus . iatADC ) ;
currentStatus . IAT = iatCalibrationTable [ currentStatus . iatADC ] - CALIBRATION_TEMPERATURE_OFFSET ;
2016-03-23 04:09:04 -07:00
}
void readO2 ( )
{
2016-06-10 05:38:05 -07:00
tempReading = analogRead ( pinO2 ) ;
2016-10-05 09:53:11 -07:00
tempReading = fastMap1023toX ( analogRead ( pinO2 ) , 511 ) ; //Get the current O2 value.
2016-06-10 05:38:05 -07:00
currentStatus . O2ADC = ADC_FILTER ( tempReading , ADCFILTER_O2 , currentStatus . O2ADC ) ;
currentStatus . O2 = o2CalibrationTable [ currentStatus . O2ADC ] ;
2016-03-23 04:09:04 -07:00
}
2016-06-10 05:38:05 -07:00
/* Second O2 currently disabled as its not being used
currentStatus . O2_2ADC = map ( analogRead ( pinO2_2 ) , 0 , 1023 , 0 , 511 ) ; //Get the current O2 value.
currentStatus . O2_2ADC = ADC_FILTER ( tempReading , ADCFILTER_O2 , currentStatus . O2_2ADC ) ;
currentStatus . O2_2 = o2CalibrationTable [ currentStatus . O2_2ADC ] ;
*/
2016-03-23 04:09:04 -07:00
void readBat ( )
{
2016-06-10 05:38:05 -07:00
tempReading = analogRead ( pinBat ) ;
2016-10-05 09:53:11 -07:00
tempReading = fastMap1023toX ( analogRead ( pinBat ) , 245 ) ; //Get the current raw Battery value. Permissible values are from 0v to 24.5v (245)
2016-06-10 05:38:05 -07:00
currentStatus . battery10 = ADC_FILTER ( tempReading , ADCFILTER_BAT , currentStatus . battery10 ) ;
2016-03-23 04:09:04 -07:00
}
2016-06-24 01:02:53 -07:00
/*
* The interrupt function for reading the flex sensor frequency
* This value is incremented with every pulse and reset back to 0 once per second
*/
2016-10-25 07:04:37 -07:00
void flexPulse ( )
2016-06-24 01:02:53 -07:00
{
+ + flexCounter ;
}