rusefi_documentation/Fuel-Overview.md

154 lines
9.9 KiB
Markdown
Raw Normal View History

# Fuel control overview
The Air Fuel Ratio (AFR) is controlled by how much fuel is delivered to the cylinder for combustion. There are many factors and many sensors that come into play when trying to determine how much O2 is in the cylinder. rusEFI collects this information and makes a guess about how much O2 is in the cyl, then rusEFI has to determine how much fuel is needed to get the expected AFR and deliver that fuel charge. Below is a graphic that shows some common differences in AFR for a particular Toyota engine. Other engines are similar to this, but may have a different peak power area, or peak efficiency area, etc. To know this information for your particular setup you would need to run it on a Dyno, and determine the exact AFR's.
![Airfuel](Fuel/Fuel_Control/Airfuel.jpg)
D is for Distraction update (#61) * Fix for Home page and future features page added * Update Acceleration_Compensation.md * Update Fuel_Overview.md * More fuel info * More X-tau * Ongoing Tasks list Free for all list for people to update as they change track * Update Ongoing_Tasks * Hidden names on pages and multi-spark page * Update X-tau_Wall_Wetting.md * Update * Update AlphaN.md * Update Speed_Density.md * Fuel control overview improvement, added wide band page * Update Wide_Band_Sensors.md * Update Fuel_Overview.md * Update MAF.md * Update MAF.md * Update rusEFI_console_directory.png * Delete rusEFI_console_directory.png * Delete wall_wetting.md * Fuel Index + Formats Also old wall wetting page kill * Update Pages_Fuel.md * Update Pages_Fuel.md * Create Pages_Hardware.md * Update Pages_Hardware.md * Sensor and Actuators index * Start of Ignition Index * Create Fuel_Injectors.md * Moved file * Added PNP72 jumper info * More updates + Software pages * Update MREAdapter72.md * Create Roadmap_Fuel.md * Created Kit Instruction link * Dev_Hardware_Guidelines * Images and links update * Update Dev_Hardware_Guidelines.md * Update Dev_Hardware_Guidelines.md * Update .gitignore * Ignition FAQ and start of what we cannot do * found by **Serching the forum** update * Searching at top of side bar * Minor grammar/wording edits. * MRE * Minor grammar/wording edits. * Minor spacing/readability edit. * Minor grammar/wording edits. * Minor spacing/readability edit. * Minor grammar/wording edits. * Minor grammar/wording edits. * 48 * Minor grammar/wording edits. * Minor grammar/wording edits. * Updated Deucalion_uart (markdown) * Minor spacing/readability edit. * Photo fixes * Minor grammar/wording edits. * Updated Dev_Hardware_Guidelines (markdown) * Minor grammar/wording edits. * Minor grammar/wording edits. * Updated Documentation_Workflow (markdown) * Updated Documentation_Workflow (markdown) * Minor spacing/readability edit. * Create Vault_Of_Ignition_Parts.md * Update Pages_Ignition.md * Minor spacing/readability edit. * Updated FAQ Basic Wiring and Connections (markdown) * Minor grammar/wording edits. * Minor grammar/wording edits. * Minor spacing/readability edit. * Minor spacing/readability edit. * Updated Frankenso (markdown) * Update FAQ_Ignition.md * Minor grammar/wording edits. * Minor grammar/wording edits. * Minor grammar/wording edits. * D is for DISTRACTION * Updated Feature Requests: Feature Bounty Program (markdown) * Updated Feature Requests Feature Bounty Program (markdown) Co-authored-by: Glitch Knitter <64521139+GlitchKnitter@users.noreply.github.com> Co-authored-by: rusefi <rusefillc@gmail.com>
2020-05-30 13:15:49 -07:00
Most people who are installing tune-able ECU's like rusEFI are looking for more power at the track. However your fuel weight advantage is also commonly important. So it is common that an engine will be tuned for peak power when over a certain load, and peak economy when at a cruise load. OEM's are often concerned with minimal environmental impact, so they may tune to a different AFR. Once you have decided on what your AFR strategy is going to be, you'll have to tune rusEFI to deliver that strategy. As well you will probably use a wide band oxygen sensor to measure your AFR and ensure that you are meeting your desired AFR target.
## Supported fuel control algorithms
2023-01-02 11:22:23 -08:00
rusEFI supports mono, individual/sequential and batched fuel injection using one of the following fuel control algorithms:
2023-01-02 11:22:23 -08:00
1. MAF-based or MAP-based table fuel lookup with interpolation - these algorithms only use the raw sensor output and thus they do not account for ambient air temperature, this is only intended as a minimum viable hardware configuration and we would suggest using the AlphaN, Speed Density or MAF air charge methods instead.
2. TPS-based table fuel lookup with interpolation (Alpha-N)
3. MAP-based Speed Density model, with fuel auto-tune provided by a fully registered copy of TunerStudio
2023-01-02 11:22:23 -08:00
4. MAF based air charge model that computed the air mass in the cylinder and thus the required fuel quantity from the direct measurement of the mass air flow.
Loads of little updates and FSIO work (#68) * Fix for Home page and future features page added * Update Acceleration_Compensation.md * Update Fuel_Overview.md * More fuel info * More X-tau * Ongoing Tasks list Free for all list for people to update as they change track * Update Ongoing_Tasks * Hidden names on pages and multi-spark page * Update X-tau_Wall_Wetting.md * Update * Update AlphaN.md * Update Speed_Density.md * Fuel control overview improvement, added wide band page * Update Wide_Band_Sensors.md * Update Fuel_Overview.md * Update MAF.md * Update MAF.md * Update rusEFI_console_directory.png * Delete rusEFI_console_directory.png * Delete wall_wetting.md * Fuel Index + Formats Also old wall wetting page kill * Update Pages_Fuel.md * Update Pages_Fuel.md * Create Pages_Hardware.md * Update Pages_Hardware.md * Sensor and Actuators index * Start of Ignition Index * Create Fuel_Injectors.md * Moved file * Added PNP72 jumper info * More updates + Software pages * Update MREAdapter72.md * Create Roadmap_Fuel.md * Created Kit Instruction link * Dev_Hardware_Guidelines * Images and links update * Update Dev_Hardware_Guidelines.md * Update Dev_Hardware_Guidelines.md * Update .gitignore * Ignition FAQ and start of what we cannot do * found by **Serching the forum** update * Searching at top of side bar * Photo fixes * Create Vault_Of_Ignition_Parts.md * Update Pages_Ignition.md * Update FAQ_Ignition.md * D is for DISTRACTION * stuff * Added Pages_FAQ_and_HOWTO * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * Update Dev_Status.md * FSIO * Labeled A/C Fan to Low-side, Labeled IAC Feed as 12v, Labeled 3A/3B GNDs as Power grounds, Labeled VVT Feed as 12v, Labeled EGR boost sensor as AV/MAP, Labeled TPS * Added in VVT control row, Added in IDLE valve control row, ensured alphabetical sorting excellence * Updated MREAdapter72 (markdown) * Added in TPS 5v power. * Added pin for * Added in instructions for making use of aux low-side. * Updated Proteus (markdown) * Updated Proteus (markdown) * Updated Proteus (markdown) * stuff * online * stepper idle * Create Vault_BMW_Info.md * Updated Proteus (markdown) * docs * docs * more checks * Update FSIO.md * Update FSIO.md * Update FSIO.md * docs * Update FSIO.md * Correction to Fuel Overview. * updates * Created TS-Plugin (markdown) * STM32 working units update * Update Hardware_Proteus_Wiring_v03.md * updates * Update D_is_for_DISTRACTION.md Co-authored-by: ByteVenom <5294819+ByteVenom@users.noreply.github.com> Co-authored-by: Matthew Kennedy <matthewkennedy@outlook.com> Co-authored-by: rusefi <rusefillc@gmail.com> Co-authored-by: rusefi <rusefi@users.noreply.github.com>
2020-06-19 06:33:41 -07:00
Wideband Oxygen Sensor is pretty much a requirement for both manual and auto-tuning.
2023-01-02 11:22:23 -08:00
![General Settings](Fuel/Fuel_Control/general.png)
Within each fuel calculation mode there is coolant temperature correction ("warm-up mode"), battery voltage correction and injector open time ("injector lag") correction.
Commands related to injector lag:
set_flat_injector_lag LAG
set_injector_lag VOLTAGE LAG
set targetvbatt VOLTS
sequential: set injection_mode 1
batch: set injection_mode 2
rusEFI could be used with MAF sensors sending out voltage (like Mazda Miata) or current (like Ford Aspire).
2023-01-02 11:22:23 -08:00
![Table](Fuel/Fuel_Control/table.png)
(also some content at [this forum thread](http://rusefi.com/forum/viewtopic.php?f=2&t=1124))
## I/O settings
Here are examples of some relevant commands:
set_injection_pin 1 PB7
fuelbench 100 200 10a
## Full Formulas
2021-07-03 20:25:25 -07:00
### Alpha-N
2023-01-02 11:22:23 -08:00
TPS-based table fuel lookup with interpolation (Alpha-N)
2023-01-02 11:22:23 -08:00
fuel_squirt_duration = injector_lag_curve_lookup(V_BATT) + warm_up_curve_lookup(COOLANT_TEMPERATURE) *intake_air_correction_curve_lookup(INTAKE_AIR_TEMP)* fuel_table_lookup(RPM, TPS)
where TPS is the reading at the start of engine cycle
### MAF
2023-01-02 11:22:23 -08:00
MAF-based table fuel lookup with interpolation
2023-01-02 11:22:23 -08:00
fuel_squirt_duration = injector_lag_curve_lookup(V_BATT) + warm_up_curve_lookup(COOLANT_TEMPERATURE) *intake_air_correction_curve_lookup(INTAKE_AIR_TEMP)* fuel_table_lookup(RPM, MAF)
where MAF is the reading at the start of engine cycle
## Auto tune
2023-01-02 11:22:23 -08:00
Fuel map auto-tune is a process of automatically preparing the configuration table based on the information gathered while vehicle is being operated. At the moment we rely on EFI Analytics Tuner Studio for fuel map (MAF mode) or VE map (Speed Density mode).
## Closed loop correction
2023-01-02 11:22:23 -08:00
Last but not least closed-loop fuel correction dynamically corrects fuel to match target AFR. The better your maps are, the better your actual AFR would be as is. Closed-loop correction is the tool to fix the gap between your maps, our models and reality.
![Fuel PID options](Images/Fuel_pid.png)
## Acceleration Enrichment
### Why Do We Need It?
**(This only applies to gasoline engines; other fuels may react differently)**
2023-01-02 11:22:23 -08:00
In order for the engine to run, the cylinders must be supplied with a combustible mixture of air and fuel. Under static or quasi-static conditions, the basic fuel algorithms take care of that. But under dynamic conditions in the intake area, especially with a quick change in throttle position things are different. Fuel enters the cylinder as a mix of evaporated fuel and droplets on most injected engines. How much evaporated fuel the air can hold depends on several factors, but most importantly on temperature of the air and pressure.
Pressing down on the gas pedal increases the pressure in the intake manifold which has the effect that it can't hold as much evaporated fuel anymore. As a result, some of the fuel contained in the air deposits on the intake runner walls. This is especially true coming off a strong vacuum such as idle or slow cruise/coast. Now this fuel is not available for combustion, creating a lean condition. This has to be corrected for and that's what acceleration enrichment is mostly about. There are plenty of other effects going on, such as the “puddle of fuel” that is explained under the wall-wetting theory. The main point is: When the pressure in the intake increases rapidly, we create a temporary lean condition.
Of course the opposite is true as well: When lifting off the gas pedal, suddenly the pressure in the intake drops and the air can hold more fuel vapor which it will suck off the intake walls. This creates a temporary rich condition. This usually isn't harmful to how the engine is running, but it's detrimental to fuel efficiency and the environment.
2023-01-02 11:22:23 -08:00
### TPS Delta Strategy
2023-01-02 11:22:23 -08:00
TPS-movement can be used as a predictor of change in MAP. This is equivalent to the accelerator pump on carbureted engines. A slow push on the pedal (small delta) causes very little or no enrichment (dumped fuel), whereas a hefty stomp on the pedal and rapid movement result in a big additional shot of fuel.
The advantage of TPS based enrichment is that it reacts very quickly and can react to small amounts of change at or near closed throttle. The disadvantage is that it cant react to changes in MAP that are not caused by a change in throttle position, like a turbo-charger spooling up. Usually a mix of load-based and TPS-based enrichment is employed.
2023-01-02 11:22:23 -08:00
#### Explanation of parameters
The parameters for TPS-based enrichment have the same meaning as the Engine-Load based parameters. However, there is no multiplier- this is taken care of in a separate table.
![TPS Parameters](Images/TPS_based_parameters.png)
#### TPS/TPS acceleration extra fuel
![TPS Enrichment](Images/TPS_multiplier_table.png)
TODO: fix error - we do not add 10% extra fuel, we add 10ms extra fuel! not multiplier any more, just extra fuel
2023-01-02 11:22:23 -08:00
This table defines the amount of additional fuel injected, based on throttle movement. The X-Axis is the “From” TPS and the Y-Axis is the “To” TPS. So if the TPS changes from 0% to 1%, we add 10% fuel. In the above table, if TPS changes from 0 to 3 the firmware adds 17% fuel.
Why so complicated? A throttle-body is not a linear device. Cracking it slightly open from completely closed will cause much more of an increase in MAP than opening it the last percent from 99% to 100%. This table allows to adjust for this degressive behavior.
In future more adjustments may be needed- for example at low rpms a throttle that is just 10% open may essentially be considered fully open, since it does not cause a significant restriction to the low airflow, so opening the throttle from 10% to 100% may have only a negligible effect on MAP. But at high rpms there will still be a significant change in MAP, Even when the position changes from 90% to 100%. A calibration table for this behavior may be required in order to be able to tune enrichment perfectly.
2023-01-02 11:22:23 -08:00
#### To Do
1. Come up with a strategy on how to deal with cumulative effects. Example: Push down on the gas pedal. What if that process takes longer than one engine rotation?
**Example:**
| Rotation in deg | Throttle Pos | Addtl. fuel current | Addtl. Fuel Taper
| - | - | - | - |
| 0 | 0 | 0 | 0 |
| 360 | 2 | 13 | 0 |
| 720 | 4 | 5 | 8 |
Should the fuel from the current change and the previous taper be added up? Or averaged? Or should the latest change completely override the previous change?
2. Deal with warming up. During warmup more additional fuel is needed. We need a setting to adjust for that.
2023-01-02 11:22:23 -08:00
#### Tuning Strategy
The point of enrichment tuning is to keep the engine from bogging down when stepping on the throttle. While it would be great to maintain perfect AFRs while this is happening, that goal is currently not realistic. OEM ECUs dont get it perfect either.
2023-01-02 11:22:23 -08:00
A gasoline engine will run without noticeable bogging at AFRs between 9 and 16, maybe 17 or so. So were shooting to stay within a very wide corridor.
On tuning there seem to be two main conflicting theories:
- Use mainly Load-based enrichment and fix the little blips that cant be tuned with load-based enrichment by TPS-based.
- Use mainly TPS-based enrichment and add a little bit of load-based enrichment to fix what TPS-based cant take care of.
Either way seems to work eventually. Lots of trial and error will be needed to get this just right.
Pointers:
- Only tune enrichment on a fully warmed up engine
- Very sharp throttle movements are the hardest to tune, start with more gentle movements first
- You can tune for sudden throttle-stabs without driving, just sitting in idle
- The goal is drivability. If you dont notice any bogging, no matter what you do with the throttle, youre good- stop right there, no matter what your AFRs are