This invention relates to processing position-related input data from a machine whose angular speed is variable. More specifically, the invention relates to a data processor, that is to say a device, apparatus or system for performing logical operations on the data, and to a method of processing data.
The variable angular speed of a machine means that angle-based data (that is to say position-related data occurring as a function of the angular position of the machine) has a variable time-based repetition rate. Known data processors for such machines require intensive processor and memory resources.
An example of a machine whose speed fluctuates is an internal combustion engine. For an internal combustion piston-and-cylinder engine, optimal operating parameters such as cylinder filling and burn characteristics are functions of the instantaneous pressure in the cylinder, which is a function of the angular-position of the crank-shaft. It is possible to control such parameters in response to a pressure signal from a pressure sensor in the cylinder.
For example, engine manufacturers use such pressure sensors in the cylinders to determine initial calibration in dynamometer cells. An example of a method of obtaining, for the purpose of analysis, real-time engine knock data derived from an operating internal combustion engine is described in US Patent Application 20060206254.
Theoretically, a system of this kind could be applied in a commercialised vehicle. However, practical difficulties have so far presented obstacles to such commercial applications, so that production vehicles use sensors of parameters such as mass air flow and air temperature along with an engine model to estimate cylinder filling and burn characteristics instead of cylinder pressure sensors, with results that are sub-optimal.
Among the practical difficulties encountered are that the pressure signal from a pressure sensor is small and noisy. Accordingly, filtering is required to clean up the pressure signal, using a filter having a low pass or band pass frequency characteristic. However, running a fixed frequency filter on variable speed and time repetition rate data is mathematically complex and uses processor resources intensively.
Instead of running a fixed frequency filter on variable time repetition rate data, the pressure signal can be sampled at regular time intervals. This makes the frequency filter straightforward and also may suit knock detection since knock is a frequency based signal. However, the data then needs to be converted into crankshaft angle based results for calculation of engine parameters. Conversion of time-based signals to results related to crankshaft angle accurately and precisely is again mathematically complex and uses processor resources intensively. In addition this conversion requires large quantities of system random access memory (‘RAM’) for buffering the time based data.
In addition, the rotational speed of an internal combustion engine is not constant during the combustion cycle (720° in a four-stroke engine) but fluctuates during the course of a revolution, with accelerations and decelerations. The calculations to determine engine parameters are based on the crankshaft angle but these angular-position-related intervals do not occur with a constant repetition rate in the time domain, because of the variable and fluctuating engine speed.
Similar problems are encountered in processing position-related input data from other machines whose speed is variable.
The present invention provides a data processor, a method of processing data, a computer program for processing data and a machine as described in the accompanying claims.
Specific embodiments of the invention are set forth in the dependent claims.
These and other aspects of the invention will be apparent from and elucidated with reference to the embodiments described hereinafter
Further details, aspects and embodiments of the invention will be described, by way of example only, with reference to the drawings. Elements in the figures are illustrated for simplicity and clarity and have not necessarily been drawn to scale.
The embodiments of the invention illustrated in the drawings are described with reference to application in an internal combustion piston-and-cylinder engine. However, it will be appreciated that the invention is applicable to other machines whose speed is variable and which need position-related data to be processed.
Typically, such an engine comprises multiple cylinders, for example four, six or more, each having a piston such as 104 coupled by a respective connecting rod 106 to a crankshaft (not shown), which in turn is coupled to a flywheel 108. The flywheel presents timing teeth 110 whose passage during rotation of the flywheel is sensed by a crank angle sensor 112. The crank angle sensor 112 of the engine 100 is an example of a position-responsive generator for producing an angular timing signal related to a rotational position of the machine. The crank angle sensor 112 may, for example, be a magnetic sensor when the timing teeth are of magnetic material, and which provides a train of electrical pulses at a crank angle terminal 114. The cylinders each have at least one combustion mixture inlet such as 116 and at least one exhaust outlet such as 118 which are opened and closed by valves (not shown) at suitable times defined by an engine controller (not shown in
In this example, the data processor 200 processes analogue input data from the pressure sensor 120. The over-sampler 202 includes an analogue-to-digital converter (‘ADC’) 208, triggered by a time-domain clock signal from a time-based trigger 210, and provides the input data in digital form. The down-sampler 204 is part of a decimator 216 also including a low-pass filter 212, which receives data from the ADC 208, the down-sampler selecting samples of data from the output of the low-pass filter 212. The low-pass filter 212 comprises a finite impulse response filter in this example, although other filters, such as an infinite impulse response filter for example, may be used. Furthermore, other types of pass characteristics, such as band pass, may be used.
The selected angle-domain samples of data are exploited by the engine controller, shown at 214 in
In more detail, the analogue pressure signal from the sensor 120 is small and noisy and filtering is used in this example to clean it up, using a fixed-frequency (time based) filter with low pass or band-pass frequency characteristics. However the variation of engine speed makes angle based sampling of the analogue pressure signal time variable, that is to say that, seen in the time domain, the angle-based sampling rate varies. In this example, both data sampled at a rate which is constant in time (the over-sampled data and the data in the filter) and data extracted (down-sampled) at defined angular positions are available without unduly complex calculations, such as recalculating the tap coefficients of the fixed frequency FIR low-pass filter as a function of engine speed, which would make heavy use of processor calculation and memory resources.
More specifically, in the example of
When a sample is needed, it is pulled from the output of the decimator/filter. This occurs at moments defined by the angle trigger 218, thus automatically re-sampling the filtered, time based signal into the angle domain.
Angle-domain data is moved by direct memory access (‘DMA’) 220 into system random access memory (‘RAM’). Alternatively, the central processor unit (‘CFU’) of the system at 220 may write the data into system memory 206. From the RAM or system memory, the angle domain data is passed to the engine controller 214. The engine controller 214 then controls engine performance parameters as a function of the angle-domain pressure signal samples, including, for example defining a knock window, that is to say a range of crank-shaft angles where knock is likely to occur in the engine.
In another embodiment of the invention, both time-domain and angle-domain pressure signal data are provided to separate buffers and utilised by the engine controller.
In an example of an implementation of the data processor shown in
The crank position signal from the sensor 112 is processed in a time processor unit 218 to create an angle ‘clock’ trigger signal. A digital comparator block matches on one degree angle trigger signals. Data is pulled from the output of the decimator 216 at moments based on the angle trigger. It is placed in a separate queue in system RAM.
For pressure sensing, crank angle accuracy is relevant. Production engines have an absolute crank reference of at best 0.3 degrees.
In an example of operation of the engine, the following parameters are obtained:
The down-sampling at 308 is responsive to an angular timing signal related to an angular position of the machine for selecting the samples of data from the over-sampled signal to extract, the angular timing signal being produced in response to an angle-based trigger at 316 from an analogue angle signal produced at 318, and which may be produced by sensing crank-shaft angle in the case of an internal combustion engine, for example. The angle-based down-sampling occurs at a rate slower than the time-based repetition rate of the over-sampled signal from the ADC. Over-sampling the input data 304 may include converting the input data to digital form in an analogue-to-digital converter. Down-sampling 308 may be performed in a decimator which includes, for example, a low-pass FIR filter that filters the digital signal that comes directly from the ADC at its native over-sampled rate.
The invention is not limited to physical devices or units implemented in non-programmable hardware but can also be applied in programmable devices or units able to perform the desired device functions by operating in accordance with suitable program code. Furthermore, the devices may be physically distributed over a number of apparatuses, while functionally operating as a single device. The invention may also be implemented in a computer program for running on a computer system, at least including code portions for performing steps of a method according to the invention when run on a programmable apparatus, such as a computer system or enabling a programmable apparatus to perform functions of a device or system according to the invention. The computer program may for instance include one or more of: a subroutine, a function, a procedure, an object method, an object implementation, an executable application, an applet, a servlet, a source code, an object code, a shared library/dynamic load library and/or other sequence of instructions designed for execution on a computer system. The computer program may be provided on a data carrier, such as a CD-ROM or diskette or non-volatile memory, containing data loadable in a memory of a computer system, the data representing the computer program. The data carrier may further be a data connection, such as a telephone cable or a wireless connection.
Some of the above embodiments, as applicable, may be implemented using a variety of different information processing systems. For example, the description of the architecture has been simplified for purposes of discussion, and it is just one of many different types of appropriate architectures that may be used in accordance with the invention. Those skilled in the art will recognize that the boundaries between logic blocks are merely illustrative and that alternative embodiments may merge logic blocks or circuit elements or impose an alternate decomposition of functionality upon various logic blocks or circuit elements.
Thus, it is to be understood that the architectures depicted herein are merely exemplary, and that in fact many other architectures can be implemented which achieve the same functionality. In an abstract, but still definite sense, any arrangement of components to achieve the same functionality is effectively “associated” such that the desired functionality is achieved. Hence, any two components herein combined to achieve a particular functionality can be seen as “associated with” each other such that the desired functionality is achieved, irrespective of architectures or intermedial components. Likewise, any two components so associated can also be viewed as being “operably connected,” or “operably coupled,” to each other to achieve the desired functionality.
Furthermore, those skilled in the art will recognize that boundaries between the functionality of the above described operations are merely illustrative. The functionality of multiple operations may be combined into a single operation, and/or the functionality of a single operation may be distributed in additional operations. Moreover, alternative embodiments may include multiple instances of a particular operation, and the order of operations may be altered in various other embodiments.
Because the apparatus implementing the present invention is, for the most part, composed of electronic components and circuits known to those skilled in the art, circuit details will not be explained in any greater extent than that considered necessary as illustrated above, for the understanding and appreciation of the underlying concepts of the present invention and in order not to obfuscate or distract from the teachings of the present invention.
In the foregoing specification, the invention has been described with reference to specific examples of embodiments of the invention. It will, however, be evident that various modifications and changes may be made therein without departing from the broader spirit and scope of the invention as set forth in the appended claims. For example, the connections may be an type of connection suitable to transfer signals from or to the respective nodes, units or devices, for example via intermediate devices. Accordingly, unless implied or stated otherwise the connections may for example be direct connections or indirect connections.
In the claims, any reference signs placed between parentheses shall not be construed as limiting the claim. The word ‘comprising’ does not exclude the presence of other elements or steps then those listed in a claim. Furthermore, Furthermore, the terms “a” or “an,” as used herein, are defined as one or more than one. Also, the use of introductory phrases such as “at least one” and “one or more” in the claims should not be construed to imply that the introduction of another claim element by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim element to inventions containing only one such element, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an.” The same holds true for the use of definite articles. Unless stated otherwise, terms such as “first” and “second” are used to arbitrarily distinguish between the elements such terms describe. Thus, these terms are not necessarily intended to indicate temporal or other prioritization of such elements The mere fact that certain measures are recited in mutually different claims does not indicate that a combination of these measures cannot be used to advantage.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB2008/052679 | 7/3/2008 | WO | 00 | 12/15/2010 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2010/001199 | 1/7/2010 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6006155 | Wu et al. | Dec 1999 | A |
7242326 | Melanson et al. | Jul 2007 | B1 |
7242327 | Thompson | Jul 2007 | B1 |
7459872 | Woodland et al. | Dec 2008 | B2 |
20050166665 | Honda | Aug 2005 | A1 |
20060206254 | Remelman | Sep 2006 | A1 |
Number | Date | Country |
---|---|---|
0647774 | Apr 1995 | EP |
1905989 | Apr 2008 | EP |
2000186611 | Jul 2000 | JP |
2001263153 | Sep 2001 | JP |
Entry |
---|
Aziz P M et al. “An Overview of Sigma-Delta Converters” IEEE Signal Processing Magazine, IEEE Service Center, Piscataway, NJ, US, vol. 13, No. 1, Jan. 1, 1996. |
International Search Report and Written Opinion correlating to PCT/IB2008/052679 dated Jul. 15, 2009. |
Number | Date | Country | |
---|---|---|---|
20110093236 A1 | Apr 2011 | US |