This application is based on and incorporates herein by reference Japanese Patent Application No. 2003-382756 filed on Nov. 12, 2003 and 2004-217805 filed on Jul. 26, 2004.
1. Field of Application
The present invention relates in general to A/D (analog-to-digital) conversion of an analog signal to a digital signal, and in particular to an A/D conversion processing apparatus which applies digital processing to exclude the effects of noise in the analog signal from the digital signal.
2. Description of Prior Art
In the prior art, for example in the case of an electronic control apparatus such as an engine ECU (electronic control unit) of a vehicle, a number of signals are acquired by the ECU and subjected to various forms of processing, with the signals being produced by respective sensors which detect the engine operating condition. Some of these signals, such as those of a crank angle sensor or engine speed sensor may be digital signals, while others are analog signals, such as those from an air intake rate sensor, a throttle position sensor, water temperature sensor, etc. The processing results derived by the ECU are used to control fuel injection and ignition timing, etc., of the vehicle engine. Since the operation of the ECU is based on a microcomputer, which cannot directly use analog signals, these are converted to respective digital signals by an A/D converter.
Such a vehicle ECU must operate in an environment in which high levels of electrical noise are generated, such as spark noise from the ignition system, noise produced by switching operation of power transistors, noise produced from motor brushes, noise in the form of induced currents resulting from external magnetic fields such as those of a starter motor, etc.
For that reason, in the prior art, each analog signal that is to be subjected to A/D conversion in a vehicle ECU is first subjected to noise removal processing by filtering, using a filter circuit such as an RC (resistor and capacitor) filter, before being inputted to the A/D converter. However in recent years, there has been a substantial increase in the extent to which control of the engine and other equipment of a vehicle is performed by an ECU, with a corresponding increase in the number of analog signals that must be acquired and processed. If it is necessary to provide respective filter circuits for each of the analog signals then the scale and manufacturing cost of the ECU becomes substantially increased.
For that reason, it has been proposed in the prior art to omit these analog filter circuits, and to perform direct removal of noise from the digital signals produced by the A/D converter, i.e., by a digital noise removal method. Such methods are described for example in Japanese Patent Laid-open No. 11-62689 and Japanese Patent Nos. 2852059 and 2828106, which will be referred to in the following as reference 1, reference 2 and reference 3, respectively.
In the following, the term “control input data” refers to a series of digital values (i.e., control input values) that are derived based on A/D conversion and are used for control purposes, e.g., are supplied to a microcomputer which performs control operations of an ECU.
In the case of reference 1, the difference between the immediately preceding A/D converted value (i.e., digital value produced by an A/D converter) and the currently derived A/D converted value is obtained as the currently derived difference value DIF1. If DIF1 does not exceed the immediately precedingly derived difference value DIF0 by more than a predetermined amount, then DIF1 is used as the currently derived control input value. If DIF1 exceeds DIF0 by more than the predetermined amount, then this is taken to indicate that the magnitude of DIF1 has resulted from noise, and is not to be used as the currently derived control input value. Instead, the immediately precedingly derived difference value DIFO is outputted in place of DIF1.
In the case of reference 2, instead of the usual manner of sampling the input analog signal once in each of successive time intervals, to perform successive A/D conversions, a set of two or more samples is derived once in each of successive time intervals, so that successive sets of A/D converted values are obtained. Within each set, the number of values and the period between deriving successive values are determined such as to attempt to ensure that there will be only a low probability that more than one A/D converted value within the set will be affected by noise. That is to say, there should be only a low probability that two or more successive noise peaks or bursts contained in the input analog signal will occur within the duration of one of these sets of A/D converted values. The values in each set are mutually compared, and if one of these is excessively different from the other values in the set, then it is judged to be a result of noise, and is discarded. The currently derived control input value is then obtained as the average of the remaining values in that set. If none of the values in a set is excessively different from the others, then the average of the values in the set is obtained, as the currently derived control input value.
In the case of reference 3, each of a plurality of successively obtained A/D converted values is compared with a previously derived control input value, and the A/D converted value for which the smallest amount of difference is obtained is utilized as the currently derived control input value.
However each of the techniques of references 1 to 3 have disadvantages. Firstly in the case of reference 1, it is difficult to establish a suitable value for the aforementioned predetermined amount that is used as a basis for comparison. If that amount is made excessively large, then noise will not be accurately detected, while conversely if the amount is too small, then sudden changes in the input analog signal will be erroneously detected as noise.
In the case of reference 2, it is necessary to ensure that there is no more than one abnormal value (i.e., which has been affected by noise) within each of the aforementioned sets of A/D converted values. Hence it is difficult to apply such a method to a system in which input analog signals having various different noise characteristics must be processed.
For example as illustrated in
In the case of reference 3,
It is an objective of the present invention to overcome the above problems of the prior art, by providing an A/D conversion processing apparatus whereby the effects of noise in an input analog signal are substantially eliminated from a series of digital values representing that signal.
According to a first aspect, the invention provides an A/D conversion processing apparatus whereby an A/D converter means operates on an analog signal to obtain A/D converted values expressing voltage values of the analog signal, to be used in control operations by an external apparatus (in general, a microcomputer). After a first set of m digital values produced from the A/D converter means (m being an integer of value 3 or more) have been stored in converted data memory means, then each time that the contents of the converted data memory means are updated, a data detection means detects a specific-rank value within the set of m digital values (i.e., having a specific rank with respect to magnitude, when the m values are arranged in order of magnitude). Each specific-rank value is detected as a digital value that is intermediate between a largest magnitude and a smallest magnitude of the set of m values, with the specific-rank values being successively stored in final result memory means, as respective final result values. All or part of the successively derived final result values are used as respective control input values, in the aforementioned control operations.
In the following, such “final result values” will be generally referred to simply as “final values”, for brevity of description.
It can thereby be ensured that each digital value that is stored as a final value has not been made excessively large or excessively small as a result of electrical noise contained in the analog signal, so that such noise can be prevented from affecting the aforementioned control operations, e.g., control operations performed by a microcomputer.
Problems of the prior art can thereby be avoided, such as those which occur when exclusion of noise from the digital values produced from an A/D converter is based upon using a predetermined amount as a basis for comparison of respective digital values, as in the case of reference 1 above. Furthermore the prior art problems of references 2 and 3 described hereinabove are also avoided, i.e., whereby an A/D converted value that is selected as a final value, to be used as control input value, may be affected by A/D converted values that are excessively large or excessively small as a result of noise contained in the analog signal and which are closely adjacent to that final value along the time axis.
Moreover, with the present invention, even if there are very large-scale variations in magnitude of the input analog signal, which would be difficult or impossible to eliminate by transferring the analog signal through an analog filter circuit such as a low-pass filter prior to performing A/D conversion, the effects of such large-scale variations can be effectively excluded from affecting the final values that are to be utilized for control purposes.
If the aforementioned value m is made an odd number, then each specific-rank value can be selected as being the median value (with respect to amplitude) of the most recently derived set of m successive A/D converted values of the analog signal.
In some special cases, such as when the analog signal contains greater amounts of noise when it attains a large amplitude, it may be preferable to select a one of the set of m A/D converted values that is smaller than the median value. However, in general, it is preferable to select each specific-rank value as the median value, since this provides optimum results for analog signals which may have various different forms of noise characteristics.
From another aspect, such an A/D conversion processing apparatus can be configured such that instead of the specific-rank values being successively stored in the second memory means, to be used as control input data, the data processing means performs smoothing processing of the specific-rank values, to reduce variations in magnitude between successive ones of these values, with the result values obtained from the smoothing processing being stored in the final result memory means as the final values. The smoothing processing may consist for example of factor-based averaging (as described hereinafter) or moving-average processing, etc.
This enables noise contained in the analog signal to be even more effectively excluded from affecting the final values.
From another aspect, if the aforementioned value m is made an even-numbered integer of 4 or greater, the data detection means can be configured to detect a plurality of digital values from among each set of m digital values, such that each of the plurality of digital values is neither the largest in magnitude nor the smallest in magnitude of the m values. With m being an even number, none of the digital values can be a median value, and so in that case, the average of each such plurality of digital values can be calculated, with the result values obtained from the averaging being stored in the second memory means as the final values that are used for control purposes. In general, it is preferable to select the plurality of digital values such that each is close to being midway between the largest and smallest of the set of m digital values, since this provides optimum results for analog signals which may have various different forms of noise characteristics.
Alternatively, when m is an even-numbered integer, the data detection means can be configured to detect the (m/2)-th and the {(m/2)+1)-th values (i.e., counting from the largest value, or from the smallest value) in each set of m digital values, and obtain the average of these two values to thereby obtain a final value.
As a further alternative, a sub-set of values are selected (from within the set of m digital values) that successively increase in magnitude, and that include the aforementioned (m/2)-th and the {(m/2)+1)-th ranked values, and the average of that sub-set is then calculated, to be stored as a final value.
Furthermore if m is made an odd-numbered value, then the data detection means can similarly be configured to select a sub-set of the set of m digital values, i.e., a plurality of values that are of successively increasing magnitude, that include the median value of the m digital values. The average of each such plurality of digital values is calculated, to be stored as a final value.
In each of the above cases, digital smoothing processing can be applied to the successive average values that are derived as described above, with the result values obtained from the smoothing processing being stored as the final values.
Especially in the case of an apparatus that is used in a motor vehicle, the noise that is present in an analog signal which is supplied to the apparatus may vary periodically, such as noise which is generated by the ignition system of a vehicle and which therefore occurs with a repetition period that varies in accordance with the speed of the vehicle engine. As a result, the timings of noise occurrences in the analog signal may become synchronized with the timings of A/D conversions performed on the analog signal, if such timings occur with a fixed period, as is usual in the prior art. Hence, the digital value produced by the A/D conversion operations will become strongly affected by the noise.
According to another aspect of the present invention, to overcome the above problem, the aforementioned A/D conversion means of the A/D conversion processing apparatus performs A/D conversions of the analog signal with a conversion period (i.e., interval between successive A/D conversions of that analog signal) that varies in duration. The probability of the A/D converted values becoming affected by periodically occurring noise in the analog signal is thereby made extremely small, so that the effectiveness of noise exclusion is substantially enhanced.
The A/D conversion period can be varied randomly, i.e., based on random number generating being performed prior to each A/D conversion of that analog signal, or can have a variation sequence that recurs cyclically.
When a plurality of analog signals are sequentially subjected to A/D conversion, with each sequence of conversions beginning at successive periodic time points, then the A/D conversion period of each of these signals can be varied by altering the sequence of conversions, prior to each of the periodic time points. This can be performed by selecting one of a plurality of possible sequences (i.e., with the number of that plurality being determined by the number of analog signals) prior to each of the periodic time points, with that selection being randomly determined, or performed with a fixed sequence that cyclically recurs.
From another aspect, an A/D conversion processing apparatus according to the present invention can be provided with data communication means for communicating with a control apparatus, with that control apparatus generally being a microcomputer. The control apparatus receives successive sets of one or more final values (i.e., as control input values) transmitted from the A/D conversion processing apparatus, for each of one or more analog signals, and performs control of a control object such as a vehicle engine based on the received values.
In that case, each of the means of the A/D conversion processing apparatus other than the communication means can operate at timings that are independent of operation timings of the control apparatus. In addition, the control apparatus can transmit a data acquisition request to the A/D conversion processing apparatus, with the A/D conversion processing apparatus responding by transmitting to the control apparatus a most recently derived set of the final values that have been stored in the final result memory means.
In that way, although the contents of the final result memory means are updated at timings that are independent of the timings of data communication between the A/D conversion processing apparatus and the control apparatus, it can be ensured that a most recently derived set of final values will be transmitted to the control apparatus each time such data communication is performed.
Alternatively, it can be arranged that the A/D conversion processing apparatus communicates with the control apparatus at successive timings occurring at fixed periodic intervals, and that all sections of the A/D conversion processing apparatus other than the communication means repetitively begin to operate at successive timings that each precede (by a fixedly predetermined interval) a corresponding one of the timings of communication with the control apparatus, so that a final value (or set of final values respectively derived for a plurality of analog signals) is obtained and stored in the final result memory means immediately prior to beginning of each communication. During each communication, the A/D conversion processing apparatus transmits the most recently stored final value(s) to the control apparatus.
In that case, the rate of performing A/D conversions can be substantially reduced, so that the power consumption of the electronic control apparatus can be correspondingly reduced.
The duration of the aforementioned fixedly predetermined interval is preferably made as short as possible, but longer than the time required to derive a final value and to update the contents of the final result memory means accordingly.
From another aspect, the invention provides an A/D conversion processing apparatus having a plurality of input terminals, each coupled to a corresponding one of a plurality of analog signals, and multiplexing means for successively selecting the analog signals for A/D conversion. In a first sub-set of these input terminals (comprising at least one terminal) each terminal is coupled to a corresponding filter circuit through which the corresponding analog signal is transferred to that input terminal, for reducing electrical noise that may be contained in the analog signal. In a second sub-set of the input terminals (comprising at lest one terminal) each analog signals is applied directly to the corresponding terminal.
In the case of each analog signal that is coupled to one of the second set of input terminals, the operations described hereinabove are performed by the converted data memory means and the data detection means, etc., are applied the A/D converted values obtained for that analog signal, to thereby obtain successive final values expressing that analog signal. In the case of each analog signal that is coupled via a filter circuit to one of the first set of input terminals, at least the operations performed by the data detection means are omitted from being applied to the A/D converted values obtained for that analog signal, when deriving successive final values expressing that analog signal.
In that way, it becomes possible to apply an appropriate form of noise removal processing to each analog signal in accordance with the particular characteristics of that signal.
Specifically, it is preferably arranged that each analog signal which is coupled via a filter to one of the first set of input terminals is selected as being a signal which varies substantially abruptly, i.e., that has a maximum rate of change of amplitude that is relatively high (such as a signal of an engine cylinder pressure sensor), while each analog signal that is coupled to one of the second set of input terminals is selected as being a signal which only varies relatively gradually, i.e., having a maximum rate of change of amplitude that is relatively small (such as a signal of an engine coolant temperature sensor), by comparison with the analog signals that are coupled to the first set of input terminals.
By omitting to apply digital noise processing such as derivation of median values as described above, for an analog signal which exhibits abrupt variations in amplitude, and instead using an analog filter circuit having characteristics which are appropriate, it can be ensured that the noise removal processing will not result in valid portions of the analog signal being erroneously rejected as noise. However in the case of an analog signal which varies only gradually, sufficiently effective noise removal can be achieved by digital processing (in particular, selection of median values as described hereinabove), without the danger of erroneous rejection of valid signal values, and without requiring the use of an analog filter circuit, so that the total number of analog filter circuits can be minimized.
Furthermore with such an A/D conversion processing apparatus having both input terminals whereby each input analog signal is directly supplied to the A/D conversion means and also input terminals whereby each input analog signal is transferred via a filter circuit to the A/D conversion means, an analog signal whose variations are not synchronized with any timebase (for example, a signal which detects when an engine crankshaft attains a specific angular position) can be advantageously applied via a filter circuit to one of the first set of input terminals.
With such an A/D conversion processing apparatus, when an input analog signal is produced based on voltage division of a power supply voltage of the A/D conversion means, it is preferable that such an analog signal is directly supplied to one of the second set of input terminals, without utilizing a filter circuit. The reason for this is as follows. Such a filter circuit generally includes one or more capacitors that are connected between the signal line of the input analog signal and circuit ground potential. If abrupt changes in level of the power supply voltage occur (e.g., due to noise in that voltage), then these changes will be absorbed by the capacitor of the filter circuit, so that no corresponding changes in the input analog signal will occur. Hence, the proportional relationship of the voltage division will not be maintained, so that accurate A/D conversion cannot be achieved.
From another aspect, an A/D conversion processing apparatus according to the present invention may include data register means, for use as a register for storing respective values for the aforementioned number m, etc. That is to say, that number m, and the duration of the interval between successive A/D conversions, are made respective variable quantities, whose values are supplied from an external source, and stored in the data register means. In the following description and in the appended claims, a “variable quantity” will be referred to simply as a “variable”, for brevity of description.
In that way, various different values for these variables can readily be arbitrarily set (e.g., by being transmitted to the A/D conversion processing apparatus from a control apparatus that performs control operations based on the aforementioned final values). Hence, an ECU formed by combining such an A/D conversion processing apparatus with a control apparatus such as a microcomputer can be used in a wide variety of different applications.
For example it can be arranged that the control apparatus supplies initial values for the variables to the A/D conversion processing apparatus (to be respectively stored in the data register means) when operation of the ECU is started. In addition, it becomes possible for the control apparatus to update the values of these variables in accordance with the current condition of the control object (e.g., a vehicle engine), on one or more occasions after operation of the ECU has started, so that flexibility of operation can be achieved.
Furthermore such an ECU can be configured such that the control apparatus obtains from the A/D conversion processing apparatus (on one or more occasions after the initial values have been supplied by the control apparatus) the respective values for the variables that are currently held stored in the aforementioned data register means of the A/D conversion processing apparatus. When that is done, the control apparatus compares these values for the variables with the corresponding values that were originally transmitted from the control apparatus (more specifically, the most recently transmitted values for the variables). The control apparatus can thereby determine whether the values for the variables that are held in the A/D conversion processing apparatus have become altered, e.g., due to the effects of electrical noise.
The control apparatus is configured such as to delete the set of final values most recently obtained from the A/D conversion processing apparatus, when it is judged that any of a received set of values for the variables does not match the corresponding originally transmitted value. It can thereby be ensured that any erroneous final values that have been derived based upon incorrect values for one or more of the variables will not have an effect upon the control operation performed by the control apparatus.
From another aspect, in the case of an A/D conversion processing apparatus as described hereinabove which has a first set of input terminals whereby each input analog signal applied thereto is transferred via a filter circuit to the A/D conversion means, and a second set of input terminals whereby each input analog signal that is applied thereto is directly supplied to the A/D conversion means, with digital noise exclusion processing (e.g., selection of respective median values from successive set of m A/D converted values) being applied only to the A/D converted values derived for each analog signal that is applied to one of the second set of input terminals, such an A/D conversion processing apparatus can be advantageously applied to a type of analog signal that consists of background level intervals and abrupt variation intervals, i.e., an analog signal that varies only gradually within the background level intervals and has sudden changes in amplitude during the abrupt variation intervals. An example of such a signal is the air/fuel ratio sensor signal of a vehicle engine.
Specifically, such an analog signal to the A/D can be coupled via a filter circuit to one of the first set of input terminals and also be directly connected to one of the second set of input terminals. The A/D conversion processing apparatus operates such that during each background level interval, A/D conversion is applied to the analog signal transferred through the second set of input terminals, so that the resultant A/D converted values are subjected to digital noise exclusion processing (i.e., using the converted data memory means, data detection means, the data processing means and final result memory means as described above) to obtain and store successive final values representing the analog signal during the background level intervals. During each abrupt variation interval, the analog signal transferred via the first set of input terminals (i.e., which has been passed through an analog filter circuit) is subjected to A/D conversion, and the resultant digital values are directly stored as final values, without being subjected to digital noise reduction processing (or at least, are not subjected to processing to select median values).
In that way, such an analog signal can be processed through two different A/D conversion channels, such as to make it possible to achieve optimum noise reduction processing for both the abrupt variation intervals and the background level intervals of the signal.
Embodiments of an electronic control apparatus will be described in the following, each being an engine ECU (electronic control unit) of a motor vehicle.
The input IC 5 includes an A/D converter 7, a multiplexer 9 which cyclically selects the input analog signals, to supply these to the A/D converter 7, a communication section 11 for performing serial data communication with the microcomputer 3, and a processing section 13 which controls the multiplexer 9 and the A/D converter 7 and processes the A/D converted values that are produced from the A/D converter 7 to effect noise elimination as described hereinafter, with resultant digital values being supplied to the communication section 11 to be transferred to the microcomputer 3.
The processing section 13 includes a RAM (random access memory) 15, having three memory regions that are respectively designated as the converted data memory region 15a, the sorting processing-use memory region 15b and the final result memory region 15c. The converted data memory region 15a is formed of six memory regions, respectively reserved for A/D converted values of the six input analog signals. Each of these six regions within the converted data memory region 15a serves to store a plurality of digitized values, which are the most recently obtained set of A/D converted values that have been derived by the A/D converter 7 (i.e., extending up to the currently derived value) by operating on the corresponding one of the six input analog signals. In the following description, it will be assumed that each of these sets consists of three successively derived A/D converted values of an input analog signal, extending up to the most recently derived value.
The sorting processing-use memory region 15b is utilized in sorting processing that is applied to each of the sets of A/D converted values held in the converted data memory region 15a, to arrange each set in order of magnitude of its values so that a median value of that set can be selected. The final result memory region 15c serves to temporarily store each of the most recently derived final values (i.e., respectively corresponding to the six input analog signals) that have been obtained by processing the median values, before the final values are transferred to the microcomputer 3.
The sensors which produce the input analog signals may include for example an air intake rate sensor, a throttle opening sensor, an engine coolant temperature sensor, etc. Such sensors can be broadly divided into two basic types, i.e.,
As shown in
VD is also supplied as the power supply voltage of the microcomputer 3 and the input IC 5, to operate the A/D converter 7, the multiplexer 9, the communication section 11 and the processing section 13.
In the case of each SNb sensor, the output terminal of the sensor is connected to a corresponding signal line within the ECU 1 as shown, which is connected to a corresponding input buffer 9a of the multiplexer 9, and is also connected via a resistor Rd to ground potential and connected to the cathode of a surge protection diode Dd within the input IC 5, with the diode anode being connected to ground potential. The resistor Rd serves to ensure that the input of the corresponding buffer 9a will be fixed at ground potential in the event that an open circuit occurs in the connecting lead between a SNb sensor and the ECU 1. The value of each resistor Rd is preferably selected to be substantially high, e.g., several hundred KΩ, so as not to have an effect upon normal operation.
Although not shown in the drawing, the microcomputer 3 also receives various digital signals such as output signals from a crank angle sensor, an engine speed sensor, etc., and applies various processing to these signals in conjunction with processing of the A/D converted signals supplied from the input IC 5, with the results of such processing being used to control the vehicle engine operation, e.g., fuel injection amounts, ignition timings, etc.
The ECU 1 of this embodiment does not include any filter circuits (e.g., CR circuits) coupled to the input analog signals of the input IC 5 for noise removal, with only digital removal of noise being performed upon the A/D converted signals as described hereinafter.
The operation of the input IC 5 will be described in the following. The multiplexer 9 periodically selects successive ones of the input analog signals to be subjected to A/D conversion by the A/D converter 7, in a predetermined sequence. For simplicity of description, only the operations performed on one of these input analog signals will be described.
Each time a new A/D converted value is derived, then the median value of that value and the two immediately precedingly derived A/D converted values (i.e., the one of these three digital values that is centrally located, when the three are arranged in order of magnitude) is detected by the processing section 13 of the input IC 5. The successive median values that are thereby obtained are shown in
As each new median value is derived, it is used in a digital smoothing calculation referred to in the following as factor-based averaging processing, with the digital value that is thereby obtained being stored as a final result in the region of the final result memory region 15c corresponding to the input analog signal, in the RAM 15.
In the example of
Similarly, the frame W2 encloses three values having the relationship AD1<AD3<AD2, so that when AD2 is derived, AD3 is detected as the median value, indicated as the value x in
The factor-based averaging processing is performed as follows. In general, designating a currently derived median value as Vm, the most recent value obtained by factor-based averaging processing as Vn−1 (i.e., which utilized the immediately precedingly derived median value), and N as a factor that is a fixed plural integer, Vm is used to obtain a new value Vn by factor-based averaging processing as:
Vn=((N−1)·Vn−1+Vm)/N (1)
Such processing will be referred to as 1/N factor-based averaging.
It will be assumed that with this embodiment, the value of N is 2, (i.e., ½ factor-based averaging) so that:
Vn=Vn−1+Vm/2 (2)
In the following, a value Vn that is obtained by the above factor-based averaging processing will be referred to simply as a factor-averaged value.
The effects of factor-based averaging processing are made clearly apparent from the diagrams of
However as shown in
In the above it is assumed that each median value is obtained from three successive A/D converted values. However it would be equally possible to derive each median value from each set of five successive A/D converted values, or from every seven A/D converted values. The greater the number of A/D converted values from which each median value is selected, the more effective will be the noise elimination effect, and this is also true if the value of N in equation (1) above is increased beyond 2. Such increases have an effect that is analogous to increasing the time constant of a low-pass analog filter.
The operation of the input IC 5 will be described in more detail, referring to
(n+1) is equal to the number of successive values from which each median value is selected, as described hereinabove.
In step S120, ADNEW is stored in the one of the addresses ADRAM0 to ADRAMn that contains the oldest value (i.e., to replace that oldest value). The sorting processing-use memory region 15b has six sets of (n+1) addresses, with these sets respectively corresponding to the six input analog signals. The set corresponding to the analog signal under consideration will be designated as STRAM0 to STRAMn.
In step S130, the values held in the addresses ADRAM0 to ADRAMn of the converted data memory region 15a are copied into the addresses STRAM0 to STRAMn respectively of the sorting processing-use memory region 15b, and a plurality of sorting processing operations are then performed to arrange the values held in addresses STRAM0 to STRAMn respectively in order of successively increasing magnitude, so that the median value becomes stored in the address STRAM(n/2). A total of (n/2+1) sorting processing operations are successively performed to achieve this.
Next, in step S140 the value held in STRAM(n/2) is read out, as the currently derived median value, and in step S150 the factor-based averaging processing is applied to that value. In step S160, the value obtained from the factor-based averaging processing is stored in the final result memory region 15c, as a final value, to be used by the microcomputer 3 in engine control. The processing of
It will be assumed that n is equal to 4, i.e., that the five most recently derived A/D converted values are stored in the converted data memory region 15a and the median value of these five values is derived. In that case, as illustrated in the example of
Specifically, in the first of three stages of the sorting processing, all possible pairings of the values AD2˜ADS are examined, to find the smallest of these, leaving ADS, AD6, AD3, AD4, AD2 respectively stored in the addresses STRAM0˜STRAM4. In a second stage, the remaining values AD3, AD4, ADS, AD6 are similarly examined, to find the second-smallest of the values AD2˜AD5. This leaves the values AD5, AD3, AD4, AD6, AD2 respectively stored in the addresses STRAM0˜STRAM4, i.e., with the second-smallest value being AD6. In the third stage, the third-smallest of the values AD2˜AD5 (i.e. the median value of these) is similarly determined. Execution of the third sorting stage leaves the values AD3, AD4, ADS, AD6, AD2 respectively stored in the addresses STRAM0˜STRAM4 as shown in
It can thus be understood that with this example, in which n=4, a total of 9 sorting operations, i.e., (4+3+2) are required to find a median value. If the value of n were 6, then a total of 18 (6+5+4+3) sorting operations would be required.
In step S140 of
In
In this case, the input IC 5, the A/D converter 7, multiplexer 9 and processing section 13 each operate independently of the timings at which communication with the microcomputer 3 are performed. When a data request is received by the processing section 13 from the microcomputer 3 via the communication section 11, the processing section 13 responds by transmitting to the microcomputer 3 (via the communication section 11) the most recent final values that have been derived for each of the input analog signals and stored in the final result memory region 15c as described hereinabove.
In that way, up-to-date digital data accurately representing the input analog signals supplied to the input IC 5 are transmitted to the microcomputer 3 as control input data for use in engine control, with the effects of noise in the input analog signals having been substantially eliminated so that such noise (i.e., appearing as digital values that are of much greater magnitude than adjacent values) will not affect the engine control operation, and that this is achieved without applying filtering to the analog signals.
It should be noted that with the above embodiment, noise elimination is achieved without requiring to perform any special type of judgement to distinguish between noise and a valid signal. That is to say, judgment is performed to find the median value of a most recently derived set of A/D converted values, so that the results are not affected by the particular characteristics of the noise.
The effects of delays upon the operation of the above embodiment will be discussed in the following. It will be assumed that the input IC 5 performs A/D conversion of the input analog signals once every 250 μs, and that n is equal to 4, i.e., that each median value is detected from the most recently obtained five successive A/D converted values of an input analog signal. In that case, as illustrated in the diagram of
Next, as shown in
In the case of a prior art system in which an analog filter (in general, an RC filter) is connected to each input analog signal line, the time constant τ of a filter will generally be set as approximately 1 ms (for example, using an RC filter formed of a 1 μF capacitor and 10 KΩ resistor). Taking into account the temperature characteristics of the capacitor and the resistor and the effects of manufacturing tolerances upon the values of the capacitor and resistor, the delay will actually be approximately 1±0.3 ms.
Hence, the delay of approximately 1.2 ms that could be expected with the first embodiment is of the same order as that of a conventional analog filter circuit. Even if the input signal varies substantially, as in the example of
As mentioned hereinabove, a similar effect to increasing the time constant of an analog low-pass filter circuit can be achieved by increasing the number of successive A/D converted values from which each median value is detected (i.e., 3, 5, 7, etc.). Such “time constant” changes can also be achieved by altering the interval between successive A/D conversions, or the factor N of the factor-based averaging.
A second embodiment of an ECU will be described in the following. Since the hardware configuration of this embodiment can be identical to that of the first embodiment, only points of difference between the ECUs of the first and second embodiments will be described in detail, and components of the second embodiment having functions corresponding to those of the first embodiment will be designated by corresponding reference numerals to those of the first embodiment. The above is also true of other embodiments described hereinafter, unless otherwise indicated.
It will further be assumed that with the second embodiment, the interval between successive A/D conversions of an input analog signal is 250 μs and the value of n is 4. In the same way as for the first embodiment, only the processing applied to a single input analog signal will be described, unless otherwise indicated.
At the start of each interval of data communication with the microcomputer 3, the processing section 13 of the input IC 5 transmits each of the most recently derived final values obtained for each of the input analog signals, held in the final result memory region 15c at that time, to the microcomputer 3 via the communication section 11. It can be understood that with the example of
It can thus be understood that whereas with the first embodiment (for each of the input analog signals) a plurality of A/D conversions, with corresponding median value detection and factor-based averaging processing operations to obtain successive updated final values, are performed prior to each interval of data communication with the microcomputer 3, with the second embodiment only a single final value is derived prior to each interval of data communication with the microcomputer 3. However that final value is derived and stored in the final result memory region 15c at a time which occurs only 0.5 ms before the start of a communication operation whereby that final value is transferred to the microcomputer 3. Hence, each time the microcomputer 3 receives a digital value of an analog signal, there is a minimum delay between the time of receiving that digital value and the time at which that value actually represented the level of the corresponding analog signal.
Moreover this is achieved while reducing the number of A/D conversion operations, so that the power required to operate the input IC 5 can be reduced.
With the second embodiment as described above, the timings of A/D conversion operations are linked to the timings of intervals of communication between the microcomputer 3 and input IC 5. However as an alternative form of the second embodiment, it would be possible for the input IC 5 to independently determined the timings at which the A/D conversions are to be performed. As a further alternative, it could be arranged that the microcomputer 3 transmits commands to the input IC 5 for designating each time point at which a set of A/D conversions (for use in deriving an updated set of final values for the respective input analog signals) are to be started.
A third embodiment will be described in the following. In the same way as for the preceding embodiments, the description will be based on processing of a single input analog signal. The ECU 1 of this embodiment differs from that of the first embodiment in that the sorting processing-use memory region 15b of the RAM 15 is omitted. Furthermore, instead of the processing of
Specifically, following the start of operation of the ECU 1, when a total of (n+1) digital values resulting from successive A/D conversions have become stored in the addresses ADRAM0˜ADRAMn of the converted data memory region 15a, these values are then arranged in order of magnitude in respective ones of the addresses ADRAM0˜ADRAMn, such that the largest value is held in ADRAM0. When that has first been completed, the processing sequence of
In a first step S210 of the processing of
Next, in step S230, the A/D converted values held in ADRAM0˜ADRAMn are subjected to sorting processing to determine the smallest of these values, which is then written into the address ADRAMn. This is achieved by a single-stage sorting processing operation.
In the next step S240, the A/D converted value that is held in the median address of ADRAM0˜ADRAMn, i.e., address ADRAM(n/2), is read out as the median value of the most recently derived (n+1) A/D converted values. In step S250, factor-based averaging processing is applied to that median value. In step S260, the value obtained from the factor-based averaging processing is stored in the final result memory region 15c, as a final value, to be used by the microcomputer 3 in engine control. The processing of
In the example of
In addition, the currently derived A/D converted value AD6 is written into ADRAM0, to overwrite the previous contents.
Furthermore with this example, in step S230 of
Next, in step S240 of
It can thus be understood that with the third embodiment, it is necessary to perform processing in step S220 of
For example if n=4, it is necessary to perform such sorting operations a maximum of 9 times to determine the median value, in step S130 of
In the case of an apparatus used in a motor vehicle, bursts or peaks of electrical noise may occur repetitively, with a regular period, at certain times. That is to say, if the engine speed remains stable for some time, then electrical noise that is generated by the ignition operations and fuel injection operations for the engine cylinders will occur with a regular period, which is determined by the engine speed. If an input analog signal is subjected to successive A/D conversion operations with a fixed repetition period, then it is possible that when the engine attains a certain speed, the timings of the A/D conversion operations will become synchronized with the noise occurrences.
A specific example will be described referring to the timing diagram of
When such synchronization occurs, one or more A/D converted values that have abnormal magnitudes due to the effects of noise, may become selected as median values, and so can result in abnormal final values being derived and supplied by the input IC 5 to the microcomputer 3, thereby affecting the engine control operation.
For that reason, each of the above embodiments is preferably configured such that A/D conversions of each input analog signal are performed without the repetition period of these conversions being fixed. The possibility that the final values produced by the input IC 5 will be affected by noise can thereby be made extremely small.
The present invention provides two alternative methods whereby this can be achieved, which can be applied to all of the embodiments of the invention described herein, and which will be referred to as noise countermeasure (a) and noise countermeasure (b), respectively, as follows:
In this case, as illustrated in
It is assumed that there are three input analog signals, so that there are six possible different sequences in which these can be successively inputted to the A/D converter 7 in each of the 500 μs intervals between the time points t0, t1, t2, etc., with these sequences being indicated at the lower part of
In this case, the processing section 13 is configured to generate a random number each time that sequential A/D conversions of the input analog signals have been completed, i.e., prior to each of the time points t0, t1, t2, etc., in
With either of the above methods, it can be ensured that the effects of periodically occurring noise contained in an input analog signal will be distributed with respect to the A/D conversion timings of that signal, such as to substantially eliminate the possibility of synchronization of the noise occurrences with the A/D conversion timings. The greater the number of input analog signal channels, the greater will be the effectiveness of distributing the effects of the noise, i.e., the lower will become the possibility that abnormal digital values resulting from noise will become selected as median values by the input IC 5, and so will affect the control operation of the microcomputer 3.
Various alternative forms of the above embodiments can be envisaged, as described in the following.
With each of the above embodiments, it would be possible to omit the factor-based averaging processing of step 150 and proceed directly from step S140 to S160 in
In that case, although factor-based averaging is not applied to the median values which are derived and supplied to the microcomputer 3 for use in engine control, there is a substantially reduced possibility that A/D converted values which deviate significantly from adjacent values (due to noise in the input analog signals) will be selected as median values, as described hereinabove with respect to
With the first embodiment described above, each median value is selected from an odd-numbered set of successive A/D converted values. However the processing shown in
Hence with such an alternative configuration, similar results can be obtained to those of the first embodiment described above. It will be apparent that the processing of
This is a modification of the alternative form 2 described above. With the alternative form 3, the factor-based averaging processing of step S150 in
A fourth embodiment will be described, referring first to
The ECU 100 of this embodiment includes an input IC 50, a microcomputer 3, and resistors Ru, Rd having the functions described for the first embodiment, as well as filter circuits connected in the signal lines of channels ch7 to ch9.
With the input IC 50 of this embodiment, various parameters used in processing operations can be preset separately for each of the channels ch0, ch1, . . . , ch9. These include, for example, determining whether or not median values will be derived (i.e., whether processing corresponding to steps S130 to S140 of
As shown in
The processing section 130 includes a RAM 15 and a data register 17. The data register 17 serves to hold sets of preset values that determine the presettable conditions described above, with these sets respectively corresponding to the channels ch0, ch1, . . . , ch9. The RAM 15 shown in
In each of the sets of preset values corresponding to the respective channels, held in the data register 17, SEL denotes a variable whose value determines whether median value calculation processing is to be performed for the corresponding channel, and if that processing is to be performed, the number of A/D converted values from which each median value is to be selected. Each set also includes a variable Tmg, whose value determines the period between successive A/D conversions, for the corresponding channel. Each set also includes a variable Nms, whose value determines whether or not factor-based averaging is to be performed, and, if it is to be performed, the value of N in equation (1) above.
SEL is predetermined as an odd-numbered positive integer, whose value determines whether or not median value calculation is to be performed for the corresponding channel, and, if it is to be performed, the number of A/D converted values from which each median value is to be selected. If for example SEL equals 3, this signifies that median value calculation processing is to be performed, with each median value selected from three successive A/D converted values. If SEL equals 1, then this signifies that median value calculation processing is not to be performed for the corresponding channel.
A value of A/D conversion period is expressed by Tmg as (128×2Tmg) μS. Thus for example if Tmg equals 0, then the A/D conversion period for the corresponding channel is to be 128 μS, while if Tmg equals 2, then the A/D conversion period is 512 μS.
The value preset for Nms determines whether or not factor-based averaging is to be applied to digital values derived for the corresponding channel, and, if it is to be applied, the value for the factor N. If for example Nms equals 4, then a value of 4 is used as N in equation (2), i.e., ¼ factor-based averaging processing is applied to median values that are derived for the corresponding channel, while if Nms equals 1 then this signifies that factor-based averaging is not to be applied to median values that are derived for the corresponding channel.
It will be assumed that a value of 5 is set for SEL, for each of the channels ch0 and ch1, thereby specifying that each median value will be selected from five successive A/D converted values. It will further be assumed that a value of 3 is set as SEL, for channel ch2, so that each median value will be selected from three successive A/D converted values. It will also be assumed that an odd-numbered value other than 1 is set as SEL, for each of the channels ch3 to ch6, while for each of the channels ch7 to ch9, SEL is set as 1 (signifying that median value calculation processing is not to be applied to these channels).
In addition, Nms is set as 2 for channel ch0, is set as 4 for each of the channels ch1, ch2, and is set as 1 for each of the channels ch7 to ch9 (so that factor-based averaging is not applied to channels ch7 to ch9).
Tmg is set as 1 for channel ch0 (designating an A/D conversion period of 256 μS), while Tmg is set as 2 for each of channels ch1, ch2 (designating an A/D conversion period of 512 μS), and Tmg is set as 5 for each of channels ch7 to ch9 (designating an A/D conversion period of 4096 μS).
With this embodiment, respective (analog) low-pass filters each formed of a resistor Rf and capacitor Cf are connected to the input signal lines of channels ch7 to ch9, i.e., the channels for which median value calculation processing is not performed. It can thereby be ensured that noise filtering is applied to the analog signals of these channels, while also ensuring that corresponding derived digital values that are supplied to the microcomputer 3 can accurately follow rapid changes in level of these analog signals. These analog signals of channels ch7 to ch9 are of the second type described hereinabove, which exhibit sudden changes in level, such as signals produced by internal pressure sensors of the engine cylinders, anti-knock sensors, etc., or signals that are not synchronized to a timebase, such as a sensor signal that varies each time a specific crankshaft angle is attained by the engine, etc.
Each of the channels ch0 to ch6, for which median value processing is performed, is not provided with such an analog low-pass filter circuit, and conveys an analog signal that is of the first type described hereinabove, i.e., a signal that changes in level only relatively gradually, such as a cooling water temperature sensor signal, an oil temperature sensor signal, an air intake temperature sensor signal, or a signal that is produced by voltage division of the supply voltage VD of the ECU 100 by a resistive voltage divider formed of the internal resistance of a corresponding sensor Sna and an internal resistor Ru within the ECU 100.
The processing section 130 of the input IC 50 of this embodiment controls the multiplexer 9 such as to perform changeover of A/D conversion operations for each channel at timings determined by the value of Tmg for that channel, and stores each resultant A/D converted value produced from the A/D converter 7 in a region of the converted data memory region 15a that is reserved for that channel, as illustrated in
If a value other than 1 has been set as SEL for a channel, then the processing section 130 stores a number of successively produced A/D converted values (in the aforementioned region of the converted data memory region 15a reserved for that channel) that is equal to the value of SEL. Thus for example if SEL for that channel is 5, then at any point in time, the five most recently produced A/D converted values for that channel are held in the corresponding region of the converted data memory region 15a. These are copied into the sorting processing-use memory region 15b, to be subjected time point sorting processing as described above for the first embodiment, to thereby obtain the median value of the most recent set of A/D converted values for that channel. The final result memory region 15c contains a plurality of regions respectively reserved for the channels, i.e., with the final values derived for a channel being successively stored in the corresponding region of the final result memory region 15c. Each time a median value is derived for a channel, it is subjected to factor-based averaging by the processing section 130 to obtain an updated final value, using a value for N that is determined by Nms for that channel, and being operated on in conjunction with the most recently derived final value for that channel (read out from the final result memory region 15c). However if the value of Nms for that channel is 1, then factor-based averaging is not performed, and each median value is stored directly, as a final value, in the region of the final result memory region 15c corresponding to that channel.
If the value of SEL specified for a channel is 1, then the processing section 130 stores each most recently derived A/D converted value in succession in the region of the converted data memory region 15a corresponding to that channel. Factor-based averaging processing is performed on each successive set of A/D converted values for a channel that are held in the converted data memory region 15a, using a value of N that is determined by Nms for that channel. Each result thereby obtained is stored in the region of the final result memory region 15c corresponding to that channel, as an updated final value.
However if the value of Nms for that channel is 1, then factor-based averaging processing is not performed, and each most recent A/D converted value obtained for that channel is transferred from the converted data memory region 15a directly to the region of the final result memory region 15c reserved for that channel, as an updated final value.
In the same way as for the first embodiment, the microcomputer 3 of this embodiment communicates with the input IC 50 at fixed periodic intervals, e.g., once every 4 ms, to send data acquisition requests. In response to such a request, the input IC 50 reads out, from each of the regions of the final result memory region 15c corresponding to the respective channels, the most recent final values that have been derived for the channels, and also the respective values that have been stored in the data register 17 for the variables SEL, Nms and Tmg for the various channels, and transmits all of these data to the microcomputer 3.
When the microcomputer 3 transmits a single-shot A/D conversion request (as defined and described hereinafter) to the input IC 50, at some arbitrary time point (i.e., an asynchronous timing, at which an A/D converted value from a specified channel becomes necessary), the processing section 130 performs processing whereby a single A/D conversion of the analog signal of the specified channel is performed, and the resultant A/D converted value is transmitted directly to the microcomputer 3.
It would be possible to fixedly stored respective preset values for the aforementioned variables Sel, Tmg, Nms in the processing section 130. However with this embodiment, these values are transmitted from the microcomputer 3 to the input IC 50, to be stored in the input IC 50, and so can be readily altered by operation of the microcomputer 3. In that way, the input IC 50 can be used as an ECU that is readily applicable to various different types of vehicle. In addition, the microcomputer 3 can update the values of one or more of these variables at any time, for any of the channels, to be appropriate for the current operation condition of the vehicle engine, so that highly accurate control can be achieved.
When the microcomputer 3 receives data sent from the input IC 50 in response to a data acquisition request as described above, it compares the values for SEL, Nms and Tmg for the various channels that are contained in the received data with respective values for these that are held stored at the microcomputer 3, i.e., which had been previously transmitted to the input IC 50 from the microcomputer 3 to be stored in the data register 17. The received values for SEL, Nms and Tmg for the various channels are thereby checked, so that the microcomputer 3 can detect when the values stored in the data register 17 have become altered, e.g., due to the effects of electrical noise. If one or more of the received values do not match the corresponding values for the variables that were previously transmitted from the microcomputer 3 to the input IC 50 to be stored in the data register 17, then all of the accompanying data (i.e., updated final values corresponding to the respective channels) are deleted, so that these will not be used by the microcomputer 3 for control purposes. The microcomputer 3 then transmits a reset signal to the input IC 5, whereby the operation of the input IC 5 is reset, and sets of values for the variables SEL, Nms and Tmg, for the various channels, are then transmitted by the microcomputer 3 to be stored in the data register 17 of the input IC 50.
The processing executed by the processing section 130 and the microcomputer 3 of this embodiment will be described in the following referring to the flow diagrams of FIGS. 15 to 17.
When power begins to be supplied to operate the input IC 50, or when a reset signal transmitted from the microcomputer 3 is received by the input IC 50, the processing section 130 performs initialization processing, to be thereby reset to a predetermined initial condition. In step S620 of the flow diagram of
In
In the following, the channel whose number corresponds to chdt, i.e., the one of the channels ch0, ch1, . . . , ch9 that is being operated on in the current execution of the processing of
In step S380 a decision is made as to whether or not Seldt is 1. If it is not 1, then since this signifies that median value calculation processing is to be performed for channel chdt, operation proceeds to step S390. As described for the first embodiment, the region of the converted data memory region 15a that is reserved for a channel serves to hold a set of the most recently derived A/D converted values for that channel, (in this case, the channel whose number corresponds to chdt, while the number of A/D converted values constituting the set is determined by Seldt). In step S390, the oldest one of that set of A/D converted values is replaced by the most recent value, i.e., ADNEW.
That is to say, the converted data memory region 15a contains a set of addresses, reserved for storing the most recent A/D converted values for channel chdt, with the number of these addresses being specified by Seldt. In the same way as for step S120 of
In step S400, in the same way as for steps S130, S140 of
Next in step S410, that median value is read out from the sorting processing-use memory region 15b and subjected to factor-based averaging in conjunction with the most recent final value that was obtained (i.e., by factor-based averaging) for channel chdt, with the latter final value being read out from the region of the final result memory region 15c that is reserved for channel chdt. The value for N that is used in the factor-based averaging calculation is Nmsdt. That is, the median value that is read out from the sorting processing-use memory region 15b is used as the “currently derived median value Vm”, while the final value that is read out from the final result memory region 15c is used as Vn−1, in equation (1) above.
Operation the proceeds to step S440, in which the result obtained in step S410 is stored, as an updated final value obtained for channel chdt, in the region of the final result memory region 15c reserved for that channel.
Although not explicitly shown in
On the other hand, if it is found that Seldt is 1, in step S380, then this indicates that median value calculation is not to be applied to channel chdt, and in that case, operation proceeds to step S420.
In step S420, ADNEW is written into the region of the converted data memory region 15a reserved for channel chdt, then in step S430 the value ADNEW is read out and subjected to factor-based averaging processing in conjunction with the most recent final value that had been derived for channel chdt, read out from the final result memory region 15c, with the factor N used in the factor-based averaging being the value of Nmsdt.
Hence in this case, in the calculation of equation (1), ADNEW constitutes the aforementioned “currently derived median value Vm”, Nmsdt is N, and “the most recent value obtained by factor-based averaging processing, Vn−1″ is the previously derived final value corresponding to channel chdt, read out from the final result memory region 15c.
Operation proceeds to step S440, in which the result obtained in step S430 is written into the region of the final result memory region 15c reserved for channel chdt, as an updated final value for that channel. However if it is found in step S430 that the value of Nmsdt is 1, then this indicates that a value 1 is to be used for N in equation (1), so that in fact factor-based averaging is not applied. In that case, in step S440, ADNEW is written directly into the region of the final result memory region 15c reserved for channel chdt, as an updated final value for that channel.
When step S440 has been executed, with the result obtained in step S410 or step S430 having been written into the region of the final result memory region 15c reserved for channel chdt, operation proceeds to step S450, in which the value of chdt is incremented by 1.
If it is found in step S340 that the value of x is not an integral multiple of 2Tmgdt, then operation proceeds to step S450, to increment chdt. Following step S450, a decision is made as to whether or not the value of chdt exceeds 9, to thereby determine whether all of the channels ch0, ch1 . . . , ch9 have been processed. If chdt is not greater than 9 then operation returns to step S330, while if it is greater than 9 then operation proceeds to step S470, to wait until a time has elapsed (following the start of operation) that is a multiple of 128 μs. When that point is reached (YES decision in step S470), step S480 is executed, to increment the value of x by 1. Operation then returns to step S320.
After the processing of
Thus if for example there is a channel for which the corresponding value of Tmg that has been stored in the data register 17 is 0, then a YES decision will be reached each time step S340 is executed in the sequence of steps from step S320 onward, with respect to that channel, i.e., once in every 128 μs, and steps S350 to S440 will be executed using the values for SEL and Nms that have been stored in the date register 17 for that channel.
Similarly if example there is a channel for which the corresponding value of Tmg had been present as 1, then a Yes decision will be reached each time step S340 is executed once every two executions of the sequence of steps from step S320 onward (i.e., when x takes the successive values 0, 2, 4, 6, . . . ), with respect to that channel, so that each time a 256 μs interval gas elapsed, A/D conversion and subsequent processing will be preformed for the analog signal of that channel (in accordance with the values for SEL and Nms that have been stored in the data register 17 in correspondence with that channel) by execution of steps S350 to S440.
Similarly if example there is a channel for which the corresponding value of Tmg has been present as 2, then a YES decision will be reached each time step S340 is executed once in every four executions of the sequence of steps from step S320 onward (i.e., when x takes the successive values 0, 4, 8, 12, . . . ), with respect to that channel, so that each times a 512 μs interval has elapsed, and A/D conversion and subsequent processing will be preformed in accordance with the values for SEL and Nms that have been stored in the date register 17 for that channel, by execution of steps S350 to S440.
When the input IC 50 receives a register value setting request from the microcomputer 3, in step S510 of
Next, in step S520, a decision is made as to whether or not a time point has been reached at which the processing of
When the input IC 50 receives a data acquisition request, then a step S640 in the flow diagram of
Nest in step S550, the microcomputer 3 performs checking processing to judge whether or not the values for SEL, Nms and Tmg for each of the channels, received and stored in step S540, correspond to original values that are held in the microcomputer 3 (i.e., values that had been previously transmitted from the microcomputer 3 to be stored in the data register 17 of the input IC 50). In step S560 a decision is made as to whether or not an error (i.e., mismatch) has been detected by the checking processing.
If no error has been detected, then operation returns to S520, while if an error has been detected, then since this indicated that at least one incorrect values has become registered in the data register 17 of the input IC 50, e.g., due to the effects of noise, operation proceeds to step S570 in which the updated final valued derived for the respective channels, received and stored in the preceding execution of step S540, are deleted. It is thereby ensured that these data will not be used in controlling the vehicle engine. Resetting of the input IC 50 is then preformed. Operation then returns to step S510, so that setting of the contents of the data register 17 is again preformed, so that correct sets of values for SEL, Nms and Tmg for the various channels are now held in the data register 17.
If it is found in step S530 that a 4 ms time point has not yet been reached, operation proceeds to step S580, in which a decision is made as to whether an asynchronous A/D conversion request is to be issued for any channel (i.e., a request for a signal A/D conversion of the analog signal of the specified channel). Such an asynchronous A/D conversion request may be transmitted by the microcomputer 3 at any arbitrary point in time, e.g., when the engine crankshaft attains a predetermined angular position, or when a specific externally produced signal is inputted to the microcomputer 3, etc. With this embodiment, an asynchronous A/D conversion request can be issued only with respect to each of the channels ch7 to ch9, each of which is provided with a filter circuit for the corresponding analog signal as described hereinabove.
If a NO decision is reached in step S580 then operation returns to step S520, while if a Yes decision is reached, operation proceeds to step S590 in which a single-shot A/D conversion request that specifies one of the channels ch0, ch1, . . . , ch9 is transmitted to the input IC 50.
Issuing of a single-shot A/D conversion request signifies that an A/D conversion of the analog signal of the specified channel is to be preformed immediately. The format of a single-shot A/D conversion request is shown in
When the input IC 50 received a single-shot A/D conversion request, then step S660 and step S670 of the flow diagram of
The processing shown in the timing diagram of
If it is judged in step S610 that a register value setting request has not been received, then operation proceeds to step S630, in which a decision is made as to whether or not a data acquisition request has been received from the microcomputer 3. If a data acquisition request has been received (YES decision in step S630), then operation proceeds to step S640, in which the data held in the final result memory region 15c (i.e., most recently derived final values corresponding to each of channels) and the sets of values of SEL, Nms and Tmg corresponding to the respective channels, held in the data register 17, are read out and transmitted to the microcomputer 3. Operation then returns to step S610.
If it is judged in step S630 that a data acquisition request has not been received, then operation proceeds to step S650 in which a decision is made as to whether or not a single-shot A/D conversion request has been received. If a single-shot A/D conversion request has not been received (NO decision in step S650) then operation returns to step S610, while if such a request has been received (YES decision in step S650) then operation proceeds to step S660.
In step S660, the multiplexer 9 selects the analog signal of the channel whose channel number is specified in the single-shot A/D conversion request, so that an A/D conversion of that signal is performed by the A/D converter 7. The resultant A/D converted value is then transmitted to the microcomputer 3, and operation returns to step S610.
It should be noted that it would be equally possible to implement step S660 as follows. The processing of steps S350 to S370 and steps S420 to S440 of the flow diagram of
In the above description, a data acquisition request transmitted from the microcomputer 3 represents a request for all of the data held for each of the respective channels in the final result memory region 15c (and their respective currently held values of the variables SEL, Nms and Tmg) to be transmitted from the input IC 50. However it would be equally possible to configure the system such that the microcomputer 3 can transmit a data acquisition request which conveys the channel number of a specific channel, so that requests for {most recent data+values for the variables} can be transmitted respectively separately for each of the channels, one at a time. The input IC 50 would respond by transmitting to the microcomputer 3 the most recent final value corresponding to the specified channel, held in the final result memory region 15c, and the values of SEL, Nms and Tmg for the specified channel that are currently held in the data register 17,
With the fourth embodiment described above, the channels ch0 to ch6 of the ten channels ch0, ch1, . . . , ch9 of the A/D converter 7 process respective analog signals, produced from the sensors designated SNa, that vary relatively slowly, for example the output signal from a water temperature sensor, or from an oil temperature sensor, or air intake temperature sensor, etc., or signals that are produced by voltage division of the supply voltage VD in a resistive voltage divider formed of the internal resistance of the sensor Sna and a resistor Ru provided within the ECU 100. No analog filter circuits are provided for these input analog signals. As described above, median value calculation processing is performed on the A/D converted values derived for each of these input analog signals (i.e., as shown in
The channels ch7˜ch9 on the other hand must process analog signals which can vary extremely rapidly, for example the sensor signal from an engine pressure sensor, or from a knock sensor, etc. These signals are asynchronous, e.g., being produced at timings when the engine crankshaft attains a specific angular position. Respective analog filter circuits are provided in the ECU 100, through which these analog signals are transferred to the multiplexer 9, and median value processing is not applied to the A/D converted values of these analog signals (i.e., as shown in
It can thus be understood that with the above embodiment, since analog filter circuits are not provided for those analog signals that are to be subjected to A/D conversion but which vary only gradually, or analog signals that are produced by voltage division of the supply voltage VD, the number of components required to implement the ECU 100 can be reduced. However the digital processing (selection of median values, smoothing processing of the median values) that is applied to the A/D converted values of these analog signals serves to remove noise that may be present in the power supply voltage VD and may be thereby introduced into analog signals that are derived based on voltage division of that power supply voltage.
In the case of analog signals which can vary extremely rapidly, by performing noise removal only by means of analog filter circuits (i.e., which can have response characteristics that are designed to be appropriate for the variation characteristics of these analog signals) rather than by processing the resultant A/D converted values, it can be ensured that the A/D converted values accurately represent these analog signals, without the danger that valid signal values will be erroneously excluded as noise.
Furthermore in the ECU 100 of the fourth embodiment, the input IC 50 can perform various types of settings, for example to determine whether or not median value processing is to be applied to any specific one of the channels of the A/D converter 7, based upon the values that have been stored for the variables SEL, Nms and Tmg for that channel in the data register 17. Moreover if it is determined that median value processing is to be applied for a channel, the number of successively derived A/D converted values from which each median value is to be selected can be specified separately for each channel. It is also possible to specify the A/D conversion interval separately for each of the channels, and whether factor-based averaging is to be applied to median values or to A/D converted values derived for a channel, and, when factor-based averaging is to be applied, the value of N that is to be used in equation (1) above. When the operation of the microcomputer 3 is started, it communicates with the input IC 50 to establish initial values for respective variables that are to be stored in the data register 17, to thereby determine the various conditions described above for each of the individual channels.
It can thus be understood that an electronic control apparatus that incorporates the input IC 50 of the fourth embodiment described above can readily be adapted for use in various different applications, having respectively different control specifications.
Furthermore, with the ECU 100 of the fourth embodiment, when the microcomputer 3 receives the aforementioned data for the respective channels that have been read out by the input IC 50 from the final result memory region 15c, it also receives the sets of values (corresponding to respective channels) of SEL, Nms and Tmg that are currently held stored in the data register 17 of the input IC 50, and the microcomputer 3 can thereby check whether these received values of SEL, Nms and Tmg respectively correspond to the values for these which are held in the microcomputer 3 and which were previously transmitted to the input IC 50 (i.e., S550 of
As a result, it becomes possible to detect when any of the register values held in the data register 17 (i.e., respective sets of values for SEL, Nms and Tmg for the various channels) become altered by the effects of noise, etc. It can also be ensured that such erroneous values will not have any effect upon engine control.
In addition, the microcomputer 3 not only effects initial setting of the register values in the data register 17 when operation is started, but also can subsequently send register value setting request to the input IC 50. When such a request is received, the register values held in the data register 17 for the channel whose number is specified in the register value setting request are changed to the values that are contained in the request. In that way, the values held for the variables SEL, Nms and Tmg, for any specific channel, can be updated in accordance with the current operating conditions of the vehicle engine. Thus for example, it becomes possible to alter the values for SEL, Nms and Tmg such that these become smaller, when the engine speed is high, than when the engine speed is low. In that way derivation of the final values from the input analog signals, for control use by the microcomputer 3, can be performed in an optimum manner in accordance with the current status of the controlled device (e.g., vehicle engine). Increased accuracy of control can thereby be achieved.
In some cases, an analog signal that is to be used for control purposes is a two-mode signal, i.e., consisting of intervals in which the signal level varies only in a gradual manner (referred to in the following as background level interval) and specific short intervals in which the signal level varies abruptly. An examples of this is a sensor signal that is produced by a method such as that of Japanese Patent Laid-open No. 11-201935, whereby the current flowing in an air/fuel ratio sensor elements is converted to a sensor voltage by means of a resistor, and whereby the impedance of the sensor element is measured by abruptly changing the voltage applied thereto, resulting in an abrupt variation interval of the sensor signal. The air/fuel ratio is measured based on the relationship between the sensor voltage levels during the background level intervals and the abrupt variation intervals. With the present invention, such a two-mode detection signal can readily be processed as follows.
In this case, the operation of the processing section 130 is predetermined (by setting appropriate values for the variable in the data register 17 as described hereinabove for the fourth embodiment) such that median value calculation processing is executed periodically for channel ch2 (e.g., by steps S350˜S410 and S440 of
In that way, by using the channels ch2, ch3 for the two-mode detection signal, channel ch2 can be used to measure the background level of that detection signal, while channel ch3 can be used to measure the abrupt changes in the level of the detection signal. Noise can thereby be effectively excluded from the background level by means of the median value calculation processing, while at the same time, noise is removed only by means of an analog low-pass filter from those parts of the two-mode detection signal where abrupt changes occur. Since the abrupt changes are not subjected to the median value calculation processing, it is ensured that these changes will not be erroneously detected as noise, and hence can be reliably measured.
Such a two-mode detection signal could also be handled as follows. Firstly, that signal would be inputted to a single channel of the A/D converter 7, that is provided with an analog filter circuit, such as channel ch7 in
Measurement of the background level of the two-mode detection signal would be performed by periodically applying the median value calculation processing of steps S350˜S410 and S440 in
In that way it would be possible to use only a single channel for handling a two-mode detection signal, so that the total number of channels can be minimized.
It should be noted that such a two-mode detection signal is not necessarily an air/fuel ratio sensor signal, and could for example be produced from an engine cylinder pressure sensor, or be an ion current signal.
Furthermore with the input IC 50 of the fourth embodiment, instead of utilizing the variable Tmg, it would be equally possible to perform A/D conversions for the respective channels in a fixed sequence of channel numbers (e.g., ch0→ch1→ch2→ . . . ch0→ . . . ) with that sequence being specified by a value which is held in the data register 17, and which is transmitted from the microcomputer 3 and written into the data register 17 by the input IC 50.
Furthermore, with the fourth embodiment, an odd-numbered value is set as SEL in the data register 17, and in step S390 and S400 of
It should thus be understood that although the present invention has been described above referring to specific embodiments, it is not limited in scope to these embodiments, and various modifications could be envisaged.
For example, various values other than 2, 4, 8, etc., could be used as the factor N in the factor-based averaging processing. Furthermore, it would be equally possible to apply some other type of digital smoothing processing, such as moving-average processing, in step S150 of
Furthermore with each of the above embodiments and their described alternative forms, each A/D converted value produced from the A/D converter 7 is stored directly in the converted data memory region 15a. However it would be equally possible to apply noise elimination processing of the form described in reference 1 or reference 3 to each of these A/D converted values before storing resultant values in the converted data memory region 15a, i.e., to thereby obtain data in which values exceeding a predetermined magnitude have been excluded as being noise.
Moreover with each of the above embodiments and alternative forms (when each final value is derived based on an odd number of most recently obtained A/D converted values) a single A/D converted value is selected as a median value of magnitude of a plurality of A/D converted values, to be used for control purposes. However it is not essential to derive each median value to a high degree of accuracy, as being the exactly central value when the most recently obtained set of A/D converted values is arranged in order of magnitude. For example it would for example be equally possible to arrange that g A/D converted values are held in the region of the converted data memory region 15a reserved for a channel (where g is a plural even-numbered integer), and that with these g values arranged in order of magnitude, the g/2-th largest value (i.e., counting from the highest-magnitude one of the g values) is selected, so that for example the third-largest value would be selected, if g=6, or selecting the g/2-th smallest value (i.e., counting from the smallest-magnitude one of the g values), which is equivalent to selecting the {(g/2)+1}-th largest value.
Furthermore if the analog signal contains an especially high level of noise, then for example the second-smallest one of each set of five successively obtained A/D converted values could be selected, to be used for control purposes, instead of the median value.
Moreover with the alternative forms 2 and 3 of the first embodiment described hereinabove, two values which are close to the median value of a set of successively obtained A/D converted values are selected, and the average of these is derived, instead of simply detecting the median value of that set of A/D converted values. However as another possible alternative form, if each set of most recently obtained A/D converted values is made an odd number such as 7 or greater, then the third-largest and fourth-largest (i.e., median), and fifth-largest of the set of values could be respectively detected, and the average of these three values calculated to obtain a result which would be utilized as a final value, rather than utilizing the median value alone.
Similar processing could be applied in the operation of the input IC 50 of the fourth embodiment, shown in
As a further alternative, if such a plurality of values are selected that are close to the median value of the set of most recently obtained A/D converted values, and the plurality of-selected values are mutually close in magnitude, then any one of these could be utilized, instead of deriving their average value.
Moreover with the embodiments and alternative forms thereof described hereinabove, memory regions 15a, 15c of a RAM 15 are used for storing the A/D converted values and resultant processed values. However any other type of data storage device could be used for that purpose, and also for storing intermediate values used in calculations or sorting processing, such the region 15b.
In addition, with the above embodiments and alternative forms, digital sorting processing is applied to derive a median value of a most recently obtained set of A/D converted values, for use (directly, or after smoothing processing) as an updated final value, or digital sorting processing is applied to derive a plurality of values that are close to the median value of such a set of A/D converted values, with the average value of that plurality of values being calculated for use (directly, or after smoothing processing) as an updated final value. However it should be noted that it is not essential to derive an A/D converted value (or average of a plurality of A/D converted values) that is accurately close to the median value of such a set. For that reason, it would be equally possible to use analog processing to identify each A/D converted value that approximates to the median value of such a set. That is to say, a plurality of delay circuits (e.g., formed of resistors and capacitors) could readily be used in conjunction with comparators to operate on an analog signal, with the delay values being appropriately determined in relation to the interval between successive A/D conversion timings of the analog signal, and with the output signals from the delay circuits being compared with one another and with the undelayed analog signal, to identify each point in the analog signal at which an A/D converted value will be derived that approximates to the median value of the aforementioned most recently obtained set of A/D converted values.
It should also be noted that the present invention is not limited in application to an ECU for vehicle engine control purposes, but could be equally applied to an ECU for controlling the transmission of a vehicle, or for controlling devices in fields other than that of motor vehicles.
Number | Date | Country | Kind |
---|---|---|---|
2003-382756 | Nov 2003 | JP | national |
2004-217805 | Jul 2004 | JP | national |