fome-fw/firmware/controllers/trigger/decoders/trigger_toyota.cpp

115 lines
3.2 KiB
C++
Raw Normal View History

2015-12-14 10:01:18 -08:00
/*
* @file trigger_toyota.cpp
*
* https://thedeltaecho.wordpress.com/2010/03/14/2jz-ge-cam-crank-signals/
*
* @date Dec 14, 2015
2018-01-20 17:55:31 -08:00
* @author Andrey Belomutskiy, (c) 2012-2018
2015-12-14 10:01:18 -08:00
*/
#include "trigger_toyota.h"
2018-12-25 17:09:35 -08:00
void initialize2jzGE1_12(TriggerShape *s) {
2016-06-13 13:03:13 -07:00
s->initialize(FOUR_STROKE_CAM_SENSOR, true);
float crankD = 360 / 12 / 2; // 15
float crankAngle = 10;
2018-12-25 16:18:37 -08:00
s->addEvent3(crankAngle, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-06-13 13:03:13 -07:00
for (int i = 0; i < 2; i++) {
2018-12-25 16:18:37 -08:00
s->addEvent3(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721);
2016-06-13 13:03:13 -07:00
crankAngle += crankD;
2018-12-25 16:18:37 -08:00
s->addEvent3(crankAngle + crankD, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-06-13 13:03:13 -07:00
crankAngle += crankD;
2016-06-13 17:01:47 -07:00
}
2016-06-13 13:03:13 -07:00
2018-12-25 16:18:37 -08:00
s->addEvent3(75, T_PRIMARY, TV_FALL, -1, 721);
2016-06-13 13:03:13 -07:00
2016-06-13 17:01:47 -07:00
for (int i = 0; i < 21; i++) {
2018-12-25 16:18:37 -08:00
s->addEvent3(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721);
2016-06-13 17:01:47 -07:00
crankAngle += crankD;
2018-12-25 16:18:37 -08:00
s->addEvent3(crankAngle + crankD, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-06-13 17:01:47 -07:00
crankAngle += crankD;
}
2018-12-25 16:18:37 -08:00
s->addEvent3(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721);
2016-06-13 17:01:47 -07:00
crankAngle += crankD;
2016-06-13 13:03:13 -07:00
2018-12-25 16:18:37 -08:00
s->addEvent3(720, T_PRIMARY, TV_RISE, -1, 721);
2016-06-13 13:03:13 -07:00
s->isSynchronizationNeeded = false;
}
2018-12-25 17:09:35 -08:00
void initialize2jzGE3_34(TriggerShape *s) {
setToothedWheelConfiguration(s, 36, 2, FOUR_STROKE_CRANK_SENSOR);
2016-07-14 20:02:55 -07:00
// s->initialize(FOUR_STROKE_CAM_SENSOR, true);
//
// float camD = 720 / 6; // 120
//
// float crankAngle = 20; // skipping two teeth
//
// for (int i = 0; i < 10; i++) {
2016-10-31 19:02:12 -07:00
// s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721);
// s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-07-14 20:02:55 -07:00
// crankAngle += 10;
// } // 2 + 10
//
// float camAngle = 0;
// camAngle += camD;
2016-10-31 19:02:12 -07:00
// s->addEvent2(camAngle, T_PRIMARY, TV_RISE, -1, 721); // 120
2016-07-14 20:02:55 -07:00
//
// for (int i = 0; i < 12; i++) {
2016-10-31 19:02:12 -07:00
// s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721);
// s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-07-14 20:02:55 -07:00
// crankAngle += 10;
// } // 2 + 22
//
//
// camAngle += camD;
2016-10-31 19:02:12 -07:00
// s->addEvent2(camAngle, T_PRIMARY, TV_FALL, -1, 721); // 240
2016-07-14 20:02:55 -07:00
//
// for (int i = 0; i < 12; i++) {
2016-10-31 19:02:12 -07:00
// s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721);
// s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-07-14 20:02:55 -07:00
// crankAngle += 10;
// } // 2 + 34
//
// camAngle += camD;
2016-10-31 19:02:12 -07:00
// s->addEvent2(camAngle, T_PRIMARY, TV_RISE, -1, 721); // 360
2016-07-14 20:02:55 -07:00
//
// crankAngle += 20; // skipping two teeth one more time
// for (int i = 0; i < 10; i++) {
2016-10-31 19:02:12 -07:00
// s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721);
// s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-07-14 20:02:55 -07:00
// crankAngle += 10;
// } // 2 + 10
//
// camAngle += camD;
2016-10-31 19:02:12 -07:00
// s->addEvent2(camAngle, T_PRIMARY, TV_FALL, -1, 721); // 480
2016-07-14 20:02:55 -07:00
//
// for (int i = 0; i < 12; i++) {
2016-10-31 19:02:12 -07:00
// s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721);
// s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-07-14 20:02:55 -07:00
// crankAngle += 10;
// } // 2 + 22
//
// camAngle += camD;
2016-10-31 19:02:12 -07:00
// s->addEvent2(camAngle, T_PRIMARY, TV_RISE, -1, 721); // 600
2016-07-14 20:02:55 -07:00
//
//
// for (int i = 0; i < 12; i++) {
2016-10-31 19:02:12 -07:00
// s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721);
// s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120
2016-07-14 20:02:55 -07:00
// crankAngle += 10;
// } // 2 + 32
// camAngle += camD;
2016-10-31 19:02:12 -07:00
// s->addEvent2(camAngle, T_PRIMARY, TV_FALL, -1, 721); // 720
2016-07-14 20:02:55 -07:00
//
// s->isSynchronizationNeeded = false;
2015-12-14 18:01:30 -08:00
}