speeduino-personal/reference/stim/stim.ino

150 lines
3.0 KiB
Arduino
Raw Normal View History

2013-08-25 21:12:14 -07:00
/* FORD 1996 CKP crank signal simulator 36-1
by Ichabod mudd
*/
#include "Arduino.h"
#define PULSE_PIN 0
2013-08-25 21:12:14 -07:00
#define CAM_PIN 8
#define MPH_PIN 12
#define POT_PIN A0
2013-08-25 21:12:14 -07:00
2014-09-20 03:19:30 -07:00
#define teeth 60
#define missingTeeth 2
#define PULSE_DURATION 50
2013-08-25 21:12:14 -07:00
unsigned int MAX_DELAY;
unsigned int MIN_DELAY;
byte actualTeeth;
2013-08-25 21:12:14 -07:00
int mph_toggle = 1 ;
int val;
unsigned int pulse_gap;
int RPMdirection = 0;
2013-08-25 21:12:14 -07:00
// the setup routine runs once when you press reset:
void setup()
{
pinMode(PULSE_PIN, OUTPUT);
pinMode(CAM_PIN, OUTPUT);
pinMode(MPH_PIN, OUTPUT);
actualTeeth = teeth - missingTeeth;
2014-09-20 03:19:30 -07:00
if(actualTeeth == 58)
{
MAX_DELAY = 3500;
MIN_DELAY = 130;
}
else if(actualTeeth == 35)
{
MAX_DELAY = 4000;
MIN_DELAY = 29;
}
else if(actualTeeth == 11)
{
MAX_DELAY = 20000;
MIN_DELAY = 833;
}
Serial.begin(9600);
pulse_gap = MIN_DELAY;
2013-08-25 21:12:14 -07:00
}
//reluctor wheel
// subroutines first
//function to first go HiGH
void triggerHigh(int duration, int count)
{
switch (count)
{
case 1: // cam CMP pin 8
digitalWrite(CAM_PIN, HIGH);
break;
case 2:
digitalWrite(CAM_PIN, LOW);
digitalWrite(MPH_PIN, LOW); //VSS
break;
case 12:
digitalWrite(CAM_PIN, HIGH);
break;
case 13:
digitalWrite(CAM_PIN, LOW);
break;
case 24:
digitalWrite(CAM_PIN, HIGH);
break;
case 25:
digitalWrite(CAM_PIN, LOW);
break;
} // end cases
//hold CKP PIN high for this delay.
digitalWrite(PULSE_PIN, HIGH);
delayMicroseconds(PULSE_DURATION);
// now CKP go low
digitalWrite(PULSE_PIN, LOW);
// end function
}
//Simulates a 36 tooth reluctor wheel
//with a 1 tooth reference
// begin main loop program section
void loop()
{
// read potentiometer wiper pin 0?
// analog A/D channel 0
val = analogRead(POT_PIN);
pulse_gap = map(val, 0, 1023, MIN_DELAY, MAX_DELAY);
Serial.println(pulse_gap);
/*
if (RPMdirection == 0)
{
if (pulse_gap < MAX_DELAY) { pulse_gap++; }
else
{
RPMdirection = 1;
}
}
else
{
if (pulse_gap > MIN_DELAY) { pulse_gap--; }
else
{
RPMdirection = 0;
}
}
*/
2013-08-25 21:12:14 -07:00
// for loop 36 counts , 150 uS to 1000 uS or 5000 to 800 rpm
for (int i = 0; i < actualTeeth; i++)
2013-08-25 21:12:14 -07:00
{
// go high then low , in Symmetry
digitalWrite(PULSE_PIN, HIGH);
delayMicroseconds(PULSE_DURATION);
digitalWrite(PULSE_PIN, LOW);
if (pulse_gap < 15000) //delayMicroseconds() only works with values up to 16383. Switch to delay() at 15000 to be safe
{
delayMicroseconds( (pulse_gap - PULSE_DURATION) );
}
else
{
delay ( (pulse_gap - PULSE_DURATION) / 1000 );
}
2013-08-25 21:12:14 -07:00
}
// simulate the missing tooth next
2014-09-20 03:19:30 -07:00
delayMicroseconds( (pulse_gap * missingTeeth) );
2013-08-25 21:12:14 -07:00
}
// end main loop version 7 , now perfect 800 rpm to 5000
// added cam pulse 7/4/2013
// using Delay calls, suck but , this is easy.
// the switch case trick, gets the cam sensor working.
// the engine fires every 120 degr. on crank, 12 teeth, and 10 degr per tooth=120
// added MPH pin, for VSS signals to ECU