This application claims the benefit under 35 U.S.C. 119 of French Patent Application 0756080 filed Jun. 27, 2007.
The present invention relates to a method for generating a variable analogue signal generated from a PWM signal, and a system generating such a signal.
Generators of DC voltage from a Digital to Analogue Converter (DAC) are known. A Central Processing Unit (CPU) controls the converter by introducing a digital value of determined precision into an input register. If the value is expressed on 8 bits, 256 values are possible and as a result the precision will be 1/256, that is 0.4%. If for example, the voltage varies from 0 volts to 10 volts, the voltage difference from one value to another is 0.04 volts. Commonly found on the market are DACs with 16 bit registers, the central processing unit can introduce 65,536 different values and the precision goes to 0.0015%. Taking the same example as previously with a voltage varying from 0 volts to 10 volts, two consecutive values present a difference of 0.15 millivolts.
The price of the DACs increases as the precision is increased and the conversion time is more rapid. If a rapid conversion time is not required, the Pulse Width Modulator (PWM) signals enable supply of an analogue voltage from a digital magnitude. A PWM signal is a periodic digital signal for which the period at “1” of the signal is variable within the total period. The period of the signal at “1” is called the cyclic ratio. A base clock supplies the base period. Take as an example the PWM signal generator having an 8-bit program register in which the value “1” is programmed, the digital signal obtained is at “1” for a single base pulse and at “0” during the following 255 base pulses. The digital output of the PWM signal is connected to a RC integrator network that smoothes out the variations. A continuous value is thus obtained that can be amplified to control a motor for example.
This type of assembly is commonly found in regulation systems, to modulate the brightness of a lamp or control the speed of a ventilation fan. This latter example is found particularly in television decoders. In fact, these electronic devices consume a great deal of energy during normal operation. This energy is transformed into heat that is concentrated within devices that are generally sealed. If it is not evacuated this heat provokes an accelerated aging of electronic components that results in irreversible deterioration. To prevent this, a ventilator is positioned close to air inlets in the casing of the decoder to accelerate exchanges with the exterior and improve cooling. But using a ventilator at full speed is noisy. If the device is placed in a room, the sound level can be disturbing. Experimentation has shown that it is not the speed that is audible but rather the variation in speed. A ventilator requires a minimal voltage to start, for example 5 volts for a maximum authorized voltage of 10 volts. If, a ventilator is controlled by a PWM signal, only digital values enabling generation of a voltage between 5 and 10 volts can be used. For an 8-bit PWM generator, these values are comprised between 128 and 255, that results in 128 possible values. As a result, the precision of such a device is 1:128 or 0.8% on the range of usable voltages. When the values are introduced into the PWM generator and a continuous voltage has thus been produced, the progression of one value to a next value is audible, especially when this variation intervenes regularly as is the case if a control system is used. In addition, different ventilator models are possible for a same device. If a servo system is used, the ventilators do not need to have the same characteristics, as a result the control system specific to the device must possess an extensive control range and a therefore a high level of accuracy over the entire range.
One solution consists in increasing the number of bits to program the PWM cyclic ratio, for example 12 bits, the precision is then at 0.025%. Assuming the same conditions as previously, the result is a precision of 0.05% that suits perfectly for reducing the audibility of the variations. But a 12-bit PWM is costly and takes longer to program than a PWM using values on 8 bits.
The document US 2007/098374—FUJIWARA published on May 3, 2007 describes a ventilator control system. A control unit 23 sends a PWM signal to the ventilator 22. A tachymetric probe detects the rotation speed of the ventilator and transmits it to the control unit 23. The system can control the temperature of a laptop computer.
The document U.S. Pat. No. 6,487,246—HOELD published on Nov. 26, 2002 describes the internal structure of a PWM signal generator. It is possible to separately program the number of clock pulses for the period and the number of clock pulses for the cyclic ratio of the PWM signal. This document specifies that if the programming of the two registers is carried out at the time of the generation of a new signal, this signal can be contain errors. The solution to this problem consists in synchronizing the update of the registers with the establishment of PWM periods, but this solution cannot increase the accuracy of the analogue signal generated.
The present invention enables a DC voltage to be generated from a more precise PWM signal without increasing the number of cyclic ratio programming bits.
One of the aims of the present invention is a method to generate a variation form of an analogue signal produced by a succession of generation steps of a PWM signal from pairs of given period and cyclic ratios, the PWM signal being integrated to produce the analogue signal, wherein during the generation of the variation form, pairs having different period values and cyclic ratios are successively applied to generate the PWM cycle, together with the pairs having different periods with the same cyclic ratio.
In this way, in choosing a succession of pairs formed from a certain cyclic ratio and a certain period value, an analogue signal can be generated whose variations are smaller that if the variation consists only in varying the cyclic ratio. Between two successively generated PWM signals, the period or the cyclic ratio can be varied, or both. This can obtain a greater number of digital values produced by the ratio between the cyclic ratio and the period, and thus, supply a large number of different analogue values. Hence, the accuracy to obtain a determined value is greater. Notably, a signal can thus be generated whose evolution is much more linear over time.
According to a first improvement, each generation step comprises an extraction step from a recorded table of a pair of period values and a cyclic ratio, the address of the extracted pair being the command value to generate the analogue signal. In this way, the search for a pair of values within a table is performed rapidly.
According to another improvement, each generation step comprises an extraction step from a recorded table of a pair of period values and a cyclic ratio, each pair of values being associated with a digital value. The pair extracted from the table is the one whose associated digital value is closest to the analogue signal to generate. In this way, the table contains only different digital values, thus preventing that table from containing duplicate values.
According to an improvement, the PWM signal generation steps are applied over equal times. In this way, the chronology of the steps is performed with great simplicity. According to a variant, the PWM signal generation steps are applied over time slots whose duration is the result of a mathematical formula. In this way, it is possible to vary the form of the variation thus generated using time. According to another variant, the PWM signal generation steps are applied over periods varying according to the difference between the associated digital value extracted from the table and the digital value that follows in the order of the table. In this way it is possible to compensate for the lack of precision of certain values.
According to another improvement, if several cyclic ratio and period pairs produce an identical result, the couple having the highest period value is selected. In this way, it is possible to apply pairs of values of period and cyclic ratio having close period values, which reduces the amplitude of some artifacts. According to another improvement, the analogue magnitude is a command signal controlling a ventilator speed.
Another aim of the present invention is a device to generate a variation form of an analogue signal, comprising a generator of PWM signals whose period and cyclic ratio are programmable and a circuit of integration of said signal to produce the analogue signal,
Wherein during the generation of the variation form, a plurality of pairs having different values of period and cyclic ratio are successively applied to the generator to produce the variation form, as well as pairs having different periods with the same cyclic ratio.
Other characteristics and advantages of the present invention will emerge from the description of the following embodiments to be taken as non-restrictive examples, made with reference to the figures attached wherein:
A PWM signal is a periodic digital signal that can be converted to an analogue signal using a means of integration, typically a low-pass filter comprising a resistor R and a capacitor C. In the embodiment, the analogue signal whose power is amplified by an amplifier A controls a ventilator V. In a known manner, the period is fixed and the amplitude of the analogue signal varies according to the cyclic ratio. According to an embodiment, the cyclic ratio of the PWM is coded on 8 bits. The applied analogue voltage can theoretically vary between 0 and 12 volts, but generally the ventilator does not rotate for a voltage less than approximately 5 volts, and becomes too noisy if greater than 9 volts. As a result, the useful range of motor command values varies for a PWM signal defined by 8-bit values between approximately 120 to 180 which constitute sixty useful values. A unit variation causes a large amplitude variation that becomes easily audible. It is clear that other values coded by more or less than 8 bits are possible, the number of bits is only given here by way of an example.
The PWM signal generation circuit generates a periodic digital signal whose cyclic ratio and period is variable. A base clock supplies a square wave signal with a frequency of 27 MHz, then this signal is according to a certain ratio to obtain the period of the PWM signal. Typically, the PWM signal generator has two registers of 8-bit programs, one to introduce the “PER” value representing the number of time units of the period of the PWM signal, and the other to introduce the cyclic ratio, that is the “T_ON” value representing the number of times that the PWM signal is at “1”. So, to obtain a PWM signal having at least one time period at “0”, it is strictly necessary that T_ON be less than PER. For example, if the period register contains the value PER=100 and the cyclic ratio register contains the value T_ON=64, then the generated signal has a frequency one hundred times less than the base frequency and the period during which the digital value is at “1,” is three times shorter than that for which the digital value is at “0”.
If the period value is not modified, the number of possible values to generate a signal is 256, but practically the usable values are from 120 to 180, which enables a precision in the order of 1.5% to regulate the ventilator speed. According to the present invention, by modifying both the PER values and T_ON a lot more than 256 possible values are obtained, and so, there is a very high number of pairs finally enabling as many different voltage values to be generated.
By respecting the rule T_ON≦PER, the following are obtained:
If PER=255, then 256 values are possible for T_ON.
If PER=254, then 255 values are possible for T_ON.
If PER=253, then 254 values are possible for T_ON.
. . .
If PER=2, then 3 values are possible for T_ON (0, 1 or 2).
If PER=1, then 2 values are possible for T_ON (0 or 1): the signal is then continuously at “0” or “1”.
The null value for PER has no meaning.
The possible number of pairs is the result of an arithmetic progression for which the formula is Σ=255×((1+255)/2)=32640 different (T_ON/PER) pairs.
According to a first simple embodiment, the generation system of an analogue signal calculates values on 16 bits to control the ventilator, given that the maximum decimal value is 32,640. the generation system creates a correspondence table supplying a pair (T_ON/PER) to apply, for a given command value. This table of 32,640 values is an ordered list of pairs of data (T_ON/PER) of 8 bits. Advantageously, it is possible to reduce the table so that it contains a number equal to a power of 2, for example 2 to the power of 14 or 2 to the power of 12. Certain pairs (T_ON/PER) disappearing as their decimal values are very close to other values maintained on the table. The memory zone occupied by the table is thus optimized.
Whatever the size of the table, the search for a pair (T_ON/PER) is performed by applying to the address the command value on 16 bits, 14 bits or 12 bits, the addressed pair is then read and used to program the two registers of the PWM generator. Here is how the table values are written: initially, all decimal values between 0 and 1 obtained by all the ratio combinations (T_ON) on (PER) are calculated to a very high degree of precision (typically 10 decimals). The decimal values are ordered from the smallest (0.00000) to the largest (1.000000) and the corresponding pairs (T_ON/PER) are arranged in the same order. Then a table precision is given, for example 16 bits=N. The 2N theoretical values i/2N are calculated where i varies from 1 to 2N=65,536. 65,536 values varying from 0 to 1 are obtained. Each theoretical value is then associated with the closest decimal value calculated from the pair (T_ON/PER) and the table is filled in this manner.
An extract of an example of such a table is given in
When the analogue signal generation system produces a command value on 16 bits, it indicates the table with this value and immediately reads the pair (T_ON/PER) to program the registers. To generate a continuous variation of an analogue signal, it is possible to go from a DEBUT value of 16 bits to a value FIN, while reading from the table all the pairs (T_ON/PER) comprised between DEBUT and FIN, and applying regular times to the intervals.
It is observed that the decimal values generated by certain pairs are identical: ½= 2/4= 4/8= 8/16= 16/32= 32/64= 64/128. The calculation shows that there are 19,947 pairs T_ON/PER producing different decimal values.
It appears particularly interesting to memorize only pairs (T_ON/PER) producing different analogue signal values. It is therefore possible to reduce the size of the table.
According to an embodiment variant, the table in the memory is modified so that it contains only differing decimal values. It has been seen that the set of pairs (T_ON/PER) producing different decimal values is 19,947, it is therefore unnecessary to keep duplicates in the table. According to the variant, the analogue signal generation system calculates the decimal values varying between 0 and 1, with, for example, 6 decimal points. The use of six decimals offers a good compromise, it depends upon the number of register bits. The table in the memory contains the 19,947 possible results ordering them from the lowest value (0) to the highest (1) with a precision of six decimal points. According to a variant, the correspondence table associates decimal values with a given pair. In order to optimize the table size, care is taken to retain only differing decimal values. If, as seen previously, several pairs produce the same result, only the pair possessing the highest period value is retained to be memorized in the table. In this way, the various pairs that succeed each other to generate the form or variation of an analogue signal, will have close period values (these values all have period values between 128 and 255), which avoids eventual artifacts produced by exchanges between PWM signals with very short periods and PWM signals with very long periods. As shown by
According to this variant, the management unit M calculates the decimal values to command the ventilator, these values are comprised between 0 and 1 and have a precision of at least five decimal points. For each new return decimal value, the management system searches for the pair (T_ON/PER) whose associated decimal value is closest to the return value. The table search illustrated by
According to a simple embodiment, the analogue signal generation system extracts the values T_ONi and PERi from the correspondence table during determined time slots and writes them into the two PWM control registers. In this way, the generated analogue signal is progressively equal to the required value passing in by numerous different discrete values, the great number of these values enabling very low variations as well as great precision and in the case of the control of a ventilator, a notable noise reduction. The time interval between two pair (T_ONi/PERi) applications depends particularly on the duration spent waiting for the new value. Let ΔT be the time to obtain the new nominal value, let Vini be the initial value and Vtarget the decimal value to obtain, the system divides ΔT by the number of values enabling the acquisition of this target decimal value in order to determine the time value around which each pair (T_ONi/PERi) extracted from the table is applied. As shown in
Assume that the analogue signal generation system must produce a linear varying analogue signal of 6.024 volts to 6.030 volts to control ventilator V. The circuit delivering a maximum voltage of 12 volts, the decimal value to supply to the analogue circuits varies from 0.502 to 0.5025. The correspondence table illustrated in
An example of a variation form of an analogue signal, typically a straight line, is seen in
Other embodiments are possible, where the application time value of a pair is obtained by a more complex equation, notably of 2nd degree.
It is noted that the temporal differences between the application of two different pairs (T_ONi/PERi) to generate a variation form are not the same, this is due to the production of discrete decimal values that do not offer the same difference between them.
To reduce the differences, the period in which a given pair (T_ON/PER) generates an analogue signal depends upon its difference with the following pair. If Ttotal is the time to obtain the new nominal value and Etotal the difference between the actual value and this nominal value, the ratio (Etotal/Ttotal) represents the value derived from the signal frame to be generated to obtain the new nominal value in a linear manner. For Vi, Vi+1 two consecutive decimal values extracted from the table, ΔV is the difference between Vi and Vi+1:
ΔV=Vi+1−Vi
The value derived from the variation ΔV must be the same as the ratio (Etotal/Ttotal), and other terms:
ΔVi/ΔTi=Etotal/Ttotal
The value Etotal/Ttotal is known and is constant, ΔV that is equal to Vi+1−Vi is deduced from the table, the unknown ΔTi is calculated by the formula:
ΔTi=ΔVi/(Etotal/Ttotal).
As a result, the duration of the pair application (T_ONi/PERi) generating a value Vi depends on the difference between this value and the following value in the table. If, for example, the management system M produces an analogue signal in the form of a ramp varying linearly between the decimal values 0.4980 and 0,5020 during 1 second, then the following ratios will be applied during the following times:
This solution enables compensation for the non-linear defects in the differences between successive values extracted from the table of
Those skilled in the art can adapt the present invention into many other specific forms without moving away from the application domain of the invention as claimed. In particular, the generation system can be adapted for the generation of signals of all physical sizes used in electronic devices. Consequently, the present embodiments must be considered as being examples but can be modified in the domain defined by the scope of the attached claims.
Number | Date | Country | Kind |
---|---|---|---|
07 56080 | Jun 2007 | FR | national |
Number | Name | Date | Kind |
---|---|---|---|
3629710 | Durland | Dec 1971 | A |
4330751 | Swain | May 1982 | A |
6487246 | Hoeld | Nov 2002 | B1 |
6765422 | Aslan et al. | Jul 2004 | B1 |
7151349 | Williamson et al. | Dec 2006 | B1 |
20050099217 | Agarwal | May 2005 | A1 |
20060164142 | Stanley | Jul 2006 | A1 |
20070098374 | Fujiwara | May 2007 | A1 |
Number | Date | Country |
---|---|---|
2235103 | Feb 1991 | GB |
Number | Date | Country | |
---|---|---|---|
20090066551 A1 | Mar 2009 | US |