82 lines
3.5 KiB
C++
82 lines
3.5 KiB
C++
/*
|
|
This file contains the various crank and cam wheel decoder functions.
|
|
|
|
Each decoder must have the following 4 functions (Where xxxx is the decoder name):
|
|
|
|
* triggerPri_xxxx - Called each time the primary (No. 1) crank/cam signal is triggered (Called as an interrupt, so variables must be declared volatile)
|
|
* triggerSec_xxxx - Called each time the secondary (No. 2) crank/cam signal is triggered (Called as an interrupt, so variables must be declared volatile)
|
|
* getRPM_xxxx - Returns the current RPM, as calculated by the decoder
|
|
* getCrankAngle_xxxx - Returns the current crank angle, as calculated b the decoder
|
|
|
|
And each decoder must utlise at least the following variables:
|
|
toothLastToothTime - The time (In uS) that the last primary tooth was 'seen'
|
|
*
|
|
|
|
*/
|
|
|
|
/*
|
|
Name: Missing tooth wheel
|
|
Desc: A multi-tooth wheel with one of more 'missing' teeth. The first tooth after the missing one is considered number 1 and isthe basis for the trigger angle
|
|
Note: This does not currently support dual wheel (ie missing tooth + single tooth on cam)
|
|
*/
|
|
void triggerPri_missingTooth()
|
|
{
|
|
// http://www.msextra.com/forums/viewtopic.php?f=94&t=22976
|
|
// http://www.megamanual.com/ms2/wheel.htm
|
|
noInterrupts(); //Turn off interrupts whilst in this routine
|
|
|
|
curTime = micros();
|
|
curGap = curTime - toothLastToothTime;
|
|
if ( curGap < triggerFilterTime ) { interrupts(); return; } //Debounce check. Pulses should never be less than triggerFilterTime, so if they are it means a false trigger. (A 36-1 wheel at 8000pm will have triggers approx. every 200uS)
|
|
toothCurrentCount++; //Increment the tooth counter
|
|
|
|
//High speed tooth logging history
|
|
toothHistory[toothHistoryIndex] = curGap;
|
|
if(toothHistoryIndex == 511)
|
|
{ toothHistoryIndex = 0; }
|
|
else
|
|
{ toothHistoryIndex++; }
|
|
|
|
//Begin the missing tooth detection
|
|
//If the time between the current tooth and the last is greater than 1.5x the time between the last tooth and the tooth before that, we make the assertion that we must be at the first tooth after the gap
|
|
//if ( (curTime - toothLastToothTime) > (1.5 * (toothLastToothTime - toothLastMinusOneToothTime))) { toothCurrentCount = 1; }
|
|
if(configPage2.triggerMissingTeeth == 1) { targetGap = (3 * (toothLastToothTime - toothLastMinusOneToothTime)) >> 1; } //Multiply by 1.5 (Checks for a gap 1.5x greater than the last one) (Uses bitshift to multiply by 3 then divide by 2. Much faster than multiplying by 1.5)
|
|
//else { targetGap = (10 * (toothLastToothTime - toothLastMinusOneToothTime)) >> 2; } //Multiply by 2.5 (Checks for a gap 2.5x greater than the last one)
|
|
else { targetGap = ((toothLastToothTime - toothLastMinusOneToothTime)) * 2; } //Multiply by 2 (Checks for a gap 2x greater than the last one)
|
|
if ( curGap > targetGap )
|
|
{
|
|
toothCurrentCount = 1;
|
|
toothOneMinusOneTime = toothOneTime;
|
|
toothOneTime = curTime;
|
|
currentStatus.hasSync = true;
|
|
startRevolutions++; //Counter
|
|
}
|
|
|
|
toothLastMinusOneToothTime = toothLastToothTime;
|
|
toothLastToothTime = curTime;
|
|
|
|
interrupts(); //Turn interrupts back on
|
|
}
|
|
|
|
void triggerSec_missingTooth(){ return; } //This function currently is not used
|
|
|
|
int getRPM_missingTooth()
|
|
{
|
|
|
|
}
|
|
|
|
int getCrankAngle_missingTooth()
|
|
{
|
|
|
|
}
|
|
|
|
/*
|
|
Name: Missing tooth wheel
|
|
Desc: A multi-tooth wheel with one of more 'missing' teeth. The first tooth after the missing one is considered number 1 and isthe basis for the trigger angle
|
|
Note: This does not currently support dual wheel (ie missing tooth + single tooth on cam)
|
|
*/
|
|
void triggerPri_DualWheel()
|
|
{
|
|
return;
|
|
}
|