1. Field of the Invention
This invention relates to cooling equipment for electronic systems, e.g., fans, and more particularly, to controlling the rotational speed of a fan.
2. Description of the Related Art
Fans are often used to evacuate warm air from enclosures in which electronic systems are contained. For example, most computer systems include one or more cooling fans to aid in circulating the air inside the enclosures and for maintaining the temperature inside the enclosures within an acceptable range. The increased airflow provided by fans typically aids in eliminating waste heat that may otherwise build up and adversely affect system operation. Employing cooling fans is especially helpful in ensuring proper operation for certain central processing units (CPUs) with relatively high operating temperatures.
Control of fans in a system typically involves a fan control unit executing a fan control algorithm. A fan control algorithm may determine the method for controlling one or more fans that are configured to evacuate warm air from a system enclosure. For example, the fan control algorithm may specify that a fan's speed should be increased or decreased dependent upon a detected temperature. Such control algorithms may also involve turning off a fan if the temperature is deemed cool enough to do so.
For detecting the temperature, a temperature sensor may provide to the fan control unit a signal indicative of the current temperature of a particular temperature zone in the electronic system. Often, fans used for CPU and/or computer system cooling have a three-wire interface with wires for power, ground, and a tachometer signal. Fan drive systems often use a signal generator that provides a Pulse Width Modulated (PWM) signal to drive an external circuit that controls the voltage between the power and ground interfaces of the fan, which in turn controls the speed of the fan. Signal generators that provide PWM signals are useful because they provide a digital control for the pulse width of a signal. The fan is typically powered only for the duration of the pulse. Between pulses power to the fan is turned off, although the fan is typically still spinning during this time. The duty cycle of the PWM pulse train currently being provided to the fan determines the fan's speed.
One problem that results from using PWM signals to drive fan circuits is that multiple cooling zones create the need for multiple sensors and multiple fans thereby causing the need for complex management schemes in fan operation management. An autofan control algorithm was defined in an industry specification (Heceta 6 Specification, Version .97, May 17, 2001, Intel Corporation) to control three PWM outputs based on three temperature zones. Pursuant to the specification, each temperature zone corresponds to a temperature sensor in a fixed manner. For example, Zone 1 may correspond to temperature measured across the pn-junction of a first remote diode, Zone 2 may correspond to ambient temperature, and Zone 3 may correspond to temperature measured across the pn-junction of a second remote diode. Each PWM signal can be controlled by one zone, or the “hottest” of two or three zones. In other words, control of the device may be performed using sensor information from a selected single corresponding zone, or using sensor information from the hottest of the three zones. If the device is configured for one of the hottest options, the duty cycle for the PWM output will be calculated for each zone with its associated limits and parameters. The zone that produces the highest duty cycle will typically control the PWM output.
Other corresponding issues related to the prior art will become apparent to one skilled in the art after comparing such prior art with the present invention as described herein.
The invention comprises a system and method for combining sensor data from two temperature zones in order to calculate a single control value used to control a fan. This would enable an autofan controller used to perform the fan control to automatically adapt to the system environment. For example, using this method, the speed of a fan may be determined based on the temperature of the CPU, with an additional factor based on the ambient temperature of a PC enclosure. Specifically, if the ambient air temperature were high, the CPU fan would increase its speed more quickly to compensate for the overall heat in the system, since it is more difficult to dissipate heat in a hot enclosure. If the ambient air temperature was low, the CPU fan could increase its speed more slowly, since it is easier to dissipate heat in a cool enclosure. In one set of embodiments, the fan is controlled by a single PWM output where the single control value is a single PWM value corresponding to the single PWM output.
In one embodiment, an autofan control system is described. The autofan control system may implement an autofan controller algorithm, which may be employed to control three PWM outputs based on three temperature zones, featuring one each of the three zones controlling one of the three PWM outputs, or a combination of zones controlling any one of the three PWM outputs at a time. In one embodiment the autofan control system includes a first multiplexer that receives zone sensor reading inputs from three separate zones, a second multiplexer that receives parameter inputs for the three separate zones, a third multiplexer that provides three PWM outputs, and a fourth multiplexer that receives three separate sets of PWM parameters, each corresponding to a respective one of the three PWM outputs. The first and second multiplexers may each provide zone sensor reading data and parameters, respectively, corresponding to one or more zones to a PWM computation logic block, which may implement an autofan control function used to compute the PWM value. Similarly, the fourth multiplexer may provide the PWM parameters to the PWM computation logic block as additional input to the autofan control function. In one embodiment, the output of the PWM computation logic block carries the currently computed PWM value, which is provided as input to the third multiplexer, which may route the currently computed PWM value to its corresponding one of the three PWM outputs.
The PWM value may be calculated, in part, from a temperature difference value. In one embodiment, the temperature difference value may be the difference between the current temperature indicated by a temperature sensor and a predefined zone limit temperature value when the current temperature is greater than or equal to the predefined minimum zone limit temperature. In one embodiment, the autofan controller algorithm may operate to calculate the PWM value based on limits and parameters associated with a first zone as a function of a second zone. In this embodiment, to obtain a final PWM value, an offset is added to the PWM value calculated for the first zone only. The offset may be a value computed by taking a fraction of the change in PWM value that was computed for the first zone as a function of the change in PWM value computed for the second zone. In one set of embodiments two methods of adding an offset are configured and each method can be enabled independently or simultaneously to adjust the computed PWM duty cycle.
In one embodiment, the PWM value is determined by first calculating a delta PWM value based on the current temperature of a first zone, adding the delta PWM value to a pre-determined minimum PWM value assigned for the first zone, calculating a delta PWM factor for the first zone and using the delta PWM factor of the first zone to weight a delta PWM factor calculated for a second zone, and adding the weighted delta PWM factor to obtain a final PWM value. Thus, the magnitude of the weighted delta PWM value may be a measure of the added contribution to the PWM value calculated for the first zone of the PWM value calculated for the second zone. In other words, the higher the temperature in the first zone, the greater contribution the term for zone 2 may make to the PWM value calculated for the first zone.
Other aspects of the present invention will become apparent with reference to the drawings and detailed description of the drawings that follow.
The foregoing, as well as other objects, features, and advantages of this invention may be more completely understood by reference to the following detailed description when read together with the accompanying drawings in which:
While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and will herein be described in detail. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the present invention as defined by the appended claims. Note, the headings are for organizational purposes only and are not to be used to limit or interpret the description or claims. Furthermore, note that the word “may” is used throughout this application in a permissive sense (i.e., having the potential to, being able to), not a mandatory sense (i.e., must).” The term “include” and derivations thereof mean “including, but not limited to”. The term “coupled” means “directly or indirectly connected”.
Fan speed control systems often control a fan with a PWM (pulse width modulated) signal generated by a PWM signal generator. The signal generator receives PWM signal parameters for calculation of the PWM signal at a particular time. One of the PWM signal parameters is “duty cycle.” The duty cycle of a PWM signal is the ratio of the amount of time that the PWM signal is asserted to being non-asserted. For example, a PWM signal having a 50% duty cycle is understood to be a PWM signal asserted half the time. The greater the PWM duty cycle, the faster the fan operates, and thus, the greater the air movement is in the fan speed control system. For example, a 100% duty cycle produces a PWM signal that powers the fan at a maximum, whereas a 0% duty cycle produces a PWM signal that turns the fan off. The terms “PWM value” and “PWM duty cycle value” are both used herein to refer to “PWM duty cycle value”.
The duty cycle may be calculated, in part, from a temperature difference value. The temperature difference value may be obtained in various manners depending on the fan speed control system. In one embodiment, the temperature difference value may be the difference between the current temperature indicated by a temperature sensor and a predefined zone limit temperature value when the current temperature is greater than or equal to the predefined zone limit temperature. The temperature difference value may then be used to calculate the duty cycle of a desired PWM signal and the PWM signal generator may generate a PWM signal having a corresponding duty cycle for controlling the speed of the fan.
The autofan control algorithm may be configured to control the fan based on the limits and parameters associated with Zone 1 as a function of Zone 2. As illustrated in
As described above, the “combination of zones” option may provide ACS 100 with an ability to adjust the amount of cooling for a PWM output as a function of two thermal inputs: primary and secondary. A typical application may be one that controls a CPU fan based on the CPU temperature as a function of the system ambient temperature. The “combination of zones” option may be configured to allow ACS 100 to operate in a manner similar to that of a PWM output being associated with Zone 1, with the difference that an offset value may be added to the total PWM output calculated for Zone 1. In one set of embodiments two methods of adding an offset may be configured, and each method may be enabled independently or simultaneously to adjust the computed PWM duty cycle. In alternate embodiments a single method may be used or other methods may be added as deemed necessary for the monitored and controlled systems. The offset term associated with the first method is referred to herein as the Alpha Term, and the offset term associated with the second method is referred to herein as the Beta Term.
The autofan control function may operate in one of two modes. The first mode may be a linear autofan control function mode. The second mode may be a piecewise linear autofan control function mode, as described in U.S. application Ser. No. 10/440,745 titled “Piecewise Linear Control of the Duty Cycle of a Pulse Width Modulated Signal” filed on May 19, 2003, invented by Eileen M. Marando and Robert W. Schoepflin, and which is hereby incorporated by reference as though fully and completely set forth herein. The first set of embodiments described herein are in relation to the linear autofan control function mode, followed by a description of one set of embodiments configured to operate for both the linear autofan control function mode and the piecewise linear autofan control function mode. The autofan controller may also feature an operating mode that allows the controlled fans to run at a minimum speed when temperature is below the minimum temperature for a currently selected zone, and an operating mode in which the fan may be turned off when the temperature is below the minimum temperature.
Linear Autofan Control Function Mode
In one embodiment, CZLB 170 is configured to operate PCLB 110 to calculate the PWM duty cycle based on the duty cycle calculated for Zone 1 only, with an adjustment factor from the duty cycle calculated for Zone 2 only. For a given PWM output that is controlled by more than one zone, PWM parameters such as PWMmin and PWMmax, shown as levels 302 and 304, respectively, in
A PWM duty cycle may be computed based on a single zone only (for example Zone 1) according to the following equations:
PWM=PWMmin+ΔPWM(z1), (1)
where
ΔPWM(z1)=ΔT(z1)*(PWMmax−PWMmin)/Trange(z1), (2)
and
ΔT(z1)=Tcurrent(z1)−Tmin(z1), (3)
where “z1” indicates that a featured parameter corresponds to Zone 1. Similarly, “z2” and “z3” indicate that a featured parameter corresponds to Zone 2 and Zone3, respectively. In other words, each time a PWM duty cycle is calculated, the PWM duty cycle may be determined by calculating ΔPWM based on the current temperature for the zone and adding ΔPWM to the min PWM (PWMmin) for the zone. The value of ΔPWM may be between PWMmin and PWMmax on the autofan curve as shown in
In one embodiment, the ΔPWM factor for Zone 1 is used to weigh the ΔPWM for Zone 2, which is added to the calculated PWM duty cycle for Zone 1. Therefore, the magnitude of the ΔPWM value may be a measure of the added contribution to the PWM for Zone 1 of the PWM calculated for Zone 2. That is, the higher the temperature in Zone 1, the greater contribution the Zone 2 term may make to the PWM for Zone 1. Again, while calculations are described for Zone 1 and Zone 2, alternate embodiments may perform similar calculation based on different zones and/or combination of zones.
In one embodiment, a PWM output calculated using a combination of zones is expressed as:
PWM=PWM(z1 only)+Offset, (4)
where the Offset value may be determined by
If (AlphaTerm>BetaTerm) then Offset=AlphaTerm else Offset=Beta Term. (5)
The Alpha Term may be a value computed by taking a fraction of the change in duty cycle that was computed for Zone 1 (only) as a function of the change in duty cycle computed for Zone 2 (only). This relationship may be expressed in the equation:
Alpha Term=α(ΔPWM(z1))*ΔPWM(z2). (5.1)
The PWM value may then be expressed as:
PWM=PWMmin+ΔPWM(z1)+Alpha Term (6)
where ΔPWM(z1) is defined in equations (2) and (3), and ΔPWM(z2) may similarly be defined in equations:
ΔPWM(z2)=ΔT(z2)*(PWMmax−PWMmin)/Trange(z2), (7)
where
ΔT(z2)=Tcurrent(z2)−Tmin(z2). (8)
As indicated in equation (5.1), the Alpha Term includes a scaling factor α (i.e. ½, ¼, ⅛, etc.). As previously mentioned, α(ΔPWM(z1)) is based on the ΔPWM duty cycle calculated for Zone 1 and in effect “weights” the amount of the ΔPWM duty cycle calculated for Zone 2. The Alpha term may be added to the ΔPWM duty cycle calculated for Zone 1 to obtain the PWM duty cycle value calculated based on a combination of zones. In one embodiment α is a programmable value, and Table 1 provides a set of possible values for α with corresponding operations that may be performed in one set of embodiments of CZLB 170 and PCLB 110. Calculation of the Alpha Term may be implemented by multiplying ΔPWM(z1) and ΔPWM(z2)—which would yield a 16 bit result in case of an 8-bit by 8-bit multiplication. The α factor may then be viewed a scaling factor for the product of ΔPWM(z1) and ΔPWM(z2), resulting in a programmable shift of the 16-bit result. In one embodiment, options for α are: 1, ½, ¼, ⅛, 1/16, 1/32, 1/64, 1/128, 1/256, and zero for canceling the Alpha Term. In one set of embodiments the value of the Alpha Term ranges from 0h (hexadecimal value) to 255h, that is, if the Alpha Term calculates to a value greater than 255h it will be limited to 255h.
A value for α may be selected and/or configured based on, for example, the desired effect of ambient temperature on the final value of a selected PWM output. In one set of embodiments values for α may be determined by trial-and-error based on measurements taken of the effects of temperature changes in each zone on the system.
In one embodiment, the Beta Term is a value computed by taking a fraction of the change in PWM duty cycle computed for Zone 2 only, and may be expressed as:
BetaTerm=β(ΔPWM(z2)), (9)
where, similar to α in equation (6), β is a scaling factor that may also be programmable. Values for β may be selected and/or configured based on the same methods used to select values for α. In one embodiment, the programmable shift of the PWM duty cycle for Zone 2 (Beta Term) is compared with the calculated adjustment factor from the duty cycle for Zone 2 (Alpha Term), selecting the largest one as a final adjustment factor. The final PWM output may then be expressed as:
PWM=PWMmin+ΔPWM(z1)+ΔPWMvalue, (10)
where ΔPWMvalue is determined based on equation (5), such that
if α(ΔPWM(z1))*ΔPWM(z2)>β(ΔPWM(z2)) then (11a)
ΔPWMvalue=α(ΔPWM(z1))*ΔPWM(z2), (11b)
and if
α(ΔPWM(z1))*ΔPWM(z2)≦β(ΔPWM(z2)) then (12a)
ΔPWMvalue=β(ΔPWM(z2)). (12b)
A set of possible values for β is presented in Table 2, with corresponding operations that may be performed in one set of embodiments of CZLB 170 and PCLB 110.
Piecewise-Linear Autofan Control Function Mode
Equation (6) may be expanded to encompass both linear and piecewise-linear autofan control functions:
PWM=PWMmin(current—z1_seg)+ΔPWM(current—z1_seg)+α(ΔPWM(z1_total))*ΔPWM(z2_total); (13)
where
ΔPWM(current—z1_seg)=ΔT(current—z1_seg)*(PWMmax(current—z1_seg)−PWMmin(current—z1_seg)/Trange(z1); (14)
ΔPWM(z1_total)=(PWMmin(current—z1_seg)−PWMmin(z1_seg1))+ΔPWM(current—z1_seg); (15)
ΔPWM(z2_total)=(PWMmin(current—z2_seg)−PWMmin(z2_seg1))+ΔPWM(current—z2_seg); (16)
ΔT(current—z1_seg)=Tcurrent(z1)−Tmin(current—z1_seg); (17)
ΔT(current—z2_seg)=Tcurrent(z2)−Tmin(current—z2_seg); (18)
and
ΔPWM(current—z2_seg)=ΔT(current—z2_seg)*(PWMmax(current—z2_seg)−PWMmin(current—z2_seg)/Trange(z2). (19)
As in equation (6), α in equation (13) is a scaling factor that may take on values of ½, ¼, ⅛, etc, as shown in Table 1. In addition, α(ΔPWM(z1_total)) is based on the ΔPWM duty cycle calculated for Zone 1, and “weights” the amount of the ΔPWM duty cycle calculated for Zone 2. α(ΔPWM(z1_total))*ΔPWM(z2_total) is referred to again as the Alpha Term and may be added to the ΔPWM duty cycle value calculated for Zone 1 to obtain the PWM duty cycle value calculated based on a combination of zones. PWMmax represents the maximum value of PWM. In one set of embodiments, the maximum value of the Alpha Term for the piecewise-linear autofan control function is 255h (255 hexadecimal), that is, if the Alpha Term calculates to a value greater than 255h it will be limited to 255h.
In equations (13)–(19), “(current_z1_seg)” indicates that the value for a given parameter, such as PWMmin and ΔT, corresponds to the temperature segment (as shown in
A Beta Term for the piecewise-linear autofan control function may be defined similarly to the linear autofan function and expressed as:
Beta Term=β(ΔPWM(z2_total)). (20)
Values for β, a scaling factor, may be selected as previously shown in Table 2.
In one embodiment, similar to the linear autofan control function, the programmable shift of the PWM duty cycle for Zone 2 (Beta Term) is compared with the calculated adjustment factor from the duty cycle for Zone 2 (Alpha Term), selecting the largest one as a final adjustment factor. Equation (10) may be re-written for the piecewise-linear autofan control function as follows:
PWM=PWMmin(current—z1_seg)+ΔPWM(current—z1_seg)+ΔPWMvalue, (21)
where ΔPWMvalue is determined based on equation (5), such that
if α(ΔPWM(z1_total))*ΔPWM(z2_total)>β(ΔPWM(z2_total)) then (22a)
ΔPWMvalue=α(ΔPWM(z1_total))*ΔPWM(z2_total), (22b)
and
if α(ΔPWM(z1_total))*ΔPWM(z2_total)≦β(ΔPWM(z2_total)) then (23a)
ΔPWMvalue=β(ΔPWM(z2_total)). (23b)
As previously stated, in one set of embodiments the autofan controller may be programmed to allow the fans to run at a minimum speed when the current measured temperature falls below a minimum temperature limit for a respective zone (T<Tmin). In an alternate set of embodiments, the autofan controller may be programmed to turn off the fans (that is, set PWM=0) when T<Tmin. In one embodiment, if β is enabled and the autofan controller is programmed to allow the fans to run at minimum speed when T<Tmin, the PWM duty cycle at T<Tmin is set to the programmed minimum PWM duty cycle plus the Beta Term. Similarly, if β is enabled and the autofan controller is programmed to turn off the fans when T<Tmin, the PWM duty cycle at T<Tmin may be set to “off”, unless T was within a programmed hysteresis temperature range.
In the embodiments described above a single PWM value corresponding to a PWM output was used as a single control value to control a fan. Alternate embodiments may employ other fan control mechanisms in which the single control value may be other than a single PWM value corresponding to a PWM output. For example, in one set of embodiments the single control value may be a single analog voltage value. In other embodiments the single control value may correspond to an alternate preferred mechanism used to control the fan, and may be other than a single PWM value or a single analog voltage value.
Having thus described the invention and the manner of its use, a system and method was presented for controlling a fan through a single control signal value calculated based on sensor data received from two or more temperature zones. Although the embodiments above have been described in considerable detail, other versions are possible. Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended that the following claims be interpreted to embrace all such variations and modifications. Note the section headings used herein are for organizational purposes only and are not meant to limit the description provided herein or the claims attached hereto.
Number | Name | Date | Kind |
---|---|---|---|
4530395 | Parker et al. | Jul 1985 | A |
4722669 | Kundert | Feb 1988 | A |
4727468 | Maekawa | Feb 1988 | A |
5249741 | Bistline et al. | Oct 1993 | A |
5271558 | Hampton | Dec 1993 | A |
5307439 | Enami | Apr 1994 | A |
5379606 | Katsuki et al. | Jan 1995 | A |
5511724 | Freiberger et al. | Apr 1996 | A |
5687079 | Bauer et al. | Nov 1997 | A |
5727928 | Brown | Mar 1998 | A |
5825972 | Brown | Oct 1998 | A |
5942866 | Hsieh | Aug 1999 | A |
5962933 | Henderson et al. | Oct 1999 | A |
5990582 | Henderson et al. | Nov 1999 | A |
6182902 | Shih | Feb 2001 | B1 |
6188189 | Blake | Feb 2001 | B1 |
6208538 | Halamik et al. | Mar 2001 | B1 |
6226324 | Allstrom | May 2001 | B1 |
6247898 | Henderson et al. | Jun 2001 | B1 |
6262549 | Yang et al. | Jul 2001 | B1 |
6519167 | Nguyen | Feb 2003 | B1 |
6528987 | Blake et al. | Mar 2003 | B1 |
6563284 | Teutsch et al. | May 2003 | B1 |
6601168 | Stancil et al. | Jul 2003 | B1 |
6650074 | Vyssotski et al. | Nov 2003 | B1 |
6661679 | Yang et al. | Dec 2003 | B1 |
20030193307 | Burstein | Oct 2003 | A1 |
20040001542 | Miller, Jr. | Jan 2004 | A1 |
Number | Date | Country | |
---|---|---|---|
20050156544 A1 | Jul 2005 | US |