In engines with electronic control unit (ECU), the primary information upon which engine control calculations are based is the engine crankshaft position. An electronic control unit comprises processors, software, and electronic hardware to process signals and perform engine operations. In most cases, crankshaft positioning relies on the respective cylinder top dead center position (TDC) as a reference point. This angle information is used to precisely time key events related to engine combustion, which in turn affects engine performance and emission. The accuracy of this information is critical, as any error may lead to engine shutdown. There are generally two possibilities for signal failure: (1) failure of a sensor, wiring, or connector resulting in a loss of signal, or (2) a high level of external noise on the sensor signal lines that interferes with the signal's zero crossing detection.
In order to identify the cylinders of a multicylinder internal combustion engine, most ECUs require signals from a camshaft sensor and a crankshaft sensor. Most engines are configured such that the crankshaft undergoes two revolutions for every single revolution of the camshaft. Typically, the engine crankshaft comprises a crank wheel that is mechanically coupled to the crankshaft. The crank wheel comprises a plurality of elements with at least one reference element, such as a missing gap, oversized element, an attached element or differently configured or shaped element, and the like. Crank sensors are positioned proximate to the crank wheel to produce signals upon passage of the elements. This signal information is sent to the ECU, and the ECU determines the position of the crankshaft by counting the number of elements after the marking element, this is also referred to as synchronization. This enables the ECU to know 360 degree position of the crankshaft. The ECU must then use the signal of the cam sensor to determine if the crankshaft is in the first revolution or the second revolution. Thus, if there is a break in the information from the crankshaft sensors, the ECU will lose the position of the crankshaft and will not know whether the crankshaft is in the first revolution or the second revolution. Consequently, the ECU cannot determine which cylinder should be injected with fuel or not (e.g. with respect to a typical diesel engine, whether the cylinder is in the power stroke or exhaust stroke). If a break in the crank sensor information occurs, the engine may be rendered incapacitated.
One attempt to minimize this problem has been to provide two crank sensors; the idea being that one crank sensor acts as a back-up sensor to the other. According to this configuration, the ECU will receive signal information from one of the sensors. If a failure happens, the ECU will effectuate a “switchover” to the other sensor. Having a redundant sensor does address the problem somewhat, but there remain important performance issues. In the event of a failure of the active sensor, the ECU loses engine position and is incapable of calculating speed. The ECU must stop fueling until synchronization is complete on the redundant sensor. The synchronization of the crank sensor signals and determination of the proper crank revolution requires time. The cessation of fuel injection during this time dramatically decreases engine performance.
a-c shows signal graphs pertaining to different signal disturbance scenarios.
a-c shows signal graphs pertaining to signals obtained during simulations to show differences of disturbance events at different RPMs
This application builds on the advancements disclosed in Co-pending U.S. application Ser. No. 10/855,914 ('914 application) filed May 27, 2004, which is incorporated herein in its entirety to the extent not inconsistent with the teachings herein. The '914 application disclosed, inter alia, new ‘bumpless’ crankshaft positioning systems for sensing crankshaft positioning that alleviated many of the problems experienced with a “switchover” from one crankshaft sensor to another when it is determined that a crankshaft sensor is malfunctioning. In working on improving upon the significant advancement of bumpless crankshaft position sensing, the inventors have identified that, in some instances, electromagnetic radiation may cause disturbance issues in the bumpless system. Locomotives are manufactured in two different models, those with an AC-electric drive system and those with a DC-electric drive system. The generator is utilized during engine start-up to turn the diesel engine. This operation consumes large amounts of electric power, and creates a significant amount of magnetic radiation. The magnetic radiation can be picked up by the crank sensors and generate transient or other unwanted phenomena. Accordingly, the inventors have enhanced the crankshaft positioning to reject these disturbances thereby achieving a more robust virtual crank signal. This and other advantageous aspects will be described further herein.
One embodiment pertains to a noise-resistant method of monitoring crankshaft position of an internal combustion engine. The method comprises providing a rotating member operationally coupled to said crankshaft, wherein said rotating member comprises a plurality of spaced elements and at least one reference element provided with a different spatial characteristic thereon; providing one or more crankshaft positioning sensors proximate to said rotating member so as to allow generation of at least one corresponding crank signal streams responsive to rotation of said rotating member; monitoring for crank signal generation during a predetermined inspection window, wherein, during undisturbed crank signal generation, a predefined number of crank signals occur in said predetermined inspection window; generating a virtual crank signal stream derived from crank signals of at least one crank signal stream,
Another embodiment pertains to an engine control system for an internal combustion engine, wherein said engine comprises at least one cylinder, each cylinder retaining a piston, and wherein a crankshaft is operationally coupled to the pistons such that the crankshaft rotates twice per engine cycle and the position of each piston depends upon the rotational position of the crankshaft, said engine control system comprising: (a) a signal processor, wherein said signal processor is configured to receive signals from one or more crank positioning sensors; (b) a rotating member arranged to rotate responsive to rotation of said crankshaft, said rotating member comprises a plurality of spaced elements and at least one reference element provided with a different spatial characteristic thereon; (c) one or more crank positioning sensors proximate to said rotating member so as to allow generation of one or more corresponding crank signal streams responsive to rotation of said rotating member; wherein said signal processor comprising at least one processing module; at least one memory device operationally coupled to said at least one processing module; and program code modules stored in said signal processor:
a computer readable first program code module for causing said signal processor to monitor for crank signal occurrence in a series of inspection windows in which, based on upstream crank signal period measurements, one or more crank signals are expected to be located;
a computer readable second program code module for causing said signal processor to accept or reject a given crank signal depending on relationship between actual location and expected location of said given crank signal; and
a computer readable first program code module for causing said signal processor to employ current or previously accepted crank signals, or both, to synthesize a virtual crankshaft positioning signal stream that correlates with crankshaft position;
wherein said virtual crankshaft positioning signal stream is useful for monitoring crankshaft position.
Shown in
In addition to the active crank series of signals, the signal processor 150 generates a clock series of signals, which is a duplicate of the active crank series of signals. The origination of the clock series of signals and their function is described in more detail, infra. The clock series of signals is sent to the first and second engine control processors 120, 130 via line 154 (also shown as 375 T2 clock).
The signal processor also receives cam signals from a camshaft sensor (not shown) via line 113 (also shown as CAM). The cam series of signals is sent to the first and second engine control processors 120, 130 via line 152 (also shown as 375 cam).
The first and second engine control processors 120, 130 are responsible for the operation of a bank of cylinders each (typically 6 or 8 cylinders based on 12 or 16 cylinder engines, respectively). Accordingly, in a 16 cylinder engine, the typical arrangement would comprise a left and right signal processor which are each in communication with two engine control processors, which each control a bank of 8 cylinders.
The system 100 also comprises external signal inverters 159 and 155 (also shown as Inverter). During processing, the signal processor 150 inverts the active crank signals and the clock signals. The external signal inverter 159 inverts these signals. The inverter also provides a robust (+5V) push pull signals that are more resilient to interference.
The locomotives are manufactured in two different models, those with an AC-electric drive system and those with a DC-electric drive system. The generator is utilized during engine start-up to turn the diesel engine. This operation consumes large amounts of electric power, and creates a significant amount of magnetic radiation. The magnetic radiation can be picked up by the crank sensors and generate transient or other unwanted phenomena. These disturbances are, if they propagate through to the FPGA, noted as extra inserted teeth. If unaccounted for, extra inserted teeth can lead to severe problems, such as mis-firing, and mechanical fatigue and/or damage to the engine. In addition to the requirement that the FPGA algorithm is to provide a virtual sensor signal, a number of requirements for the disturbance rejection properties of the FPGA-based signal processing algorithm are stipulated. These requirements are based on the disturbance scenarios shown in following figures.
a describes a disturbance scenario in which the FPGA notes one or more additional teeth close to the falling edges of the un-disturbed signal.
In one embodiment, the missing tooth gap for the virtual crank sensor signal is aligned with the missing tooth gap for the first crank sensor signal. The virtual crank sensor signal should not have more than 89 teeth. If a disturbance, similar to any of those described in
A phase shift, between the virtual crank sensor output and the crank wheel, typically is not to be allowed for more than 7 crank revolutions. If a sensor is continuously disturbed, the sensor should be de-activated (the term de-activate(d) or de-activation as used herein in relation to crank positioning sensors means that the information from the sensor is ignored and therefore not used in the computation for synthesizing the virtual signal, not that the crank sensor is shut down or modulated), and re-activated first when it has been free from disturbances for some period of time. In addition to these requirements, the signal processing algorithm should be able to detect crank signals belonging to the range of engine speeds that spans from 30 RPM to 1200 RPM. Within this range, the algorithm must be able to cope with the following acceleration/deceleration levels:
The following is a list of the features provided by, and properties of, an exemplary embodiment of the FPGA algorithm implemented in signal processor 150. The embodiment comprises one or more of the following features.
The algorithm merges the measurement information obtained from two crank sensor measurements and forms a single virtual crank sensor signal that is free from disturbances.
The missing tooth gap for the virtual crank sensor signal is aligned with the missing tooth gap for the first crank sensor signal.
The measurements obtained from the two crank sensor measurements are filtered to remove disturbances.
Disturbances are sensed by the FPGA algorithm as a series of narrow teeth, or, alternatively, as no teeth at all, the latter occur when disturbance prevents a zero crossing thus inducing extra missing teeth.
The filtering procedure employs an inspection window, within which the algorithm expects to find exactly one tooth for each crank sensor channel.
If the algorithm detects that a tooth is missing or disturbed on one of its crank sensor measurements, the algorithm discards that measurement information and relies on the measurements obtained from the other crank sensor signal.
If the algorithm detects that teeth are missing or disturbed on both of its crank sensor measurements, the algorithm then assumes that the engine speed remains constant and proceeds under the assumption that a tooth edge was found at T=TS+PT where T denotes the time in absolute terms, TS denote the time-based location of the last tooth edge and PT denotes the current estimate of the tooth period time.
The current estimate of the tooth period time (PT) is the average of the tooth period times for the last four teeth. This average filtering scheme is to further improve the algorithm's robustness against disturbances.
If the algorithm senses that a particular crank sensor measurement is disturbed for more than 3 teeth during one revolution, the algorithm temporarily de-activates that particular crank sensor measurement. While the crank sensor measurement is de-activated the algorithm automatically discards all measurement information arriving from that sensor signal.
To re-activate a de-activated sensor signal the algorithm requires that no disturbances occur for one full revolution. Here meaning from one missing tooth gap to the next. Thus if the sensor remains disturbance free from tooth #70 of a particular revolution to tooth #80 of the next revolution the sensor will not be reactivated. But if the sensor remains disturbance free from tooth #70 of a particular revolution to tooth #89 of the next revolution the sensor will be re-activated.
The tooth period time PT is not updated during the missing tooth gap phase. Hence, if both sensors are activated the PT is not updated during tooth #90 and tooth #3. If the first crank sensor signal is active and the second crank sensor signal remains de-activated PT is not updated during tooth #90, but is updated during tooth #3.
The phase shift between the two crank sensor measurements must always be less than 0.25 crankshaft degrees. If the phase shift is larger than 0.25 degrees the algorithm will use the crank sensor measurements that is closest to the previously calculated time period.
If teeth are detected during the missing tooth gaps, when the algorithm expects to find no teeth, there is a possibility that there is a large phase shift between the virtual crank sensor signal and the crank sensor measurements. This can potentially damage the engine. The algorithm therefore monitors the sensor activity during the missing tooth gaps. If a phase shift is detected the engine will run for a maximum of seven revolutions.
If both crank sensor signals are activated, and no disturbances affect the crank sensor measurements, or if the disturbances affect only one of the crank sensor measurements, the maximum acceleration/deceleration levels the algorithm can handle are given by the following table.
If only one crank sensor signal is activated, and disturbances affect its measurements, of both sensors are active and disturbances affect both measurements simultaneously, the maximum acceleration/deceleration levels the algorithm can handle are given allowing table:
In a worst-case scenario, when both sensors are active and disturbances affects both tooth #1 and tooth #2, PT will not be updated for 4 consecutive teeth due to the rule that PT is not updated during the missing phase. The maximum acceleration/deceleration levels the algorithm can handle under these conditions are given by the following table.
The FPGA algorithm may experience difficulty tackling disturbances that cause the tooth edges to shift their positions. If the change of the position is less than +−1 crankshaft degrees, and affects both sensor signals simultaneously, the FPGA algorithm fails to detect this disturbance. The average filtering scheme, employed when updating PT, helps to reduce the influence of this problem, but cannot completely eliminate its influence on the virtual crank sensor signal.
Analogue Front-End (AFE) Interface—Filtering characteristics
The AFE, (13 or 14,
The simulations reveal that when the input signal is subjected to noise, small errors are introduced near the falling and rising edges of the digitized signal. The errors are noted as small differences in when the falling and rising edges occur. Occasionally, extra inserted teeth can also be noted. This, however, occurs only at lower RPMs. Finally, it should be noted that at the noise level used in these simulations (which is significant), the errors are small and therefore of little significance.
Timing Characteristics of the Digital Crank Sensor Signals
Since the crank wheel is mechanically linked to the engine, it will always spin with the same speed as the engine. Given the engine speed, the tooth frequency can be computed using formula 2-1.
Tooth Frequency=W×90/60[Teeth/s] (2-1)
W denotes the engine speed (in RPM). By inverting the tooth frequency the tooth period time can be computed using formula 2-2.
Tooth Period=PT=1/Tooth Frequency=60/(W×90)[s/Tooth] (2-2)
During acceleration and deceleration of the engine, the tooth period changes between two consecutive teeth. From an algorithmic perspective it is important to know how big this change is. In order to derive a formula for this, recall that, given an acceleration or deceleration speed, A [RPM/s], the change in speed can be expressed as in formula 2-3.
W1=W0+dt×A (2-3)
In formula 2-3 dt refer refers to the time elapsed between measuring the speeds W0 and W1. If it is assumed that the speed changes linearly between two consecutive tooth edges the tooth period time, PT, can be computed using formula 2-4.
PT1=(60×2)/((W0+W1)×90) (2-4)
Now, by combining (2-3) with (2-4), 2-5 is obtained.
PT1=(60×2)/((W0+W0+PT1×A)×90) (2-5)
Formula 2-5 is a second order polynomial equation that has solution 2-6.
PT1=((W0/A)2+(2×60)/90/A)0.5−W0/A (2-6)
Consequently, by combining formula 2-6 and formula 2-2 it is possible to compute a measure of the change in PT between two consecutive teeth. At high speeds, even high acceleration terms, produce small changes in PT. At low speeds, even small acceleration terms have a large influence. To satisfy the requirements on acceleration/deceleration the algorithm must accept at least a 4% change between two consecutive teeth.
As will be appreciated by one of skill in the art, embodiments of the present invention may be embodied as a device or system comprising a processing module, and/or computer program product comprising at least one program code module. Accordingly, the present invention may take the form of an entirely hardware embodiment or an embodiment combining software and hardware aspects. Furthermore, the present invention may include a computer program product on a computer-usable storage medium having computer-usable program code module embodied in the medium. Any suitable computer readable medium may be utilized including hard disks, CD-ROMs, DVDs, optical storage devices, or magnetic storage devices.
The term “processing module” may include a single processing device or a plurality of processing devices. Such a processing device may be a microprocessor, micro-controller, digital signal processor, microcomputer, central processing unit, field programmable gate array, programmable logic device, state machine, logic circuitry, analog circuitry, digital circuitry, and/or any device that manipulates signals (analog and/or digital) based on operational instructions. The processing module may have operationally coupled thereto, or integrated therewith, a memory device. The memory device may be a single memory device or a plurality of memory devices. Such a memory device may be a read-only memory, random access memory, volatile memory, non-volatile memory, static memory, dynamic memory, flash memory, and/or any device that stores digital information. A computer, as used herein, is a device that comprises at least one processing module.
Certain embodiments of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer-readable program code modules. These program code modules may be provided to a processing module of a general purpose computer, special purpose computer, embedded processor or other programmable data processing apparatus to produce a machine, such that the program code modules, which execute via the processing module of the computer or other programmable data processing apparatus, create means for implementing the functions specified in the flowchart and/or block diagram block or blocks.
These computer program code modules may also be stored in a computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the program code modules stored in the computer-readable medium produce an article of manufacture.
A block schematic representation of the architecture of an exemplary signal processor (FPGA) is shown in
Black arrows indicate the primary path for the signals, while the white, and thick, arrows indicate the signal path for the control signals. The labels T1, T2, T3, TS, Cin1FE, Cin2FE and PT correspond to variable names in the FPGA algorithm.
Since there are two input signals, the sampling system is divided into two input channels—one connected to the first crank sensor and one connected to the second crank sensor. Note also that the FPGA algorithm utilizes separate timer registers for the two input channels (denoted T1 and T2), but stores only the most recent timer value (and does not maintain a history of past timer values). The sampling system for each input channel is furthermore divided into two separate processes—a sampler and a signal conditioner. The samplers are responsible for detecting the falling edges, while the signal conditioners, based on a set of detection rules, are responsible for registering the time stamps of the falling edges in the corresponding channel registers, T1 or T2.
Most of the sub-systems depicted in
A. Behaviour During the Normal Operating Mode
To make the FPGA code more efficient and less resource intensive, the two sampler processes lack built-in intelligence, and thus cannot establish whether a falling edge is triggered by a disturbance or an actual tooth edge. Instead the sampler, blindly, registers every falling edge, leaving it to the remaining sub-systems to either discard or accept its measurements. In its current form, the FPGA algorithm employs a two-level filtering procedure to decide how to respond to the falling edges registered by the two samplers. At the lower level, the filtering is carried out by the signal conditioning processes, and at the upper level, the filtering is carried out by the supervisory system. It should also be noted that only at the supervisory level does the filtering process take into account both signal paths. Thus, the filtering carried out by each signal conditioner process has knowledge only of the readings obtained from the local sampler. The main aim of the two-level filtering structure employed by the FPGA algorithm is to enable the formation of an internal representation of a ‘cleaned’ measurement signal. The general idea is to gradually ‘clean’ the measurement readings as they are passed along the signal path, until they reach a cleanliness-state where they can be used as a basis for the virtual crank sensor output. To reach the desired level of cleanliness for the ‘cleaned’ measurement signal, a wide range of filtering techniques is employed. While on the outset these techniques appear very different, they all make use of the following two fundamental concepts:
1. Both the upper and lower level of filtering procedures rely on the assumption that the tooth frequency changes only very little between two consecutive teeth, i.e. (T1(t−1)−T1(t−2)) is roughly equal to (T1(t)−T1(t−1)). Under this assumption the FPGA algorithm can predict, by inspecting past occurrences of falling edges, roughly when the next falling edge is expected to occur. To enable this feature, however, the FPGA algorithm needs to maintain a history of past timer values. For this reason the supervisory system maintains two additional time stamp registers, TS and PT. The 21-bit register TS holds the time stamp for the end of the previous tooth (hence the start of the current tooth) and the 21-bit register PT holds the current tooth period. Thus, provided the engine speed remains constant, the next tooth edge (falling edge) is to be found at: TS+PT. Note that both TS and PT are managed by the supervisory system, and together characterizes the shape of the ‘cleaned’ measurement signal.
2. The second concept, central to both filtering procedures, is the use of an inspection window. For each new tooth that the FPGA algorithm tries to detect a new inspection window is created. Each window starts on the edge of the previous window and ends at: 1.25×PT+TS (i.e. when T>=1.25×PT+TS). When the inspection window expires, the FPGA algorithm analyses the measurements obtained from both input channels, and provided a valid tooth has been detected on either or both channels, the FPGA algorithm updates the contents of the registers TS and PT. In the unlikely event that the FPGA algorithm fails to detect a valid tooth for the duration of the first inspection window, the FPGA algorithm extends the inspection window to: 2.5×PT+TS1. The FPGA algorithm employs a flag, LongT, to indicate the size of the inspection window. Admittedly, a much easier and less complex solution in the latter case, would have been to simply assume that a valid tooth was detected at TS+PT and update TS and PT accordingly (in such a case PT and TS would have been updated according to: PT=PT, TS=TS+PT). The reason for choosing the more complex approach is that it provides for better accuracy in some instances. It should be noted that if the extended detection window is already in use, and the FPGA algorithm yet again fails to detect a valid tooth, the FPGA algorithm updates TS according to: TS=TS+PT, and thereafter proceeds as before, with an extended inspection window in place (i.e. the detection window is shifted one tooth). Following the detection of a valid tooth, the inspection window is always reset to normal.
In general terms, the two-level filtering structure is not only separated by execution context (here meaning the subsystem in which they are implemented, i.e. supervisory system or signal conditioner system), but also separated by the type of disturbances they tackle. The filtering procedures executed by the signal conditioner processes are designed to tackle rapid disturbances—disturbances that can be detected within the inspection window. By contrast, the supervisory level filtering procedures can detect much more slow-moving disturbances, which spans several inspection windows.
B. Low-Level Filtering—Signal Conditioners
The two signal conditioners—one for each input channel—carries out low level filtering on the input signals and manages each input channel's time stamp register (T1 or T2). In addition, the signal conditioner systems also manage various status registers and flags, which are used by the supervisory system to de-activate and activate the sensor signals (more about activation and de-activation below). In order to communicate with the supervisory system, the signal conditioner processes utilizes the following flags and registers:
T1 or T2: These 21-bit registers hold the time stamp of the last falling edge.
C1 Valid or C2 Valid: These flags are used by the supervisory system to establish if the values contained in T1 or T2 corresponds to a valid tooth edge. These flags are checked by the supervisory system after the inspection window has expired.
PCL1 or PCL2: These 7-bit registers essentially communicate the failure rate of the input channel. When the PCL-registers reaches zero, the input channel is de-activated by the supervisory system, here meaning that the supervisory system will discard the data arriving from the input channel (the sampler and signal conditioner will still be active, trying to detect teeth, and trying to become re-activated).
The supervisory system uses a flag, Slave1 or Slave2, to communicate activation/de-activation status to the signal conditioners. If the flag is set to true, the input channel is currently de-activated.
At the start of each new inspection window the signal conditioner process is reset, here meaning that the process is reset to its idle state and that the flags C1Valid/C2Valid are reset to false (the contents of the PCL1/PCL2-registers and T1/T2-registers remain unchanged and the status of the Slave1/Slave2 flags remain unaltered). Throughout the inspection window the signal conditioner process monitors the sampler activity. Whenever the sampler process signals that a falling edge has occurred the signal conditioner follows the following set of rules to determine if the current edge corresponds to a disturbance or an actual tooth-edge:
1. If the edge occurred inside the window defined by: 0.75×PT<=T−TS<=1.25×PT (or 1.5×PT<=T−TS<=2.5×PT if an extended inspection window is used), and the flag C1Valid/C2Valid is false, the flag C1Valid/C2Valid is set to true (i.e. signal to the supervisory system that the current tooth is valid) and T1/T2 is set equal the current time (T).
2. If the edge occurred inside the window defined by: 0.75×PT<=T−TS<=1.25×PT (or 1.5×PT<=T−TS<=2.5×PT if an extended inspection window is used), and the flag C1Valid/C2Valid is already set to true (i.e. this is the second falling edge during this inspection window), the flag C1Valid/C2Valid is set to false (i.e. signal to the supervisory system that the current tooth is invalid) and the signal conditioner process will, for the remainder of the detection window, discard all data arriving from the sampler.
3. If the edge occurred outside the window defined by: 0.75×PT<=T−TS<=1.25×PT (or 1.5×PT<=T−TS<=2.5×PT if an extended inspection window is used), the flag C1Valid/C2Valid is set to false (i.e. signal to the supervisory system that the current tooth is invalid) and the signal conditioner process will, for the remainder of the detection window, discard all data arriving from the sampler. At the end of the inspection window, prior to the reset, the signal conditioners update the contents of the PCL1/PCL2 registers. If the input channel is active (i.e. Slave1/Slave2 is set to false) the PCL1/PCL2 register is updated according to the following rules:
1. If the flag C1Valid/C2Valid is set to true, then the PCL1/PCL2 register is incremented by unity (89 is the maximum value).
2. If the flag C1Valid/C2Valid is set to false, then the PCL1/PCL2 register is decremented by 24 (0 is the minimum value). The un-symmetric counting mechanism employed for the PCL1/PCL2 registers, means that if 4 teeth, within 89, are deemed invalid by the signal conditioner, the PCL1/PCL2 register reaches 0 and the input channel is subsequently de-activated. Once the sensor has been de-activated the signal conditioner process employs the following update rules for the PCL1/PCL2 register:
Since the supervisory system will re-activate a de-activated sensor, first when the PCL1/PCL2 register reaches 89, these update rules implies that 89 valid consecutive teeth are required for the sensor to become re-activated (if the sensor is currently de-activated).
C. High-Level Filtering and the Updating of the Registers TS and PT
At the end of each inspection window the supervisory system receives the status flags and time stamps from the signal conditioners. The supervisory system further analyses this data, and then merges these measurements into a ‘cleaned’ measurement signal, characterised by the registers TS and PT. During the analysis and processing of the measurement readings and status flags, the supervisory system forms an intermediate signal, characterised by the 21-bit time-stamp register T3. The filtering procedure employed by the supervisory system can therefore be divided into two steps:
1. Diagnose the measurements and status flags obtained from the two input channels, and if at least one of the channels has registered a valid tooth, compute a ‘merged’ time stamp, and store this value in the register T3.
2. Use the value stored in the register T3 to update TS and PT.
In order to merge the readings obtained from the two input channels, the supervisory system employs the following rules (these rules are executed after each inspection window has expired):
1. If both Slave1 and Slave2 are set to: false (i.e. both signal paths are active), and if both C1Valid and C2Valid are set to: true (i.e. both input channels have registered a valid tooth), then the following rules apply:
2. If Slave1 is set to: true, or if C1Valid is set to: false (i.e. if the signal is either de-activated or disturbed) and C2Valid is set to: true, and Slave2 is set to: false, then the supervisory system sets T3 to: T3=T2.
3. If Slave2 is set to: true, or if C2Valid is set to: false (i.e. if the signal is either de-activated or disturbed) and C1Valid is set to: true, and Slave1 is set to: false, then the supervisory system sets T3 to: T3=T1.
4. If none of the above is true T3 is not updated.
During normal operation, when both sensor signals are valid, the register T3 consequently holds the average between the registers T1 and T2 (see
1. If T3 was not updated, i.e. some fault(s) was discovered, or if the supervisory system expects a missing tooth gap, the supervisory system expands the inspection window (i.e. setting LongT to: true). If an expanded inspection window is already in use, the supervisory system also updates the register TS according to: TS=TS+PT.
2. If T3 was indeed updated, and an extended inspection window is not in use (i.e. LongT is set to: false), the supervisory system performs the following:
3. If T3 was indeed updated, and an extended inspection window is in use (i.e. LongT is set to: true), the supervisory system performs the following:
As can be seen from the update rules above, a moving average scheme is used for updating the FPGA algorithm's estimate of the tooth period, PT. The moving average scheme makes the FPGA algorithm robust against disturbances, but has the drawback that it also makes the FPGA algorithm less responsive to acceleration and deceleration.
In
The supervisory system also ensures that the signal channels are activated and de-activated when needed. This is achieved by monitoring the PCL1/PCL2-register, and by setting the Slave1/Slave2-register appropriately. If a channel is activated and its PCL-register reaches zero the supervisory system sets the corresponding Slave1/Slave2 register to true. The Slave1/Slave2 register will thereafter remain true (indicating a de-activated state) until the corresponding PCL1/PCL2-register reaches 89. During normal operating mode, the flags Slave1 and Slave2 can never be true simultaneously. If this happens, the supervisory system changes its master mode to its synchronization mode.
D. Virtual Crank Sensor Output
The virtual crank sensor signal is formed from past values of PT and TS. As illustrated in
Tv(t)=PT(t−1)+TS(t−1) or Tv(t)=2×PT(t−1)+TS(t−1) when LongT is set).
Observe that the virtual crank sensor signal remains in its low state until the inspection window expires (normally this occur at 1.25×PT(t−1)+TS(t−1)). In order to generate a virtual crank sensor signal with the missing tooth gap correctly inserted (in the FPGA algorithm the missing tooth gap of the virtual sensor output coincides with the missing tooth gap of the first crank sensor), the FPGA algorithm need to maintain a tooth counter. The teeth are numbered 1-89, where tooth #1 corresponds to the first tooth following the missing tooth gap for the first crank sensor signal, and where tooth #89 corresponds to the tooth prior to the missing tooth gap for the first crank sensor signal. At a supervisory level in the algorithm, the FPGA algorithm continuously tries to detect if there is a phase difference between the virtual crank sensor signal and the measurements. Phase shifts are inadvertently introduced if the tooth counter is initialized on the wrong tooth—a phenomena that fortunately only can arise under very rare conditions. Despite the low probability that phase shifts are introduced, a procedure that detects phase shifts are extremely important as phase differences can cause serious damage to the engine.
E. Detecting Large Phase Shifts (More than 4 Degrees)
If a phase difference is inadvertently introduced, the FPGA algorithm can relatively quickly sense this by checking the status of its measurements during tooth #90 and tooth #3. In the normal case, when there is no phase difference, tooth #90 corresponds to the missing tooth gap for the first crank sensor signal while tooth #3 corresponds to the missing tooth gap for the second crank sensor signal. Consequently, if teeth are consistently emitted from the crank sensors during these phases, the FPGA algorithm should stop outputting the virtual crank sensor signal and re-synchronize against its measurements. This feature is implemented in the FPGA algorithm as a counter (denoted PIM) that increases its count by unity whenever a tooth is detected during the missing tooth gap (can be two each revolution). The counter decreases its count by unity if no tooth was detected during the missing tooth gap. When the counter value reaches 7 the FPGA algorithm stops outputting the virtual crank sensor signal and starts the re-synchronization process.
If a phase difference is present the FPGA algorithm, using the logic described above, will run for four revolutions until it starts its re-synchronization process (provided both sensors are active). If only ones sensor is active the FPGA algorithm will run for seven revolutions until it starts its re-synchronization process.
F. Behavior During the Synchronization Mode
Operation of the tooth-based sampling procedure employed by the FPGA algorithm is halted whenever the crank wheel stops spinning (that is, when the engine is stopped). To start operation of the FPGA algorithm, and to enable output of the virtual crank sensor signal, the FPGA algorithm needs to re-synchronize its tooth counter and sampling procedure. This involves finding a crank sensor signal that has a stable tooth frequency (to avoid being tricked into resynchronizing its output against a damaged sensor signal) and finding the missing tooth gap (to initialize the tooth counter).
For practical reasons the FPGA algorithm cannot search for a stable tooth frequency (a stable PT) on both sensor signals simultaneously. Instead, the FPGA algorithm alternates between the two sensor signals. The FPGA algorithm searches each sensor signal for 128 consecutive teeth/falling edges, or until a timer time-out event occurs (the timer times out after 87 ms, but is reset every time the FPGA algorithm detects a falling edge). During the 128 teeth the following steps will be carried out.
1. On each falling edge of the sensor signal, the time since the last falling edge is computed and stored in the variable PT.
2. The current PT is compared to the previous PT. If the change is less than 25% a counter is increased by one. If the change was more than 25% the counter value is reset to zero.
3. When the counter reaches 4 (that it after the FPGA algorithm has sensed four valid PTs in a row), the FPGA algorithm starts searching for a missing tooth gap.
4. While searching for the missing tooth gap the FPGA algorithm proceeds as above, meaning that PT is updated on each falling edge and compared to previous values. If the FPGA algorithm senses a change larger than 25% the counter is reset and the procedure is restarted.
5. When/if a missing tooth gap is detected, the tooth counter is set appropriately and the operational mode is changed to Normal.
These steps ensure that when the FPGA algorithm has re-synchronized the pulse train (generated by the crank sensor) has been undisturbed for at least four teeth (six if the missing gap is included). It should be noted that during synchronization, the FPGA algorithm does not filter its PT estimates through by a moving average filter, as done during normal operating mode. However, the history variables registers, PT1, PT2, and PT3 are updated simultaneously to PT. Thus, when the FPGA algorithm transits to the normal operating mode these variables have been properly initialized.
A reference implementation of an exemplary FPGA algorithm is attached hereto as ATTACHMENT A. Those skilled in the art will appreciate that provision of this specific algorithm in no way is intended to limit the scope of the invention. In view of the teachings herein, control system engineers may be able to implement this or design an alternative algorithm to achieve similar aspects and features.
Those skilled in the art will recognize that, in addition to conventional 90-1 and 60-2 crank wheels, any number of rotating member apparatuses may implemented comprising a plurality of elements that generate a signal stream. Furthermore, though crank wheels comprising a missing element or elements are exemplified herein as the reference element, many different elements may be implemented such as, but not limited to, a wider element or different shaped element, or other such elements having different spatial characteristics. In addition to magnetic sensors, variable reluctance sensors and hall sensors, any number of other sensors that are capable of sensing the passage of elements of the rotating member may be implemented in accord with the teachings herein. Furthermore, the algorithm embodiments described herein can be readily adapted to generating a synthesized crank signal based on multiple time variant voltage signals (not necessarily a crankshaft speed sensor) that are fixed to the crankshaft rotation position, including but not limited to, alternators, or other electrical power generating equipment. Further, a phase locked loop can also be implemented as a means of estimating the location a downstream pulse in a pulse series in a synthesized signal.
While various embodiments of the present invention have been shown and described herein, it will be obvious that such embodiments are provided by way of example only. Numerous variations, changes and substitutions may be made without departing from the invention herein. Accordingly, it is intended that the invention be limited only by the spirit and scope of the appended claims.
The teachings of all references cited herein are incorporated in their entirety to the extent not inconsistent with the teachings herein.
Number | Name | Date | Kind |
---|---|---|---|
5471869 | Kuroda et al. | Dec 1995 | A |
5670713 | Machida et al. | Sep 1997 | A |
6041647 | Matsuoka | Mar 2000 | A |
7000598 | Sheikh et al. | Feb 2006 | B2 |
20050263138 | Sheikh et al. | Dec 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
20070256482 A1 | Nov 2007 | US |