MembersPage/DavidBlades/IdleControl (2016-09-29 18:07:19)

Idle Air Control

September 2016

I have been looking at the IAC functions on my VEMS over the last couple of days and have found a potential problem with some types of stepper.

During the power-up cycle, the stepper is driven hard against the "IAC closed" end stops to reference it, and then moved to the required position for starting. This is fine when my Lucas stepper motor is sat on the bench with a G clamp acting as an end stop, but the process doesn't work well when the stepper is in the car because the stepper pin is driven hard into a tapered port and then it sometimes sticks here instead of moving to the correct starting position. (In this case, the car won't start without a lot of throttle applied) This then causes the stepper to be completely out of sync with where the ECU thinks it should be, meaning the car is difficult to do anything with because it isn't consistent from run to run.

A solution to this could be to reference the stepper by driving against the "IAC fully open" end stop - this is a much better defined position for the Lucas stepper - and it seems like it will make the main problem go away.

In order to test my theory, I reversed the step sequence, ensured all forms of IAC PID controllers were still disabled and changed the stepper reference position table to work in reverse. It confirmed my theory that the Lucas stepper can't accurately be referenced from the closed position, but it can be referenced properly from the fully open position.

Is there a way of implementing this in VEMS properly without me having to tell lies to it? I would like to get the PID controller to operate again, and right now it will be very confused.

I would prefer an option in the configuration to allow me to specify which end stop should be used to reference the stepper.

Modify message

---

Historic Stepper Information

The idle stepped does something, but I'm not confinced it's right. I connected the 4 wires from the stepper to the A,B,C & D channels (on the EC18 connector) going clockwise round the motor looking at it from the connector end. My stepper is an "anti-stepper" like Marcell's... It was operating the wrong way round at first.

Idle controls

Idle afterstart RPM (added value?) - Value to add to base idle speed when the car is first started.

Idle afterstart duration (s) - the duration to do the above for.

IAC afterstart (steps per 160 rpm) 0 is OK (this was a hint to the ECM, dropped from firmware recently)

Max steps to extend - total number of steps the motor can do. I managed to shoot the pin out of the end of mine. Don't do this as they get stuck in awkward places...

IAC step sequence - Lots of things, depending on how you wire up your motor. Mine was 201. ie drive C, then B, then D, then A.

stepper speed (ms) - Speed motor moves at. ie time between steps. 0 ms is fast and can shoot the pin a long way (see earlier). 3..7 msec is common. Surprising that your stepper works so fast.

iac_conf RAW - bitflags, see global.h . The values you copied from Marcell should be fine (precise idle=on; stepper=on; asymetric PID=whatever you like)

See the IAC section of: MembersPage/MarcellGal/EngineSwap/AirFeed for more info. on config

Hints for Tuning Idle

Update

A couple of problems were found.

Moral: Check carefully for mechanical problems 1st!

Current Idle Config

Note that this is not correctly set up yet since various engine changes have happened.\n

iac_step_seq=C9
iac_conf=4C
iac_max_steps=B0
iac_tps_thres=05
iac_cold_idle_temp=BF
iac_warm_idle_temp=CF
iac_cold_rpm=5A
iac_warm_rpm=50
iac_cold_start_pos=64
iac_warm_start_pos=B4
iac_afterstart_rpm=0A
iac_afterstart_duration=28
iac_afterstart_steps=00
iac_kp=14
iac_ki=01
iac_kd=01
iac_integral_speed=0A
iac_integral_limit_dec=06
iac_integral_limit_inc=19
iac_integral_deadband=0F
iac_deadband=0A
iac_pid_conf=00
iac_overclose_interval=0A
iac_ref_pos[0]=B0
iac_ref_pos[1]=B0
iac_ref_pos[2]=B0
iac_ref_pos[3]=B0
iac_ref_pos[4]=B0
iac_ref_pos[5]=B0
iac_ref_pos[6]=B0
iac_ref_pos[7]=B0
iac_ref_pos[8]=B0
iac_ref_pos[9]=B0
iac_sol_channel=FF
iac_ign_advance_change=50
iac_ign_retard_change=50
iac_ign_advance_limit=00
iac_ign_retard_limit=00
iac_ign_threshold=08

Questions:

Q Does the direction the stepper moves to close the valve matter?

A Yes, it matter which direction the stepper moves, 0% should be closed and 100% far open, otherwise pid controller wont work properly. Be sure to start with proper reference postions in your iac reference table (disable pid controller at first Kp, Ki, Kd = 0) thatway the iac runs on reference table only without pid interfering.

Q: New issue today: With PID idle control turned OFF, (so a fixed stepper position) I now find that the engine speed oscillates with amplitude of 250RPM (500 RPM peak to peak, average speed is 750 RPM) and a period of 2.5 seconds. What could cause oscillations in the idling???

Too slow to be a problem with a single cylinder weak spark. (The engine runs fine at high speed.)

Not had chance to do much diagnosis yet. I have not changed the config (other than what Auto VE learn has done) since last week. It worked then!!

Could it be one of these?

A: Autolearn had got carried away at one point, and had not changed some others. So there was some discontinuities in the VE map and hence oscillations. Once cleared up, it all worked fine.

  • VE autolearn is ment as a tuning aid in the early stage of tuning, not to be saved (with mvs) every time before shutdown. Do you maybe have a backup of the VE map with discontinuities ? (and the good map to compare side by side).
  • Yes. That's exactly how I found the problem - by doing mvs and looking for the changes... (I have backups of the config since I started) VE learn is now set to only work on the bits of map I've not got optimised yet. Mainly high(ish) load and high(ish) RPM. Most of the time I plod the car to work at 60 kph. Not had too many opportunities for tuning runs lately :(

Back to MembersPage/DavidBlades