Even with the update VT help, I did not fully understand the difference between the IAC Integral Deadband and IAC Integral Minmap.
I am even more confused because I had to put non zero value to control the IAC idle since, on another hand, I always used deadband on target to filter high frequency noise (w/r to the actuator band), that is never on integral action which is low pass.
Philippe
dead band. If rpm error is less than value, intergral value is frozen.
if map is less than int minmap, integral value is 0.
What is the integral value?
Is it IAC_int the integral action which is added (or substracted) to IAC_ref ?
or
__int the time integral of the rpm error to the idle (moving) target?
That is, such as we get IAC_int = I*__int
where I is the chosen parameter of the PID.
Indeed one can frozen IAC_int or set it to zero, while the time integral __int is still integrating.
Do you know what's going on in our case?
intergral value is intergral error. So sum of errors multy with PID int constant.
So this is IAC_int, and the question is
Is the sum (or the integral) of the error frozen (or set to zero) or not?
In another way, what is the value of IAC_int or of the sum when one gets out of the deadband in the 2 cases.
error=target rpm- current rpm
IAC_int= sum of few error in the past*PID_int constant
if error< int deadband then IAC_int frozen(doesn't change)
if engine MAP < Integral Minmap then IAC_int=0
Thanks for your explanations.
I do understand now the use of the Integral Minmap parameter.
As for the Integral Deadband, alright this is the sum which is frozen inside the deadband and by the way the IAC_int value.
However looking at the log file kindly given by DamiMuha (I have not found back his post)
http://www.vems.hu/files/DamirMuha/1.2.20/v3.7_n008036-2014.01.20-16.10.19.vemslog
One sees that for in integral deadband = 30, IAC_int is frozen @ -16 when entering the deadband, time 0:22:03 and is still frozen at this value when leaving the deadband by low values, time 0:22:55.
On the same hand, it shows that this integral deadband leads to an undershoot with an IAC=29%
The steady idle at the begining of the log being given by IAC = 47%.
That is my log :). That car has DBW. On DBW it's much harder to set good idle. On normal 2wire idle motor that is a joke.
So, when map is less thena 20kPa, iac int is 0.
Then idle is to high, so int is lowered until rpm are in range 870 and 930. In that range is frozen to value -16.
I see it frozen when rpm = 867 and idle target rpm = 920, time 0:22:55
Quote from: fphil on February 13, 2014, 11:20:02 PM
I see it frozen when rpm = 867 and idle target rpm = 920, time 0:22:55
Yes, i bit strange.
Hi Phil / MWfire,
All the IAC pid parameters can be logged and their net effect on the IAC output dutycycle/position, when using recent firmwares (>1.2.15) and recent VemsTune. Check the channels in: Change gauge data -> IAC -> IAC Calc XX (Refpos, PE, IE, DE).
I hope these provide the desired insight in their effect on output.
Best regards, Dave
VemsTune help has been updated to cover all IAC menu settings, run manual ini_update to fetch the latest files. Also available on: http://vems.hu/vt/help/v3/v3_idle_control_menu.html
Best regards, Dave
Quote from: VEMS on February 14, 2014, 03:48:03 PM
run manual ini_update to fetch the latest files.
I did Preferences/update files manually. I was asked to download 69 files so I replied NO.
I went to http://vems.hu/download/v3gui/ where I am used to find the latest VT update, no ini file there.
Where can one manually download the latest ini files?
In your opinion, what will go wrong if you reply YES ?
I have never downloaded any ini files manually, why would I when it can be done automatically in the software?
Quote from: mattias on February 16, 2014, 12:45:20 PM
In your opinion, what will go wrong if you reply YES ?
Because I do not know and because I do not need 69 files I said no ;)
QuoteI have never downloaded any ini files manually, why would I when it can be done automatically in the software?
Neither did I, I use to get it automatically as well (see Dave's message)
Meanwhile I have opened the Dave's link for the updated help. OK for the minmap parameter. One more question.
It is said concerning "Integral Increase Limit" (decrease) :
"High limit for the IAC Integral, any desired value higherr than this is railed to High Limit"
Is it a saturation of the IAC integral value which is used by the PID while the errors keep summing up?
or is that sum freezed, the errors not being summed up anymore
Hello FPhil,
To the question of updating 69 files, the answer should of course be YES. Updating files manually or automatic invokes the same procedure, therefore has the same net effect (if answering YES).
VemsTune program changes (as available on: http://vems.hu/download/v3gui/) are only made when there are changes to the program itself (executable or underlying database structure), rest of the updates are available through update server (ini_update) this also counts for the latests dialogs and menu help files.
The integral increase/decrease limits are limits of the integral itself (the sum) to use your analogy, the errors are not being summed anymore when reaching either of these limits.
Secondly there are also absolute limits on the total output (Reference + PID) which are in "Idle PWM/Stepper Hardware settings", "Max/Min PWM/Steps Allowed" again using your analogy this is a limit on max output value, errors might still be summing up if integral limit is not yet reached.
If there is anything still unclear, please let me know so i can elaborate further in help to make it more clear for everyone.
Best regards,
Dave
Quote from: VEMS on February 16, 2014, 04:49:41 PMQuote
To the question of updating 69 files, the answer should of course be YES. Updating files manually or automatic invokes the same procedure, therefore has the same net effect (if answering YES).
but why 69 files? ok I shall give it a try
Quote
VemsTune program changes (as available on: http://vems.hu/download/v3gui/) are only made when there are changes to the program itself (executable or underlying database structure), rest of the updates are available through update server (ini_update) this also counts for the latests dialogs and menu help files.
I was not aware of that, thanks to quote
Quote
If there is anything still unclear, please let me know so i can elaborate further in help to make it more clear for everyone.
ok. Concerning
"Threshold for Activating IAC
Activate IAC when this number of degrees have been exceeded to adjust idle RPM.. "
Would you confirm that when "this number of degrees have been exceeded " one gets PID IAC control AND ign. advance control.
btw, I shall put a proposal for fw update. I think there is a need for a deadband on the PID command as a last block before the command to be sent to the actuator.
(In that case the integral is kept summing up, which is unarmful in the neighborhood of the target)
Indeed for a noisy rpm and high P, the command is unnecessary noisy about the target and could even lead to instability due to phase lag.
Best regards,
Philippe
Hi FPhil
Why 69 files ? Good question (keep in mind that most files are sub 10kb). 69 files because i added help for certain dialogs to previous firmware version profiles also (back-ported), that way even users of older firmware versions get help additions even when they were not available at the time the firmware was released.
Threshold for Activating IAC (the question was hiding a bit in the quote almost missed it :) ): This is the way it was intended a long time ago (it seems i forgot to remove that variable from dialog), it is no longer used. When in idle mode, both IAC and advanced based idle are active always (when enabled).
We welcome any proposal for firmware enhancements, i will review and implement (if feasible). Thanks for your feedback!
Best regard, Dave