/* * @file trigger_toyota.cpp * * https://thedeltaecho.wordpress.com/2010/03/14/2jz-ge-cam-crank-signals/ * * @date Dec 14, 2015 * @author Andrey Belomutskiy, (c) 2012-2020 */ #include "trigger_toyota.h" /** * TT_2JZ_1_12 * One cam + 12 crank * http://rusefi.com/images/triggers/trigger_29.png */ void initialize2jzGE1_12(TriggerWaveform *s) { s->initialize(FOUR_STROKE_CAM_SENSOR); float crankD = 360 / 12 / 2; // 15 float crankAngle = 10; s->addEventClamped(crankAngle, T_SECONDARY, TV_FALL, -1, 721); // 120 for (int i = 0; i < 2; i++) { s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721); crankAngle += crankD; s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_FALL, -1, 721); // 120 crankAngle += crankD; } s->addEventClamped(75, T_PRIMARY, TV_FALL, -1, 721); for (int i = 0; i < 21; i++) { s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721); crankAngle += crankD; s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_FALL, -1, 721); // 120 crankAngle += crankD; } s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721); crankAngle += crankD; s->addEventClamped(720, T_PRIMARY, TV_RISE, -1, 721); s->isSynchronizationNeeded = false; } /** * https://rusefi.com/forum/viewtopic.php?f=5&t=1720 */ void initialize2jzGE3_34(TriggerWaveform *s) { setToothedWheelConfiguration(s, 36, 2, FOUR_STROKE_CRANK_SENSOR); // s->initialize(FOUR_STROKE_CAM_SENSOR); // // float camD = 720 / 6; // 120 // // float crankAngle = 20; // skipping two teeth // // for (int i = 0; i < 10; i++) { // s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721); // s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120 // crankAngle += 10; // } // 2 + 10 // // float camAngle = 0; // camAngle += camD; // s->addEvent2(camAngle, T_PRIMARY, TV_RISE, -1, 721); // 120 // // for (int i = 0; i < 12; i++) { // s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721); // s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120 // crankAngle += 10; // } // 2 + 22 // // // camAngle += camD; // s->addEvent2(camAngle, T_PRIMARY, TV_FALL, -1, 721); // 240 // // for (int i = 0; i < 12; i++) { // s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721); // s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120 // crankAngle += 10; // } // 2 + 34 // // camAngle += camD; // s->addEvent2(camAngle, T_PRIMARY, TV_RISE, -1, 721); // 360 // // crankAngle += 20; // skipping two teeth one more time // for (int i = 0; i < 10; i++) { // s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721); // s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120 // crankAngle += 10; // } // 2 + 10 // // camAngle += camD; // s->addEvent2(camAngle, T_PRIMARY, TV_FALL, -1, 721); // 480 // // for (int i = 0; i < 12; i++) { // s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721); // s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120 // crankAngle += 10; // } // 2 + 22 // // camAngle += camD; // s->addEvent2(camAngle, T_PRIMARY, TV_RISE, -1, 721); // 600 // // // for (int i = 0; i < 12; i++) { // s->addEvent2(crankAngle + 5, T_SECONDARY, TV_RISE, -1, 721); // s->addEvent2(crankAngle + 9.9, T_SECONDARY, TV_FALL, -1, 721); // 120 // crankAngle += 10; // } // 2 + 32 // camAngle += camD; // s->addEvent2(camAngle, T_PRIMARY, TV_FALL, -1, 721); // 720 // // s->isSynchronizationNeeded = false; }