1. Field of the Invention
This invention pertains to piezoelectric elements, and particularly to circuits and methods for driving piezoelectric elements utilized in such devices such as pumps, for example.
2. Related Art and Other Considerations
A piezoelectric element is a crystalline material which produces an electric voltage when subjected to mechanical pressure. In view of their various properties, piezoelectric elements have been used as actuators in diaphragm displacement pumps. In general, piezoelectric actuators of the type used in pumps require excitation by a regularly reversing high-voltage field. Depending on the application, the excitation voltage may be anywhere from 25 to 1000 volts or more and the frequency of field reversal may be anywhere from a fraction of a cycle per second to thousands of cycles per second. Typically, this excitation signal must be derived from a relatively low-voltage source of 1.5-25 volts. It is desirable that this derivation or conversion be very energy efficient and that the associated components be inexpensive.
In addition, given that both the piezoelectric actuators and the devices that employ them often have many resonant characteristics, it is desirable for the field reversal to be monotonic—e.g., a sine wave.
An example of a reasonably effective drive circuit for driving piezoelectric elements used as pump actuators is disclosed in U.S. patent application Ser. No. 10/380,547 and U.S. patent application Ser. No. 10/380,589 (both filed Mar. 17, 2003, both entitled “Piezoelectric Actuator and Pump Using Same”, and both incorporated by reference herein in their entirety). That drive circuit comprises a EL lamp driver circuit which was originally designed to drive electro-luminescent (EL) lamps, but which has now ingeniously been employed in the referenced documents for driving piezoelectric pumps. The EL lamp driver circuit is a high-powered, switch-mode integrated circuit (IC) inverter intended for backlighting color LCDs and automotive applications. The specially designed EL lamp driver IC and a few components such as a discharge circuit comprise a complete EL lamp driving circuit.
Described in more detail, the EL lamp driver circuit uses a relatively high frequency oscillator or state-machine to drive a flyback circuit to produce high-voltage charges that are stored in a storage capacitor. The storage capacitor is then treated as a high-voltage source of direct current which is applied to a bridge-type switching circuit that is driven by either a second oscillator or state-machine or a signal derived from the flyback oscillator to produce a reversing field effect.
These EL lamp driver circuits have been widely employed in the electroluminescent lighting industry and consequently many of the circuit elements have been integrated into “one-chip” solutions. This EL lamp driver technology/circuitry has evolved to drive the displays of handheld electronic devices such as cell phones, Personal Digital Assistants (PDAs) and electronic games. The circuits can operate at low frequency and current draw, and at relatively high frequencies, making them very attractive for portable applications. Moreover, equipped with a discharge circuit design, the EL circuit minimizes EL lamp system noise, i.e., noise that would affect the operation of other integrated circuits or chips.
Despite its overall ingenious and overall beneficial utilization in piezoelectric pumps, some aspects of using a EL lamp driver circuit are problematic. Several example problems are now briefly described.
As a first example problem, the EL lamp driver is limited in that it operates only at a fixed frequency once installed. The oscillators and/or state machines used in EL lamp drivers are fixed. The EL lamp driver circuits are “Mona Lisa's”—each circuit having a fixed flyback frequency. As a result, when used in a piezoelectric pump, the EL lamp driver circuit provides a fixed piezoelectric drive frequency and a fixed output voltage to input voltage/load ratio. When used in a piezoelectric pump, the EL lamp driver circuits are essentially irrevocably “tuned” to a specific piezoelectric application by varying component values at the time of manufacture.
As a second example problem, the output wave form of the EL lamp driver circuit is a modified sawtooth which creates audible noise in the piezo even under load (due to the sharp peak on the waveform output by the EL lamp driver circuit). This is due, in part, to the architecture of the EL lamp driver circuit which employs a crude, somewhat direct current source. This current source is digitally switched by a bridge circuit to produce the reversing field, so that the resulting drive waveform is far from pure. Square waves and sawtooths are common with ragged, time-varying frequency content signals being typical. But non-audio applications piezoelectric actuators and the devices that employ them typically need to operate at pure frequencies for maximum efficiency and to produce the least amount of audible noise. So when a drive waveform is applied that has frequency content outside of the targeted fundamental drive frequency, that extraneous frequency content adds little to the work output of the piezoelectric element but greatly increases undesirable actuator audible noise.
As a third example problem, the only variable user input to the EL lamp driver circuit is the voltage input (Vin). As such, the current drive circuits do not have means for accepting external control inputs or monitoring local actuator related parameters. Capabilities such as resonance detection, pressure feedback, temperature feedback, external modulation, etc. were not heretofore contemplated for drive circuits for a piezoelectric actuator in a pump environment.
The EL lamp driver architecture employs a unipolar voltage source to drive the piezoelectric actuator in bipolar fashion. Given this fact, it is unavoidable that both “sides” of the piezoelectric actuator are subjected to voltage potentials other than system ground. In applications such as a pump which pumps a conductive liquid, it is highly desirable that the fluid side of the actuator always remain at system ground. This cannot be achieved using the EL lamp driver circuitry.
What is needed, therefore, and an object of the present invention, is a piezoelectric actuator drive circuit which overcomes one or more of the foregoing problems and deficiencies.
A drive circuit produces a drive signal for a pump having a piezoelectric actuator, with the piezoelectric actuator forming a part of the drive circuit and serving to shape a waveform of the drive signal. The piezoelectric actuator essentially serves as a charge storage device for a power supply for the drive circuit. The drive circuit comprises a pulse generator which generates digital pulses; a converter circuit which uses the low voltage, long period digital pulses generated by the pulse generator to produce high voltage, shorter period pulses (charge packets); and, the piezoelectric actuator. The piezoelectric actuator, by its capacitive nature, integrates the charge packets to shape the waveform of the drive signal. Thus the shape for the waveform is influenced by the digital pulses produced by the pulse generator and the capacitance of the piezoelectric actuator. The piezoelectric actuator integrates the charge packets to yield a drive field that preferably approximates a sine wave. While the capacitance of the piezoelectric actuator is essentially fixed, by controlling the generator pulses (e.g., varying a pulse width modulation duty cycle) on a pulse by pulse basis, waveforms of arbitrary complexity can be produced. The drive circuit together with the piezoelectric element facilitates the integration of the high frequency charge packets into a lower frequency drive waveform of any desired wave shape.
In one non-limiting example embodiment, the pulse generator comprises a microcontroller-based pulsed width modulator (PWM) circuit and the converter circuit comprises a flyback circuit. The flyback circuit produces potentials that are bipolar with respect to an electrical ground. Preferably, the frequency of the charge packets produced by the converter circuit is greater than the ability of the piezoelectric actuator to mechanically respond so that the charge packets produced by the converter circuit do not contribute to one of mechanical inefficiency and noise in the piezoelectric actuator. Advantageously, neither a bridge converter circuit nor a charge storage circuit need be connected between the converter circuit and the piezoelectric actuator.
Another aspect of the invention are pumps which incorporate or utilize the drive circuit. Such a pump typically comprises a pump body for at least partially defining a pumping chamber and an inlet and an outlet which communicate with the pumping chamber. The piezoelectric actuator is situated in the pump body and is responsive to a drive signal for pumping fluid between the inlet and outlet. The drive circuit produces the drive signal for the piezoelectric actuator. The drive circuit comprises a pulse generator which generates digital pulses, as well as a converter circuit which uses the digital pulses generated by the pulse generator to produce short period, high voltage pulses (charge packets). The piezoelectric actuator also forms part of the drive circuit. The piezoelectric actuator integrates the charge packets to shape a waveform of the drive signal.
As another aspect, the invention encompasses methods of operating a piezoelectric pump. An example such pump has a piezoelectric actuator situated in a pump body and responsive to a drive signal for pumping fluid between an inlet and an outlet of the pump body. The method comprises generating low voltage, long period digital pulses; using the digital pulses to produce high voltage, short period pulses (charge packets); and, using the piezoelectric actuator to integrate the charge packets to shape a waveform of the drive signal.
The foregoing and other objects, features, and advantages will be apparent from the following more particular description of preferred embodiments as illustrated in the accompanying drawings in which reference characters refer to the same parts throughout the various views. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention.
In the following description, for purposes of explanation and not limitation, specific details are set forth such as particular architectures, interfaces, techniques, etc. in order to provide a thorough understanding of the present invention. However, it will be apparent to those skilled in the art that the present invention may be practiced in other embodiments that depart from these specific details. In other instances, detailed descriptions of well-known devices, circuits, and methods are omitted so as not to obscure the description of the present invention with unnecessary detail. Moreover, individual function blocks are shown in some of the figures. Those skilled in the art will appreciate that the functions may be implemented using individual hardware circuits, using software functioning in conjunction with a suitably programmed digital microprocessor or general purpose computer, using an application specific integrated circuit (ASIC), and/or using one or more digital signal processors (DSPs). Captions or textual headings appearing in this detailed description do not define or limit the invention(s) described herein in anyway, but are merely inserted for possible convenience of the reader.
1.0 Representative Piezoelectric Pump Structure
The example pump 10 of
A pump chamber 30 is formed in the center of the pump body 12, for example by molding or machining. The dimensions of pump 10, and hence the dimensions of pump chamber 30, depend on the particular application. A seat 32 is provided in pump body 12 at the top of the pump chamber 30. As shown in
In one illustrated embodiment, piezoelectric actuator 14 can take the form of a piezoelectric wafer laminated to/between one or more ruggedizing layers (e.g., metal layers). An example such piezoelectric actuator is illustrated in U.S. patent application Ser. No. 10/380,547 and U.S. patent application Ser. No. 10/380,589 (both filed Mar. 17, 2003, both entitled “Piezoelectric Actuator and Pump Using Same”, and both incorporated by reference herein in their entirety). However, the drive method and drive circuit disclosed herein is not confined to any particular type of piezoelectric actuator.
As mentioned above, structural aspects of the example pump as illustrated in
The piezoelectric actuator drive circuit 18 is preferably but not necessarily embodied in an electronic printed circuit board (PCB). The piezoelectric actuator drive circuit 18 can take many distinct forms or embodiments and have many distinct modes of operation, with some of the embodiments and modes being implemented in conjunction with other embodiments and modes (e.g., some embodiments/modes can be combined to realize yet other embodiments and modes).
2.0 Example Embodiments of Drive Circuits
General non-limiting examples of the piezoelectric actuator drive circuit 18 are illustrated in
2.1 Drive Circuit Providing Digital Pulses
As shown in simplified form in
2.2 Drive Circuit Receiving Feedback Signal
As an aspect of its operation, the piezoelectric actuator 14 actually serves as part of piezoelectric actuator drive circuit 18. By virtue e.g., of its capacitance, piezoelectric actuator 14 integrates the short period pulses (charge packets) which are output by converter circuit 102 as the drive signal on line 104. In view of the integration of drive signal on line 104, the drive signal on line 104 actually acquires the general shape of a sine wave. Thus, piezoelectric actuator 14 contributes to shaping the waveform (e.g., drive signal applied on line 104) of the piezoelectric actuator drive circuit 18.
The converter circuit 102 receives digital pulses from the pulse generator 100 and generates a stream of high voltage, short period pulses (charge packets) on line 104. In an illustrated example embodiment, the digital pulses applied to converter circuit 102 from pulse generator 100 have a pulse width modulation and a period or cycle which affects the amplitude and the period of the sine wave waveform which results as the drive signal on line 104. For sake of basic illustration,
2.3 Drive Circuit Receiving Analog Input Signal
2.4 Drive Circuit Receiving Digital Input Signal
2.5 Drive Circuit Receiving Input Signal from Sensor in Utilization Device
2.6 Drive Circuit Receiving Input Signal from Sensor Elsewhere in/on Utilization Device
Whereas
2.7 Drive Circuit Receiving Input Signal from Sensor Internal to Served Device
2.8 Drive Circuit Receiving Input Signal from Sensor Proximate Served Device
2.10 Drive Circuit Operating in Conjunction with Delivery Scheduler
FIG. 3H(1) shows an embodiment/mode of piezoelectric actuator drive circuit 18G which works in conjunction with a delivery scheduler 160. By receiving input from the delivery scheduler 160, the piezoelectric actuator drive circuit 18G controls non-continuous operation of the piezoelectric actuator 14. For example, the delivery scheduler 160 may either control or supply piezoelectric actuator drive circuit 18G with information for the timing of application of a drive signal on line 104 to piezoelectric actuator 14. The delivery scheduler 160 can but does not have to be utilized in embodiments which receive feedback on line 105, for which reason line 105 is shown as a broken line in FIG. 3H(1).
The logic and operation of delivery scheduler 160 can be varied from application to application. For example, delivery scheduler 160 may direct piezoelectric actuator drive circuit 18G to supply a drive signal for one or more finite time periods (e.g., in response to external stimuli or signal to delivery scheduler 160 or to piezoelectric actuator drive circuit 18G). One example scenario for such finite delivery involves driving piezoelectric actuator 14 in a pump for delivering or dosing fluid (e.g., medication) in accordance with a prescribed flow and/or volume amount.
Alternatively, delivery scheduler 160 may apprise piezoelectric actuator drive circuit 18H of certain sensed conditions which are to be monitored either to initiate or to terminate the drive signal on line 104 to piezoelectric actuator 14. For example, through delivery scheduler 160 the piezoelectric actuator drive circuit 18H may be instructed to apply the drive signal to piezoelectric actuator 14 and thus turn on the utilization device incorporating the same when a temperature (e.g., of a fluid) is detected to be outside a predefined temperature range.
The delivery scheduler 160 can be implemented in various ways. For example, logic for the delivery scheduler 160 can be included in a microprocessor of the digital pulse generator and accessed through a graphical user interface or other input device. Alternatively, the delivery scheduler 160 may be a separate processor or computer as understood with reference to
In yet further embodiments/modes, generically illustrated by FIG. 3H(2), the delivery scheduler 160 may include a remote unit 162 which is connected to digital pulse generator 100 through an appropriate communication channel 164. For example, the communication channel 164 may be a wireless network, in which case both the delivery scheduler 160 and the remote unit 162 include a wireless station (e.g., laptop with mobile termination, cell phone, Bluetooth unit, etc.) so that a user may send programming information (e.g., drive signal start and/or stop times) to delivery scheduler 160 over an air interface (e.g., radio frequency or other electromagnetic spectra).
As another example, the remote unit may be a browser and the communication channel 164 can comprise a packet network such as the Internet, for example. In such example, either the piezoelectric actuator drive circuit 18H or the utilization device itself may have its own internet or network address.
Using either of these or other implementations, through the remote unit a user can input data to delivery scheduler 160 so that the delivery scheduler 160 can control the timing of application and cessation of the drive signal to the piezoelectric actuator 14.
2.11 Drive Circuit Driving Plural Actuators
FIG. 3I(1)-FIG. 3I(3) show embodiments/modes of piezoelectric actuator drive circuits 18I(1)-18I(3) which serve plural piezoelectric actuators. Distinctive elements of FIG. 3I(x) bear a corresponding “x” parenthetical suffix, and for each FIG. 3I(x) the piezoelectric actuator drive circuit 18I(x) serves plural piezoelectric actuators 14(x)y, where y ranges from 1 to n. For each embodiment, the plural piezoelectric actuators 14(x)y may be incorporated in respective plural utilization devices (e.g., plural pumps 10), or even plural types of utilization devices. For example, piezoelectric actuator 14(x)1 may be included in a pump; piezoelectric actuator 14(x)2 may be included in a fan or other type (non-pump) of utilization device. Alternatively, in other embodiments the plural piezoelectric actuators may be may be utilized in a single device or system. Preferably but not necessarily the piezoelectric actuator drive circuits 18I(x) comprise a separate converter circuit 102(x)y for each of the plural piezoelectric actuators 14(x)y.
In the embodiment/mode of FIG. 3I(1) the same PWM-A and PWM-B digital pulses generated by pulse generator 100 are applied to the converter circuits 102(1)1 and 102(1)n associated with the separate piezoelectric actuators 14(1)1 and 14(1)n, respectively. The embodiment/mode of FIG. 3I(1) is particularly suitable when the plural piezoelectric actuators 14(x)y function in parallel and/or in time synchronization.
In the embodiment/mode of FIG. 3I(2), the pulse generator 100(2) produces different PWM-A and PWM-B digital pulses for at least two of the converter circuits 102(2)y, so that the plural piezoelectric actuators 14(2)y are driven differently. The embodiment/mode of FIG. 3I(2) is particularly beneficial when the feedback signals on line 105(2)y or other input signals (e.g., sensor input signals as described, e.g., with reference to
If desired, input signals for the piezoelectric actuator drive circuits 18I(x) can be obtained from one or more analog input devices or one or more digital input devices (e.g., sensors) as understood from the preceding discussion, so that (in addition to serving plural piezoelectric actuators 14(x)y) the piezoelectric actuator drive circuits 18I(x) can take on attributes of any of the previously described embodiments.
2.12 Drive Circuit Receiving Analog and Digital Input Signals
3.0 Example Drive Circuit Implementation
Subsequent generic reference herein to a drive circuit, or to a piezoelectric actuator drive circuit (such as piezoelectric actuator drive circuit 18), can refer to one or more types of piezoelectric actuator drive circuits, such as those types of drive circuits which have been generally described above. Reference to a drive circuit, or to a piezoelectric actuator drive circuit (such as piezoelectric actuator drive circuit 18), is not constrained or limited by the examples herein provided.
3.1 First Example Drive Circuit: Structure
In the example embodiment of
In the non-limiting example embodiment of
In an illustrated, non-limiting embodiment, pulse generator 100 is shown as including a microcontroller 116. It should be understood that pulse generator 100 may comprise one or more microcontrollers or processors and/or other circuits. In addition, certain operations or functionalities herein ascribed to microcontroller 116 can also be considered to be performed by one or more processors, including but not limited to a microprocessor which comprises microcontroller 116. In this regard, for example, in the embodiments/modes of FIG. 3I(2) and FIG. 3I(3), the pulse generators 100(2) and 100(3) may include plural or even y number of microcontrollers for controlling the respective y number of piezoelectric actuators 14(x)y. Alternatively, the pulse generators 100(2) and 100(3) for the embodiments/modes of FIG. 3I(2) and FIG. 3I(3) may include a suitable microcontroller with multitasking capability and differing output pin arrangement for driving the y number of piezoelectric actuators 14(x)y.
The piezoelectric actuator drive circuit 18 is connected to a power supply 20103. The piezoelectric actuator drive circuit 18 comprises a power supply monitor 118. The power supply monitor 118 includes an input voltage divider network 119 (which comprises resistors R1 and R2 connected in series between power supply 103 and ground); input capacitance C1 connected between power supply 103 and ground; and, voltage input regulator 120. The voltage divider network formed by resistors R1,R2 serves to generate an analog input to microcontroller 116 (applied at pin 18) for monitoring the input supply voltage. This allows microcontroller 116 to make adjustments via software to maximize the overall circuit performance for varying supplies. Capacitor C1 filters the main supply from power supply 103. The voltage input regulator 120 has an input terminal connected to pulse generator 100, and an output terminal connected to pin 15 of microcontroller 116.
Advantageously, the piezoelectric actuator drive circuit 18 can receive inputs including user input and external sensor input. To this end, two example user input devices 106 and 108 in the form of respective potentiometers (trimpots) R8 and R9 are connected between pins 17 of microcontroller 116 and ground. A greater or lesser number of user input devices can be provided. A connector 110 has leads connected to certain pins of microcontroller 116. As explained above, some of the pins in connector 110 may be connected to a source (such as a computer or one or more sensors) which produces signals which may be utilized by microcontroller 116 in shaping the waveform of the drive signal applied on line 104. The number of such external sensors can be variable in accordance with user desire and/or application or environment of use of pump 10.
An output monitor 122 in the form of a feedback voltage division network (which comprises resistors R6 and R7) is connected between the drive signal applied on line 104 and ground. A node of the feedback voltage division network between resistors R6 and R7 is connected to pin 19 of microcontroller 116.
As understood from the foregoing, the pulse generator 100 can be a microcontroller. Yet the pulse generator 100 can also be any ASIC or any other device or circuit which generates pulses suitable for use by flyback circuit 102 and piezoelectric actuator 14 for the general purposes herein described. In the illustrated, non-limited example embodiment, the pulse generator 100 is a microcontroller 116 such as an ATTINY26L microcontroller.
Pin connections for the microcontroller 116 of the illustrated embodiment are now briefly described. Pins 1, 2, 3 and 4 serve double duty as in-circuit programming pins and the functions described below. For example, pins 2 & 4 are the outputs of a software-controlled pulse width modulator embodied in microcontroller 116 and are used to drive flyback circuit 102. In particular, a signal PWM-A is output from pin 2 on line 124 to flyback circuit 102; a signal PWM-B is output from pin 4 on line 126 to flyback circuit 102. The pulse width-modulated signal PWM-A comprises positive digital pulses such as those shown in
Pins 2 & 3 provide for a 2-wire serial interface buss 128 to microcontroller 116 for communications with other systems (for example, via buss 128 an array of pumps can be remotely controlled by another system such as a desktop computer). Pin 5 is connected to an output terminal of voltage input regulator 120 and to a filter “bypass” capacitor C2. Pins 7, 8, 9, 11, 12, and 20 are general purpose input/output pins that provide for external analog and/or digital communications so that various things such as temperature or pressure sensors can be attached to the pump to control its operation. Pins 13 & 14 are the input signals from user input device 108 and user input device 106, respectively. Pin 17 provides access (e.g., for user input device 106 and user input device 108) to the analog reference bandpass reference voltage of microcontroller 116. Capacitor C3 connected between pin 17 and ground is a bypass capacitor for the analog reference voltage for the analog to digital converter of microcontroller 116. Pin 18 is the analog input from power supply monitor 103, and is connected to a node between resistor R1 and resistor R2 of input voltage divider network 119. Pin 19 is the analog input for the output monitor 122 and is connected to a node between resistor R6 and resistor R8 of the voltage division network which comprises output monitor 122.
The flyback circuit 102 comprises transistor Q1, transistor Q2, transistor Q3, and transistor Q4. In the illustrated embodiment, the transistors are metal oxide semiconductor field effect transistors (MOSFET). The pulse width modulated signal PWM-A output from pin 2 of microcontroller 116 is applied on line 124 and via capacitor C4 to the gate of transistor Q1; the pulse width modulated signal PWM-B output from pin 4 of microcontroller 116 is applied on line 126 to the gate of transistor Q2. A resistor R10 connected between line 126 and ground serves as a pull down to increase noise immunity.
The source of transistor Q1 is connected by line 130 to power supply 103. The drain of transistor Q2 is connected by line 132 and through inductor L2 to power supply 103. The source of transistor Q2 is connected to ground.
Resistor R3 and diode D1 are connected between lines 124 and 130. Capacitor C4, resistor R3, and diode D1 serve to bias the output of microcontroller 116 up to one microcontroller output voltage level below the main supply voltage so that microcontroller 116 can turn transistor Q1 on and off even when the main supply voltage greatly exceeds the supply voltage of microcontroller 116.
The drain of transistor Q1 is connected to ground through inductance L1 and to an cathode of diode D2. The cathode of diode D2 is connected both to ground through snubber capacitor C5 and to the emitter of transistor Q3. The drain of transistor Q3 is connected through resistor R4 to ground. The collector of transistor Q3 is connected to the piezoelectric actuator 14 via line 104.
The emitter of transistor Q4 is connected by line 132 and through inductor L2 and diode D3 to power supply 103. The anode of diode D3 is connected to inductor L2 and to the drain of transistor Q2. The cathode of diode D3 is connected to ground through snubber capacitor C6 and to the emitter of transistor Q4. The gate of transistor Q4 is connected through resistor R5 to line 132. The collector of transistor Q3 is connected to piezoelectric actuator 14 via line 104.
Transistor Q1, transistor Q2, inductor L1, inductor L2, diode D2, and diode D3 are the primary components for generating the positive and negative high voltage flyback pulses as described above. The capacitors C5 and C6 are “snubber” capacitors which bring the fundamental frequency component of the flyback pulses within the frequency response capability of control transistors Q3 & Q4.
Transistor Q3, transistor Q4, resistor R4, and resistor R5 form a steering circuit for the flyback voltage, preventing charge cross-conduction that would otherwise render the circuit dysfunctional.
Resistors R6 and R7 form a voltage divider for output monitor 122, and serve to allow microcontroller 116 to monitor the output voltage and thus regulate the drive voltage. Regulation of the drive voltage is accomplished by microcontroller 116 varying the pulse widths W of the pulse bursts applied as PWM-A on line 124 and as PWM-B applied on line 126 (see
3.2 First Example Drive Circuit: Operation
In operation, the pulse generator 100 (e.g., microcontroller 116) of piezoelectric actuator drive circuit 18 generates output pulses. Specifically, in the embodiment illustrated in
The flyback circuit 102 is driven by the signals PWM-A and PWM-B which are generated by microcontroller 116. In the illustrated embodiment, the signals PWM-A and PWM-B are variable frequency pulse trains at a frequency of 125 KHz. In typical operation of a pump being driven at say 60 Hz, for the first half cycle a burst of pulses lasting approximately 1/120 of a second would be sent on line 124 as PWM-A while the signal for PWM-B on line 126 is held at ground (turning transistor Q2 “off”). Examples of the series of digital pulses applied as PWM-A on line 124 are shown in
As explained herein after, the pulse width of the digital pulses applied as signal PWM-A on line 124 and as signal PWM-B on line 126 can be controlled by microcontroller 116 in accordance with one or more factors. For example, the excitation voltage and the reversal frequency can be dynamically manipulated based on either external control signals or on parameters being monitored locally such as actuator load, actuator resonance, pump pressure, temperature, etc. In addition, in one example mode, the period P of the signals PWM-A and PWM-B can be adjusted if desired as hereinafter discussed.
The PWM-A digital pulses applied from microcontroller 116 on line 124 to flyback circuit 102 cause transistor Q1 to switch on and off. When on, transistor Q1 causes magnetic flux to be stored in inductor L1. Immediately after transistor Q1 turns off, the stored flux causes a negative “flyback” voltage to be generated which is captured by diode D2 and capacitor C5, forcing transistor Q3 into conduction and thus the captured charge is further distributed to pump 10 and to piezoelectric actuator 14 in particular.
At the end of the first half cycle, e.g., at the end of the 1/120 second period, the signal PWM-A on line 124 is held high (turning transistor Q1 off) and an identical series of drive pulses is sent as signal PWM-B on line 126 to transistor Q2, generating a series of positive flyback pulses from inductor L2. These flyback pulses are fed to pump 10 via diode D3, capacitor C6, and transistor Q4. These positive pulses first serve to discharge the negative charge in the pump in a controlled fashion and then build a positive charge in the pump.
Thus, the pulse generator 100 applies digital pulses to flyback circuit 102. Flyback circuit 102 receives the digital pulses and produces charge packets (e.g., 35). The charge packets output by converter circuit 102 on line 104 appear essentially in a manner comparable to those illustrated in
The repeating flyback or charge packets applied on line 104 build a charge in the pump's capacitance, i.e., in piezoelectric actuator 14, resulting in the signal on line 104 taking the form of a voltage curve approximating a sine wave. In other words, the piezoelectric actuator is used to integrate the positive charge packets and the negative charge packets to shape a waveform of the drive signal. The aforedescribed period is repeated over and over, with the result that pump 10 “sees” a drive signal on line 104 that approximates a 60 Hz sine wave in the manner shown in
Thus, the flyback circuit 102 applies charge pulses, e.g., charge packets, to piezoelectric actuator 14 which are integrated by piezoelectric actuator 14 into an electric field. The piezoelectric actuator 14 converts the charge packets into a lower frequency excitation signal. In other words, by building electrical charge in piezoelectric actuator 14 (e.g., by adding more or less charge), the piezoelectric actuator 14 participates in building the waveform in the piezoelectric actuator 14. By such integration the piezoelectric actuator 14 essentially serves as a charge storage device for power supply 103. In essence, the piezoelectric actuator 14 acts much like a filter capacitance in a power supply.
The charge generating components transistor Q1, inductor L1, transistor Q2, & inductor L2 are always being driven digitally (either on or off) and are thus operating at maximum efficiency (switching power supply theory). Yet pump 10 “sees” a sine wave drive waveform. This is achieved with an absolute minimum number of parts by using the piezoelectric actuator 14 itself as the primary charge storage device in this pseudo switching power supply design.
The fastest components of the flyback signal are “snubbed” out by capacitor C5 and capacitor C6. The majority of the flyback high frequencies are filtered by the pump itself. The PWM/flyback frequency of 125 KHz is at least two orders of magnitude above the pump's ability to mechanically respond.
Thus, the piezoelectric actuator drive circuit 18 uses the pump capacitance itself, e.g., the capacitance of piezoelectric actuator 14, as an integral part of a switching-type drive supply circuit.
In an aspect of an embodiment thus far described, piezoelectric actuator drive circuit 18 can be a microcontroller-based pulsed width modulator (PWM) circuit which is used to drive a flyback circuit that very uniquely has the ability to produce potentials that are bipolar with respect to system ground. Neither a bridge switching circuit nor a charge storage circuit are employed. Instead, the flyback circuit switches between producing positive pulses and negative pulses at a rate that equals the desired drive frequency of the actuator. For circuit efficiency and EMI reduction, some of the higher frequency components of the pulses are capacitively filtered. The pulses are then passed directly to the piezoelectric actuator and are integrated by the capacitive nature of the piezoelectric actuator to yield a drive field that very nearly approximates a sine wave. The frequency of the flyback pulses is designed to be greater than the ability of the actuator to mechanically respond so that the flyback pulses do not contribute to mechanical inefficiency or noise in the actuator.
3.3 Second Example Drive Circuit: Structure
In the non-limiting example embodiment of
The drive circuit 18C can be utilized with all embodiments, including those which drive single piezoelectric actuators as well as those driving plural piezo electric actuators. Again with regard, for example, to the embodiments/modes of FIG. 3I(2) and FIG. 3I(3), the pulse generators 100(2) and 100(3) may include plural or even y number of microcontrollers for controlling the respective y number of piezoelectric actuators 14(x)y. Alternatively, the pulse generators 100(2) and 100(3) for the embodiments/modes of FIG. 3I(2) and FIG. 3I(3) may include a suitable microcontroller with multitasking capability and differing output pin arrangement for driving the y number of piezoelectric actuators 14(x)y.
The piezoelectric actuator drive circuit 18C is connected to a power supply 103. A power supply monitor, understood with reference to the previous embodiment, can also be included.
Advantageously, the piezoelectric actuator drive circuit 18C can receive inputs including user input and external sensor input. The potential inputs received by piezoelectric actuator drive circuit 18C include all those previously described in conjunction with
The pulse generator of the piezoelectric actuator drive circuit 18C generates a single PWM pulse train, rather than the dual PWM pulse trains of the piezoelectric actuator drive circuit 18A of
The piezoelectric actuator drive circuit 18C generates a bipolar drive signal on line 104 for application to a piezoelectric actuator 14 or other capacitive load. A typical but non-limiting application of piezoelectric actuator drive circuit 18C is to drive a piezoelectric pump from a 5 volt DC power source, generating an excitation voltage on the piezoelectric actuator that is roughly a 60 Hz sine wave swinging from +300 volts to −100 volts.
The piezoelectric actuator drive circuit 18C uses a unipolar power source. The converter circuit 102C comprises a modest-voltage, power switching element Q1 and a transformer T1 that has only one secondary with no taps and yet it generates a high voltage bipolar output. The converter circuit 102C functions in conjunction with a single unipolar pulse source and a single unipolar polarity control signal are required for operation. In the illustrated implementation, the pulse generator 100 serves both as the unipolar pulse source and the source of the unipolar polarity control signal. In addition, the pulse generator receives the feedback signal from piezoelectric actuator 14 on line 105.
The converter circuit 102C further comprises transistors Q2 and Q3. The gates of transistors Q2 and Q3 are connected via resistors R1 and R2, respectively, to the source of the polarity drive signal. The emitter of transistor Q3 is connected to power source 103, the collector of transistor Q3 is connected via diode D2 to the secondary of transformer T1. In
In piezoelectric actuator drive circuit 18C, polarity switching is achieved by current (as opposed to voltage) control on the “slow side” of the transformer T1 secondary. This permits the use of very low-cost, slow, high-voltage transistors that are mass produced. Furthermore, only a single, low potential, low frequency, unipolar steering signal is required for operation. Such simplicity is in contrast to more expensive SCRs or MOSFETS or transistors with possibly multiple, more complex, higher voltage drive and biasing requirements.
Bipolar voltage generation is achieved in the piezoelectric actuator drive circuit 18C by catching the “resonant bounce” electromotive force (emf) of transformer T1 on the half cycle that is generated by the parasitic capacitance of the transformer windings. Paradoxically, parasitic capacitance in transformers is generally considered to be a design impediment that reduces the efficiency of transformers and their associated circuits. Yet the piezoelectric actuator drive circuit 18C ingeniously and uniquely uses the parasitic capacitance of the transformer T1 to generate an opposing emf. Advantageously, this allows the transformer T1 to be fabricated at very low cost. Alternatively, a 2 secondary transformer (or tapped secondary) transformer such as that shown as T1′ in piezoelectric actuator drive circuit 18D of
3.4 Second Example Drive Circuit: Operation
The piezoelectric actuator drive circuit 18C of
In the first mode of operation illustrated in
At the end of each high pulse of the signal PWM, transistor Q1 turns “off” and the primary of transformer T1 reacts by generating a “flyback” positive charge pulse on the primary (V1) and secondary (V2) (v=di/dt). In the illustrated, example embodiment, the secondary is wound in a 15:1 ratio to the primary so that the induced voltage at V2 is 15 times greater than V1. Because transistor Q3 is forward biased, current is able to flow out of I2 (on line 104) to the piezoelectric actuator 104, and a positive step (S+) in the potential on the piezoelectric actuator results. In an example implementation, the PWM drive pulses occur at about 100 KHz. The individual pulse widths of these PWM pulses can be modulated such that any positive direction amplitude/wave shape can be induced on the piezoelectric actuator 14.
In the second mode of operation illustrated in
At the end of each high pulse, transistor Q1 turns “off” and the primary of transformer T1 reacts by generating a “flyback” positive charge pulse on the primary (V1) and secondary (V2) (v=di/dt), as in the first mode. However, in the second mode transistor Q3 is “off”, and thus current cannot flow in diode D2, nor will it flow in diode D1 due to its direction. This causes the flyback potential to be “trapped” in the transformer T1 and partially dissipated in transformer resistive losses, with the rest being stored in the parasitic capacitance of transformer T1. The parasitic capacitance and the transformer inductance form an LC resonant circuit which shortly thereafter responds by producing a “bounce” charge at V2 which is opposite in polarity. Because of its new polarity, current can now flow out of the piezoelectric actuator 14 and through diode D1 and transistor Q2, inducing a negative direction step in the potential on the piezoelectric actuator 14. The individual pulse widths of the PWM drive pulses can be modulated such that any negative direction amplitude/wave shape can be induced on the piezoelectric actuator 14.
Thus, by appropriately modulating the duty cycle and/or frequency of PWM drive and polarity drive signal, using the piezoelectric actuator drive circuit 18C (or piezoelectric actuator drive circuit 18D) virtually any desired bipolar waveform can be induced on a piezoelectric or other capacitive load.
4.0 Example: Drive Circuit Receiving Analog Input
In an embodiment such as that illustrated in
5.0 Drive Signal: Fixed PWM Mode
As mentioned above, in one illustrated embodiment the drive signal applied on line 104 to piezoelectric actuator 14 is based on the digital PWM-A and PWM-B signals output from microcontroller 116. In a PWM servo mode of operation described hereinafter, the pulse widths of the pulse width modulation signals PWM-A and PWM-B applied to converter circuit 102 can be changed, even dynamically changed in real time operation of pump 10, in order to change the waveform of the drive signal applied to piezoelectric actuator 14. But in another embodiment known as the fixed PWM mode, the logic (e.g., software) executed by pulse generator 100 is configured so that the pulse widths of the signals PWM-A signal PWM-B are uniform.
The fixed PWM mode may be selectively entered and exited during operation of piezoelectric actuator drive circuit 18, as in the case of determining the resonance of piezoelectric actuator 14. On the other hand, in certain “fixed” applications in which the pulse width of the signals PWM-A and PWM-B are expected never to change, the operating parameters for the piezoelectric actuator 14 (e.g., pulse width, frequency of the drive signal) may be stored in non-volatile storage. For example, the operating parameters necessary for the fixed PWM mode may be “burned in” to microcontroller 116 at manufacturing time, at application time, or for that matter, at any time. Thus, microcontroller 116 can be configured to work in essentially any application.
6.0 Drive Signal: Optimized Waveform Mode
The piezoelectric actuator drive circuit can also operate in an optimized waveform mode. In the optimized waveform mode, the piezoelectric actuator drive circuit 18 uses pre-stored values to maintain an essentially constant waveform shape. The example sinusoidal waveform shown in
In the optimized waveform mode, certain values utilized to generate the drive signal having the optimized waveform are prepared and pre-stored in a table (such as lookup table 140 of
In another implementation representatively illustrated by table 140-18B of
As an example of the foregoing, at a point X1=P/20 a first value from PWM lookup table 140 is utilized for the pulse width of the PWM-A signal, at a point X2=2*P/20 a second value from PWM lookup table 140 is utilized for the pulse width of the PWM-A signal, and so forth. At the half way point, e.g., point 10*P/20 in this example, the signal PWM-B is utilized rather than the PWM-A signal, in which case an appropriate value for PWM-B is garnered from PWM lookup table 140, followed at point 11*P/20 with another corresponding value for PWM lookup table 140, and so forth.
The lookup table 140 thus comprises a pairing of waveform points and appropriate pulse width values (any particular pulse width value being either for the PWM-A signal or the PWM-B signal, as discussed above). As discussed further herein, the pulse width values stored in PWM lookup table 140 can be predetermined or “optimized” in accordance with the particular pump with which the piezoelectric actuator is being utilized, in accordance with a particular environment in which the pump is utilized, in accordance with one or more criteria (e.g., sensor input values), and/or one or more of the foregoing.
The lookup table 140 is preferably stored in non-volatile memory. Typically the lookup table 140 is stored in microcontroller 116. Alternatively, for some applications lookup table 140 may also be external to microcontroller 116. The illustration of lookup table 140 in
7.0 Drive Signal Control Program: Overview
Basic example steps of one example mode of logic implemented by microcontroller 116 in handling the input signals such as the analog input signals received from user input device 106 and user input device 108, as well as the fixed PWM mode and the PWM servo modes of operation, are understood in conjunction with
As mentioned before, in the illustrated example the user input device 106 is a trimpot which can be used to set a period/frequency of the drive signal applied on line 104, and user input device 108 is a trimpot which can be used to set a voltage/amplitude of the drive signal applied on line 104. By “period” or “frequency” is meant a period such as that illustrated as P in
7.1 Drove Signal Control Program: Main Routine
At step 6A-6, the main routine checks to determine if an external user digital input has been received which affects operation of pump 10. Checking whether an external user digital input has been received can involve checking whether a start bit has been set on serial interface buss (Universal Serial Interface (USI) buss) 128. If external user digital input has been received, at step 6A-7 a routine is called to handle receipt of the external user digital input (a USI handler). If the determination at step 6A-6 is negative, and after execution of step 6A-7, execution returns to step 6A-6.
7.2 Drive Signal Control Program: Interrupt Service Routine
Since operation of pump 10 can be terminated or shut off by software, a check occurs at step 6B-2 whether there has been a software termination of pump 10. In case of software termination, the interrupt service routine of
The interrupt service routine of
The value of variable Counter affects the period or frequency of the drive signal (see
When it is determined at step 6B-2 that operation of the pump is not to be terminated, the counter Counter is decremented at step 6B-4. Step 6B-5 involves checking whether the (just decremented) value of counter Counter corresponds to a point just shy of half of the waveform (e.g., whether Counter has reached the value CounterHalf+1).
If an affirmative determination occurs at step 6B-5, as step 6B-6 the interrupt service routine of
The signal PWM-A and signal PWM-B are turned off just shy of midpoint of the waveform in order to prepare for ensuing step 6B-7. Step 6B-7 involves checking voltage obtained from the multichannel analog to digital converter ADC) of microcontroller 116. The PWM signals PWM-A and PWM-B are turned off in case they generate noise that might interfere with the voltage determinations from the ADC.
So as soon as the signal PWM-A and signal PWM-B are turned off at step 6B-6, a measurement of voltage is taken as quickly as possible at step 6B-7. The ADC reading of step 6B-7 is a reading of voltage applied to pump 10. This reading is taken to ensure that the pump is being driven at the desired set value of the amplitude. In other words, the reading at step 6B-7 is a reading of amplitude A of the drive signal of
Thus, when an affirmative determination is made at step 6B-5 that a point just shy of mid-waveform has been reached, the signals PWM-A and PWM-B are turned off, and a sample taken of voltage to the pump 10 before exiting the interrupt service routine of
A negative determination at step 6B-5 means that the waveform is not at the sampling point (not just shy of the mid waveform point). When a negative determination is made at step 6B-5, a check is performed at step 6B-8 whether the value of decremented Counter is exactly equal to CounterHalf (meaning that the waveform has reached its exact midpoint). If the check at step 6B-8 is affirmative, as step 6B-9 the interrupt service routine of
If the check at step 6B-8 is negative (which means that waveform formation is past its midpoint), a check is made at step 6B-10 whether the value of Counter has reached 1. The Counter reaching 1 means that the negative pulse formation is essentially completed. Therefore, if the determination at step 6B-10 is negative, at step 6B-11 the interrupt service routine of
If the check at step 6B-10 is negative, a further check is made at step 6B-12 whether the decremented value of the Counter has reached zero. If so, it is time to start formation of a new waveform, and accordingly at step 6B-13 the interrupt service routine of
As an optional step, after turning off both signal PWM-A and signal PWM-B at step 6B-11, the voltage at the ADC of user input device 106 could again be checked in the manner of step 6B-7.
Thus, repeated performance of the interrupt service routine of
As a result of execution of interrupt service routine of
The integrated waveform shape is under the control of the drive circuit, particularly in view of the pulse width modulation (e.g., of the PWM-A and PWM-B signals on lines 124 and 126, respectively, in the circuit of
7.3 Drive Signal Control Program: Checking ADC
Aforedescribed step 6B-7 involved checking the analog digital converter (ADC) of microcontroller 116. Step 6B-7 essentially involves execution of a routine named CheckAtoDs. Selected basic example steps of routine CheckAtoDs are illustrated in
The routine CheckAtoDs is entered at step 6C-1. It will be recalled that the ADC of microcontroller 116 is a multichannel ADC, and as such can receive analog signals on several channels from a corresponding number of sources. For example, the multichannel ADC of microcontroller 116 receives a voltage feedback signal from output monitor 122 regarding the voltage on line 104 applied to piezoelectric actuator 14 of pump 10, and two distinct other voltage signals which are input from user input device 106 and user input device 108.
The routine CheckAtoDs is configured to check, in a predetermined sequence: a channel of its ADC which receives voltage from output monitor 122; a channel of its ADC which receives voltage from user input device 106 indicative of
RateInput; a channel of its ADC which receives voltage from user input device 108 indicative of VoltInput; and, a channel of its ADC which receives a supply voltage from power supply 103. The sequencing of operation of routine CheckAtoDs is based on a counter AtoDCtr, which counts from 1 to 6 as it is incremented at step 6C-20.
At step 6C-2 of routine CheckAtoDs a check is performed whether the counter AtoDCtr currently has the value of one. If the check at step 6C-2 is affirmative, at step 6C-3 the routine CheckAtoDs processes the value previously read from a previously selected channel of the ADC of microcontroller 116. In particular, at step 6C-3 the routine CheckAtoDs calls routine CheckVolts. The routine CheckVolts actually processes the voltage feedback signal, now converted to digital by ADC of microcontroller 116, obtained from output monitor 122. The digital voltage value processed at step 6C-3 should correspond to the amplitude A of the drive signal at its peak (see
If, upon entry into routine CheckAtoDs, the value of counter AtoDCtr is two (as determined at step 6C-5), the routine CheckAtoDs calls routine CheckVoltsInput in order for the channel of the ADC which handles the user input device 108 to process the analog value obtained from user input device 108 and read at the prior execution of step 6C-4. It will be recalled that the user-set value set at user input device 108 corresponds to VoltInput, and determines the pulse widths of digital pulses applied as signals PWM-A and PWM-B on lines 124 and 126, respective, and thus determines the amplitude of the drive signal on line 104. After enabling the appropriate channel of the ADC to read the analog value, at step 6C-7 the routine CheckAtoDs again selects the channel of the ADC which handles the reading of voltage from output monitor 122 (and thus the drive signal applied on line 104). The channel selection of step 6C-7 results in the selected channel reading the analog value applied thereto in preparation for the next execution of routine CheckAtoDs. Thereafter, the counter AtoDCtr is incremented (step 6C-20) and the routine CheckAtoDs is exited (step 6C-21).
If, upon entry into routine CheckAtoDs, the value of counter AtoDCtr is three (as determined at step 6C-8), at step 6C-9 the routine CheckAtoDs again calls routine CheckVolts in order to process the digitally converted feedback voltage acquired from output monitor 122 (which represents the actual amplitude of the voltage applied as the drive signal to piezoelectric actuator 14). If necessary, in its processing the routine CheckVolts adjusts the pulse width of the signals PWM-A and PWM-B in order to achieve the desired amplitude for the drive signal to piezoelectric actuator 14. Then the routine CheckAtoDs prepares for its next execution by (at step 6C-10) selecting the channel of the ADC which handles user input device 106 so that at step 6C-10 the selected channel acquires the analog information applied thereto. Thereafter, routine CheckAtoDs increments the counter AtoDCtr (at step 6C-20) and is exited (step 6C-21).
If, upon entry into routine CheckAtoDs, the value of counter AtoDCtr is four (as determined at step 6C-11), the routine CheckAtoDs calls routine CheckRateInput in order for the channel of the ADC which handles the user input device 106 to process the analog value obtained from user input device 106 and read at the prior execution of step 6C-10. It will be recalled that the user-set value set at user input device 108 corresponds to RateInput or PumpRate, and determines the frequency or period of the drive signal applied to piezoelectric actuator 14 on line 104. After enabling the appropriate channel of the ADC to read the analog value, at step 6C-13 the routine CheckAtoDs again selects the channel of the ADC which handles the reading of voltage from output monitor 122 (and thus the drive signal applied on line 104). The channel selection of step 6C-13 results in the selected channel reading the analog value applied thereto in preparation for the next execution of routine CheckAtoDs. Thereafter, the counter AtoDCtr is incremented (step 6C-20) and the routine CheckAtoDs is exited (step 6C-21).
If, upon entry into routine CheckAtoDs, the value of counter AtoDCtr is five (as determined at step 6C-14), at step 6C-15 the routine CheckAtoDs again calls routine CheckVolts in order to process the digitally converted feedback voltage acquired from output monitor 122 (which represents the actual amplitude of the voltage applied as the drive signal to piezoelectric actuator 14). If necessary, in its processing the routine CheckVolts adjusts the pulse width of the signals PWM-A and PWM-B in order to achieve the desired amplitude for the drive signal to piezoelectric actuator 14. Then the routine CheckAtoDs prepares for its next execution by (at step 6C-16) selecting the channel of the ADC which handles the supply voltage from power supply 103 so that at step 6C-16 the selected channel acquires the analog information applied thereto. Thereafter, routine CheckAtoDs increments the counter AtoDCtr (at step 6C-20) and is exited (step 6C-21).
If, upon entry into routine CheckAtoDs, the value of counter AtoDCtr is six (as determined at step 6C-17), at step 6C-18 the routine CheckAtoDs sets a variable SupplyVoltsRaw to the digitally converted value read at step 6C-16, and resets the value of counter AtoDCtr back to zero. Then, at step 6C-19, the routine CheckAtoDs again selects the channel of the ADC which handles the reading of voltage from output monitor 122 (and thus the drive signal applied on line 104). The channel selection of step 6C-19 results in the selected channel reading the analog value applied thereto in preparation for the next execution of routine CheckAtoDs. Thereafter, the counter AtoDCtr is incremented (step 6C-20) and the routine CheckAtoDs is exited (step 6C-21).
Thus, as seen from the foregoing and
7.4 Drive Signal Control Program: Check Volts Input Routine
Basic steps in the routine CheckVoltsInput, called at step 6C-3, step 6C-9, and step 6C-15 of the routine CheckAtoDs, are illustrated in
At step 6D-8 a check is made whether the value of the variable actual_volts exceeds a variable SetVolts. The value of the variable SetVolts reflects the actual desired amplitude for the drive signal for piezoelectric actuator 14 on line 104. The value of the variable SetVolts can be set by user input, e.g., either analog input such as the VoltInput provided by user input device 108, or from a GUI in the manner previously illustrated by the embodiment of
7.5 Drive Signal Control program: PWM Setting Routine
The routine PWM Set serves to adjust (either increase or decrease, as appropriate) the pulse width W of the digital pulses included in both signal PWM-A applied on line 124 and signal PWM-B applied on line 126 to converter circuit 102. It will be recalled that the pulse width W corresponds to the amount of time charge time that the inductor L1 of converter circuit 102 is being charged. Example basic steps of routine PWM Set are illustrated in
As mentioned above, the routine CheckAtoDs (at step 6C-6) calls the routine CheckVoltsInput to determine whether the user input voltage obtained from user input device 108 indicates that the desired amplitude of the drive signal has been changed by the user. If necessary, the routine CheckVoltsInput makes an adjustment in the desired amplitude. Basic steps of an example implementation of routine CheckVoltsInput are illustrated in
At step 6F-4 a check is made whether the value of the variable volts_ctl is less than a variable MAX_VOLTS. The value of the variable MAX_VOLTS reflects a maximum permissible amplitude for the drive signal for piezoelectric actuator 14. If value of the variable volts_ctl is less than the variable MAX_VOLTS, at step 6F-5 a value of variable SetVolts is set equal to the variable volts_ctl. Otherwise, at step 6F-6 the variable volts_ctl is set to the value MAX_VOLTS. After the value of variable volts_ctl has been established (either at step 6F-5 or step 6F-6), the routine CheckVoltsInput is exited at step 6F-7.
7.6 Drive Signal Control Program: Check Rate Input Routine
As mentioned above, the routine CheckAtoDs (at step 6C-12) calls the routine CheckRateInput to determine whether the user input voltage obtained from user input device 106 indicates that the desired frequency of the drive signal has been changed by the user. If necessary, the routine CheckRateInput makes an adjustment in the desired frequency. Basic steps of an example implementation of routine CheckRateInput are illustrated in
The pulse period of the PWM-A and PWM-B waveforms can be adjusted on a pulse by pulse basis in “real-time”, producing an endless array of drive waveform possibilities. For such complex waveforms, it may be necessary to employ a digital signal processor type of microcontroller.
8.0 Determining Parameter(s) of Piezoelectric Actuator
One use of one or more embodiments and modes of operation of the piezoelectric actuator drive circuit 18 described above involves determining one or more parameters or characteristics of piezoelectric actuator 14 or of a system in which the piezoelectric actuator 14 operates.
8.1 Determining Capacitance of Piezoelectric Actuator
For accurate operation of pump 10 it is important to have an accurate determination of the capacitance of the piezoelectric actuator 14. As a general rule, a higher capacitance piezoelectric element has more energy and displaces further than a lower capacitance piezoelectric element. While the particular piezoelectric material employed in piezoelectric actuator 14 may have a specified or nominal capacitance, experience shows that the capacitance of piezoelectric elements produced in a same manufacturing lot may vary as much as five percent from piece to piece, and that the capacitance of the same type of piezoelectric elements produced in different lots may vary by as much as twenty five percent.
Embodiments of the piezoelectric actuator drive circuit 18 herein described enable a pump manufacturer to use a piezoelectric element which differs from the nominal capacitance for its type. Advantageously, these embodiments of piezoelectric actuator drive circuit 18 can automatically determine the actual capacitance and thereby deliver the appropriate voltage in view of the actual capacitance. In other words, the piezoelectric actuator drive circuit 18 senses the capacitance of piezoelectric actuator 14, and customizes the drive signal accordingly. For example, for a piezoelectric actuator 14 whose ceramic degrades over time, the piezoelectric actuator drive circuit 18 can test the load (e.g., piezoelectric actuator 14) and thereafter drive the piezoelectric actuator 14 with a higher voltage to compensate for degradation or variation of the piezoelectric element over time.
Having applied a known amount of charge (in Coulombs) to the piezoelectric actuator and by subsequently measuring the voltage (in volts) on the piezoelectric actuator (at step 9A- 5), the capacitance can be directly calculated. The voltage measurement is obtained by the voltage feedback signal applied by output monitor 122 on line 105 to microcontroller 106. The capacitance check routine samples the voltage feedback signal applied by output monitor 122 on line 105 to microcontroller 106.
Alternatively, the capacitance check routine samples the voltage feedback signal obtained from output monitor 122 at successive points along a waveform, and particularly at and after the peak of the waveform. For example, the capacitance check routine determines the voltage measurements at several points in a time neighborhood around peak K of a waveform such as the waveform of
After determining the capacitance of piezoelectric actuator 14, the capacitance check routine can exit (as depicted by step 9A-7). More preferably, however, the capacitance check routine can call or be succeeded by a capacitance compensation routine.
At step 9B-2, the capacitance compensation routine determines an appropriate pulse width value for the PWM signal (e.g., the signal PWM-A on line 124 and the signal PWM-B on line 126 in the
After determining the necessary pulse width for the PWM signal (e.g., PWM-A on line 124 and the signal PWM-B on line 126) in view of the capacitance, as step 9B-3 the capacitance compensation routine sets the value PWM to the appropriate capacitance-determined pulse width value determined at step 9B-2. Then, as step 9B-4, the capacitance compensation routine checks whether it should initiate a fixed PWM mode of operation or a PWM servo mode of operation.
If the fixed PWM mode of operation is selected at step 9B-4, then as step 9B-5 the capacitance compensation routine enters or enables the fixed PWM mode. Entering or enabling the fixed PWM mode essentially means that a consistent PWM value (the value determined at step 9B-2 and set at step 9B-3) is consistently utilized for forming the pulse widths of the signal PWM-A and PWM-B. In other words, in the fixed PWM mode the routine CheckVolts is bypassed so that the PWM value is not updated by a feedback signal or other signal.
If the PWM servo mode of operation is selected at step 9B-4, then as step 9B-6 the capacitance compensation routine enters or enables the PWM servo mode. Entering or enabling the PWM servo mode essentially means that a the PWM value can be updated or changed in accordance with input, such as the feedback voltage signal applied on line 105 by output monitor 122. In so doing, the capacitance compensation routine may first need to turn off the fixed PWM mode (if the fixed PWM mode had been turned on, such as at step 9A-2, for example). Turning on the PWM servo functionality involves including the routine CheckVolts as part of execution of microcontroller 116, so that the PWM value is update (e.g., decremented at step 6D-9 or incremented at step 6D-11) in accordance with an input value (e.g., an ADC read value obtained at step 6D-2).
8.2 Determining Impedance/Resonance of Piezoelectric System
The piezoelectric actuator drive circuit 18 facilitates determinations of the impedance of a system in which the piezoelectric actuator 14 operates, the impedance being an indication of the resonant frequency of piezoelectric actuator 14. For example, when the piezoelectric actuator 14 operates in a pump, the impedance of the system comprising the piezo pump, the attached tubing, the fluid viscosity, the trapped air, etc. The impedance of the system relates to the resonant frequency of the system. A low impedance point in a frequency spectrum indicates a resonant frequency. If the resonant frequency of the system is known, the performance of the pump can be optimized for that particular system. Typically, the resonant frequency of a system is anywhere from 40 to 130 Hertz. One pump in two different systems will have two different resonant frequencies and therefore it is desirable to be able to measure the system resonant frequency in real time. Once the resonant frequency is known, the micro controller can adjust the drive frequency for maximum performance.
Two example and non-limiting impedance/resonance determination techniques are an impedance measurement technique and an impulse response technique. Both the impedance measurement technique and the impulse response technique are preferably implemented during real time operation of pump 10, e.g., while piezoelectric actuator 14 is actually pumping fluid in pump 10.
8.2.1 Impedance Measurement Technique
The first technique is very similar to the previously described capacitance technique. A constant power drive is applied at various drive frequencies and the signal attenuation is measured. The frequency at which maximum attenuation occurs indicates minimum impedance and thus indicates the resonant frequency.
Basic example steps of the impedance measurement technique are illustrated in
As step 11A-2, the impedance measurement routine turns off the PWM servoing capability of piezoelectric actuator drive circuit 18. This is because the impedance of piezoelectric actuator 14 at a particular frequency is made by driving piezoelectric actuator 14 with the voltage control servo circuitry disabled. This is accomplished by the impedance measurement routine disabling the call to or otherwise bypassing the routine CheckVolts (which is illustrated in
In its remaining steps, the impedance measurement routine of
After it has been determined at step 11A-6 that the entire range of excitation frequencies has been checked, at step 11A-8 the peak voltage feedback signal values obtained for the entire range are normalized. Then, as step 11A-9, the impedance measurement routine determines the resonant frequency of pump 10 as the particular excitation frequency in the scan range that resulted in the minimum impedance value (i.e., the minimum voltage feedback peak value).
8.2.2 Impulse Response Technique
The second technique measures the resonant frequency not by measuring the dynamic impedance but by measuring the system's impulse response. This is exactly equivalent to hitting a tuning fork with a hammer and measuring the fork frequency. The piezo is hit with an electrical impulse and then “listened to” via the voltage feedback line for the physical shock wave to propagate into the pump system, and then “bounce” back to the piezo and physically displace it, generating an echoed electrical impulse. The inverse of the time between the impulse excitation and the echo is the resonant frequency of the system.
Basic example steps of the impulse response technique are illustrated in
As step 11B-4, the microcontroller 116 enters a step function drive mode in which the pulse widths of the signals PWM-A and PWM-B are set in accordance with a step function. That is, the pulse widths of the signals PWM-A and PWM-B are initially set at a first value, then increased to a second (greater) value, then increased to a third (yet greater) value, and so forth. In other words, the impulse response routine varies the drive signal, and all the while, as step 11B-5, the voltage feedback signal from output monitor 122 on line voltage feedback signal on line 105 is monitored by microcontroller 116 or some other processor. When the echo is found, at step 11B-6 the inverse of the echo period is taken as the resonant frequency of the piezoelectric actuator 14.
9.0 Drive Circuit Receiving Sensor Signals
As mentioned above, the connector 110 can be connected to one or more sensors. Such sensor(s) supply a corresponding sensor signal(s) to piezoelectric actuator drive circuit 18, and to microcontroller 116 in particular. For example,
The digital input signal shown in
10.0 Drive Signal Waveform Optimization
As previously indicated, in a waveform optimization mode the piezoelectric actuator drive circuit 18 can use previously prepared and/or pre-stored information (e.g., waveform shape data) in order to generate a drive signal with optimized waveform for application to the piezoelectric actuator 14 of a pump. The previously prepared and pre-stored information can be stored in a table, such as lookup table 140 (see
10.1 Waveform Optimization Apparatus
As indicated previously, the waveform data being prepared by waveform optimizer 200 can be optimized with respect to one or more operational parameters, e.g., one or more criteria. Examples of optimizable criteria include flow (e.g., rate of flow of fluid through the pump), acceleration, noiselessness, pressure, temperature, elevation, power consumption, and signals or input from any other analog or digital feedback device. Optimization of a driving signal waveform typically involves the use of a sensor in order to obtain a signal (e.g., feedback signal) regarding the operational parameter being optimized. More than one such sensor may be utilized, and the location and/or positioning of such sensor(s) depends upon the parameter being sensed/optimized. For sake of simplicity,
In the ensuing discussion an example, non-limiting waveform optimization scenario is described in which the optimized parameter is fluid flow through the pump. In such example scenario it should be understood that the sensor can be a flowmeter, and that the flowmeter may be positioned either at an outlet or downstream from an outlet of the pump.
The waveform optimizer 200 outputs a drive signal on line 204. It will be appreciated that in one example embodiment the waveform optimizer 200 has constituency and operation similar to that of the previously described pulse generators and/or microcontrollers for generating a digital output signal for use as the drive signal. In addition, the waveform optimizer 200 typically includes an executable program, such as waveform optimization program 210. The waveform optimization program 210 executes steps based on instructions stored in a memory in order to generate the drive signal to be applied to the piezoelectric actuator and in order to generate a waveform equation which is solved in order to obtain a table of waveform optimization data values. The waveform optimization data values are stored in a table memory of waveform optimizer 200, illustrated as table 212 in
An input/output device 220 is connected to waveform optimizer 200 so that the waveform optimization data stored in table 212 can be extracted therefrom. The input/output device 220 can take various forms, such as a display (for reading data values from table 212), or a hardware memory production device (such as a ROM burner for storing values in a read only memory (ROM)).
10.2 Waveform Optimization Convenance Techniques
The output of waveform optimizer 200 is a table or listing of waveform optimization data, also known as waveform shape data. Generation of the waveform optimization data for such table is depicted as event 14-2 of
The waveform optimization data generated by waveform optimizer 200 will subsequently be used in a target piezoelectric actuator drive circuit 18 (such as embodiments described herein) in order to optimize the waveform applied on line drive signal applied on line 104 to piezoelectric actuator 14 in a target pump. Conveyance of the waveform optimization data generated by waveform optimizer 200 to the target pump can occur in several modes, such as the modes respectively illustrated by events 14-3A, 14-3B, and 14-3C in
As waveform optimization data conveyance mode 14-3A, the particular waveform optimization data generated by waveform optimizer 200 can be input to a memory table comprising or accessible to pulse generator 100 of the target pump in which it is to be utilized. For example, a graphical user interface (GUI) or the like can be utilized for inputting the waveform optimization data developed by waveform optimizer 200 into a memory for piezoelectric actuator drive circuit 18. The memory can be either on-board memory (e.g., for microcontroller 116) or other form of memory (e.g., read only memory (ROM)).
As waveform optimization data conveyance mode 14-3B, the particular waveform optimization data generated by waveform optimizer 200 can be stored in table form in a memory chip or other memory device, and afterwards the memory chip/device bearing the waveform optimization data can be installed in the piezoelectric actuator drive circuit 18 of the target pump. This mode is also illustrated in
As waveform optimization data conveyance mode 14-3C, the particular waveform optimization data generated by waveform optimizer 200 can be stored in table form or otherwise in a microprocessor or microcontroller of the target pump. For example, in the conveyance mode 14-3C the entire microcontroller 116, and perhaps the entire piezoelectric actuator drive circuit 18, is supplied for the target pump.
10.3 Waveform Optimization Data Preparation Procedure
The logic of the waveform optimization program 210 executed by waveform optimizer 200 can be sequenced, arranged, formatted, and programmed in a variety of ways. Moreover, the waveform optimizer 200 may include one or more controllers, processors, or ASICs which, either in distributed or consolidated manner, perform basic operations such as the example steps hereinafter depicted. In one non-limiting, example configuration illustrated in
Essentially, the waveform optimization procedure first determines coefficients for a wave equation. The coefficients of the waveform equation are determined to optimize at least one operational parameter of the pump. Then the waveform optimization procedure solves the waveform equation to obtain waveform shape data which can be utilized by the piezoelectric actuator drive circuit of the pump so that, for each of plural points within a period of the waveform, the drive signal has an appropriate amplitude for a predetermined waveform shape (e.g., a waveform shape optimized for the pump). The waveform shape data is stored in a memory (such as table memory 212 of
Any suitable basic waveform equation can be utilized by waveform optimizer 200, e.g., sine wave, square wave, rectangular wave, etc. In a non-limiting example mode now discussed, the fundamental wave equation having the general form of Equation 1 is utilized.
In Equation 1, D is the drive amplitude in volts; f is the operating frequency in Hz; N is the number of harmonics to be considered; and i=0, . . . N-1 is the index range for the harmonics.
As mentioned above and explained in more detail below, the coefficients Ai and Bi of the waveform equation of Equation 1 are first determined, after which the waveform equation is solved for its amplitude (voltage) V. In Equation 1, for the coefficients Ai and Bi the subscript i is respectively associated with the sine term and the cosine term of the fundamental term pair (when i=0) and harmonic term pairs (terms in which i>0).
Step 17-2 through step 17-4 involve initialization operations for various variables utilized in the waveform optimization procedure. These initialization operations are performed preparatory to invocation of a coefficient determination routine having example steps illustrated in
As mentioned above, the waveform optimization procedure can produce waveform shape data that is optimized in accordance with one or more operational parameters (e.g., operational criteria). For one or more of these operational parameters there may be certain boundary conditions within which the pump must operate. For example, if fluid flow is such an operational parameter, the operation of the pump may be acceptable only within a certain range of flow values. Therefore, optional step 17-5 involves inputting boundary conditions for the waveform optimization procedure. For example, at step 17-5 an upper fluid flow rate and/or a lower fluid flow rate may be input to the waveform optimization procedure.
A forthcoming step 17-10 involves execution of the coefficient determination routine for determining the coefficients of the waveform equation. As a precursor, nominal preliminary values for the coefficients Ai and Bi of the waveform equation are obtained at step 17-7. In one example implementation, these nominal preliminary values for the coefficients Ai and Bi are preferably stored in non-volatile memory. Then, using these nominal preliminary values for the coefficients Ai and Bi of the waveform equation, the waveform equation is utilized by waveform optimizer 200 at step 17-8 to generate a drive signal which is applied on line 204 to the piezoelectric actuator of the operative pump. As indicated by step 17-9, the waveform optimization program 210 waits a (preferably predetermined) settling time before continuing further operation. The settling time depends on the field of employment of the pump but may be, for example, on the order of twenty seconds. After expiration of the settling time, as indicated by symbol 17-10 the waveform optimization program 210 continues execution with the steps shown in
As step 17-10 of
After the coefficient determination routine of step 17-10 has determined all coefficients for the waveform equation, e.g., all harmonic term pairs, at step 17-11 the waveform optimization program 210 provides an opportunity to further refine the coefficients. In particular, starting from and building on the coefficients determined at step 17-10, the waveform optimizer continues to operate by essentially repeating step 17-10. Before so doing, at step 17-12 the appropriate counters and values are reset or reinitialized. For example, the coefficient subscript counter is reinitialized at zero, the value of step_size again reset, and active_term set to point to the sine term. The waveform optimizer may loop back to repeat step 17-10 several times, each time using the coefficients calculated during the last loop as the starting coefficients for the successive loop. For example, the loop may be repeated such that step 17-10 is performed three times based on the first criteria.
In addition to refinement, as an option the waveform optimizer also provides an opportunity for redundancy check. That is, after making a first determination of waveform coefficients with respect to a first criteria, at step 17-13 the waveform optimizer can start all over again with newly initialized coefficients, performing step 17-10 one or more times in order to check whether the redundancy-inititated performance(s) of step 17-10 yielded comparable coefficients as the original performance(s) of step 17-10. The redundancy check of step 17-13 can involve using the same basic waveform equation, or another waveform equation. The redundancy check of step 17-11 can be performed as many times as desired. Although not so illustrated, it will be appreciated that, prior to repeating the coefficient determination routine of step 17-10, in like manner as step 17-12 the appropriate counters and values are reset or reinitialized. If redundancy checks have been performed (as determined at step 17-13), there will be plural versions of tables of waveform shape data prepared by the coefficient determination routine of
As indicated above, in some applications and/or modes of operation the waveform optimization program 210 may optimize the waveform shape data based on only one operational parameter (e.g., only one criteria). On the other hand, in other applications and/or modes of operation the waveform optimization program 210 may optimize the waveform shape data based on plural operational parameter (e.g., more than one criteria). The series of steps of
In the example, non-limiting implementation, should the waveform optimization program 210 perform its optimization based on plural operational criteria (e.g., multivariable optimization), the coefficients of the waveform equation are considered one at a time and in sequential fashion. For example, the coefficients of the waveform equation are first determined at step 17-10 with respect to the first operational parameter (first operational criteria, based e.g., on a first feedback signal) by a first execution of the coefficient determination routine. Then, after the first set of coefficients have been determined, those coefficients are utilized as a starting point for a second execution of the coefficient determination routine (at step 17-16) in which the second operational parameter influences coefficient determination (based, e.g., on a second feedback signal). Similarly, if there are other operational criteria upon which the optimization is to be dependent, the most recently determined coefficients are utilized as a starting point for another execution of the coefficient determination routine (at step 17-18) in which the another operational parameter influences coefficient determination (based, e.g., on yet another feedback signal).
Of course, prior to each performance of the coefficient determination routine, the appropriate initializations and resets have to be made (e.g., i=0; step_size; active_term=sine). These initializations and resets are reflected by step 17-15 and step 17-17, which precede respective step 17-16 and step 17-18.
Other techniques are possible for performing waveform optimization when receiving plural criteria (e.g., receiving plural sensor input). As an alternative implementation, for example, a step such as step 17-10 can be performed with respect to one of the sensor/inputs (which is deemed a primary input). For example, the primary input might be flow in the pump. The waveform optimizer also keeps track of the signal(s) from other sensor(s), which are considered as secondary criteria. In particular, the waveform optimizer in this alternative implementation monitors to ensure that the input signal received for the secondary criteria sensor is within prescribed boundary values for the secondary criteria. So long as the input signal received for the secondary criteria sensor is within prescribed boundary values, the readings obtained for the primary sensor are validated and used to compute waveform coefficients. However, at any time that the input for the secondary sensor is outside of its boundary conditions, the primary input signals are discarded and therefore not used in the coefficient calculation. Therefore, only data collected when all of the plural sensor inputs are within boundary conditions is used for calculating the waveform coefficients based on the primary input.
After as few or as many operational parameters as necessary have been considered, and the final coefficients determined, the table generation routine of
While in the preceding example discussion the plural operational criteria were considered essentially sequentially in determining the coefficients, it should be understood that, in other embodiments, the coefficients of the waveform equation can be determined while essentially simultaneously considering all operational criteria.
10.3.1 Coefficient Determination Routine
Basic steps involved in an example scenario of the coefficient determination routine are illustrated in
As evident from the ensuing discussion, the coefficient determination routine comprises an inner loop of steps which is nested within an outer loop of steps.
The outer loop of steps increments the coefficient subscripter counter i. That is, in a first execution of the outer loop, the inner loop is repetitively executed, as many times as necessary, to determine both the coefficient A0 for the sine term and the coefficient B0 for the cosine term for the fundamental pair of terms of the waveform equation. During a second execution of the outer loop, the inner loop is repetitively executed, as many times as necessary, to determine both the coefficient A1 for the sine term and the coefficient B1 for the cosine term for the first harmonic pair of terms of the waveform equation. Similarly, during a third execution of the outer loop, the inner loop is repetitively executed, as many times as necessary, to determine both the coefficient A2 for the sine term and the coefficient B2 for the cosine term for the second harmonic pair of terms of the waveform equation, and so forth.
The inner loop of steps is repetitively executed, as many times as necessary, for determining an optimized coefficient value for a single term of the waveform equation. For a given pair of terms of the waveform equation (e.g., either the fundamental pair of terms or a harmonic pair of terms), the inner loop is first executed as many times as necessary (while active_term=sine) to find an optimal coefficient for the sine term. After the optimal coefficient for the sine term is determined, the active_term is switched (to active_term=cosine) so that the inner loop is executed as many times as necessary to find an optimal coefficient for the cosine term. Thus, the coefficient being determined at any given moment is determined by the active_term variable (which indicates either the sine or the cosine term), and the coefficient subscript counter i (which indicates to which pair of terms the term belongs: either to the fundamental pair of terms (i=0) or to one of the harmonic pairs of terms (i>0).
The commencement of the coefficient determination routine is indicated by step 17C-1. After the coefficient determination routine is initiated, as step 17C-2 the currently existing version of the waveform equation is used to apply a drive signal to the piezoelectric actuator 14 of the operational pump connected to waveform optimizer 200. Thereafter, e.g., possibly after a time delay, as step 17C-3 the coefficient determination routine evaluates the feedback signal received from the pump. For example, if the criteria of interest for this execution of the coefficient determination routine is fluid flow in the pump, then as step 17C-3 the sensor signal from the flowmeter is evaluated.
In conjunction with the evaluation, as step 17C-4 the coefficient determination routine determines if the feedback signal from the criteria sensor is consistent with required conditions for that criteria. For example, if the feedback signal is fluid flow, the logic of step 17C-3 may determine whether the fluid flow through the pump continues to increase (as is desired), or whether the fluid flow undesirably decreases. If the feedback is consistent with the required conditions (e.g., if the fluid flow continues to increase), then as step 17C-5 the current value of the coefficient being determined is stored as the latest best coefficient. On the other hand, if the feedback is inconsistent with the required conditions (e.g., if the fluid flow decreases rather than increases), then the coefficient determination routine knows that it has stepped too far in attempting to determine the coefficient, and accordingly as step 17C-6 the coefficient determination routine settles for using the latest best coefficient value for coefficient subscript i.
The feedback consistency check of step 17C-4 has been described with reference to the one operational criteria in view of which the waveform optimization program 210 is currently attempting to optimize the coefficients, and thus the waveform shape data. It should be understood that the feedback consistency check of step 17C-4 may also involve checks with respect to any other operational criteria for which the waveform optimizer 200 may also be requested to optimize the waveform shape data. For example, while checking at step 17C-4 to ensure that the signal from the flowmeter indicates that the fluid flow through the pump is increasing, the check at step 17C-4 may also involve determining that a feedback signal or sensor signal with respect to another operational parameter (e.g., operational criteria) is within boundary conditions for that other parameter/criteria. As an illustration, consider an example embodiment in which the waveform shape data is to be optimized not only in view of fluid flow but also fluid temperature. In such illustration, a second check performed at step 17C-4 may be to ensure that the a signal indicative of temperature in the pump chamber is within boundary conditions (e.g., either above or below a predetermined temperature, or between a first predetermined temperature and a second predetermined temperature).
If it is determined at step 17C-4 that the feedback signal from the criteria sensor is consistent with required conditions for that criteria, after step 17C-5 a check is made whether the value of step_size is less than or equal to a predetermined value. In the illustrated mode, the predetermined smallest value of step_size which is utilized by the coefficient determination routine is 0.001.
If the variable step_size has not reached its predetermined smallest value, then further iterations of the inner loop of the coefficient determination routine are necessary for optimizing the coefficient. In preparation for further executions of the inner loop for the same coefficient, step 17C-8 through step 17C-10 are performed. At step 17C-8, the sign and magnitude of the variable step_size are adjusted (e.g., decremented to a smaller value). This is done for reducing the step_size as the coefficient determination routine gets closer and closer to the optimized value for the coefficient currently being handled. In one example implementation, at step 17C-8 the value of step_size is halved. At step 17C-9 an new coefficient value for the term currently being handled by coefficient determination routine is computed by adding the value of the variable step_size (as just computed at step 17C-8) to the latest best coefficient value for the current term. Then, as step 17C-10, the waveform equation is updated to that coefficient of the term currently being handled by the coefficient determination routine has the value just determined at step 17C-9. Thereafter, the inner loop is repeated (branching back to step 17C-2) so that the waveform equation as updated at step 17C-10 is used to apply the drive signal to the pump.
Should it be determined at step 17C-7 that the variable step_size has reached its predetermined smallest value, then no further iterations of the inner loop of the coefficient determination routine are necessary for optimizing the coefficient. At this point, the optimized value of the coefficient for the term currently being handled by the coefficient determination routine has been determined, at least with respect to the operational criteria for which optimization is now being performed. As such, the coefficient determination routine is now ready to determine a coefficient for the next term of the waveform equation, and continues with step 17C-11.
The value of the variable step_size reaching its predetermined smallest value is just one way in which the coefficient determination routine may realize that it is finished with determining a coefficient for a particular term. The coefficient determination routine can also realize that it has determined the optimum coefficient (at least for the current criteria) when the required conditions check of step 17C-4 is not satisfied. When the check of step 17C-4 fails (e.g., the fluid flow starts to decrease rather than increase), the coefficient determination routine realizes that it has gone too far in its increasing of the value of the coefficient. Accordingly, in such case as step 17C-6 the coefficient determination routine uses the latest best value of the coefficient (as determined at a previous execution of step 17C-5) as the coefficient for the term currently being handled. Thereafter the coefficient determination routine continues with step 17C-11.
Step 17C-11 is preformed when the coefficient determination routine realizes that it has just found the optimum coefficient for the criteria currently being optimized. The coefficient determination routine is now ready to execute the inner loop (as many times as necessary) for the next term of the waveform equation. If the term just processed was sine, then the next term will be cosine, and vise versa. For this reason, as step 17C-11 the coefficient determination routine switches the active_term variable (e.g., either from sine to cosine, or from cosine to sine).
As step 17C-12 the coefficient determination routine ascertains whether coefficients for both the sine term and the cosine term for a given term pair have been completed. If the coefficient subscript i is zero, then as step 17C-12 the coefficient determination routine checks whether coefficient A0 for the sine term and the coefficient B0 for the cosine term for the fundamental term pair have been completed. Or if the coefficient subscript i is one, then as step 17C-12 the coefficient determination routine checks whether coefficient A1 for the sine term and the coefficient B1 for the cosine term for the first harmonic term pair have been completed. If both coefficients for a given term pair have not been processed, execution loops back to step 17C-2 so that the inner loop can be repetitively performed as necessary for determining the coefficient for the cosine term of the term pair.
When it has been determined at step 17C-12 that the optimum coefficients for both the sine term and the cosine term of a given term pair have been determined, a further check is made at step 17C-13 whether all term pairs have been processed. In other words, step 17C-13 determines whether the value of the coefficient subscript counter equals the maximum number of harmonics for which the waveform equation is being optimized. In an illustrated embodiment, seven harmonics of the waveform equation are considered to be within the bandwidth of the pump, for which reason the coefficient determination routine realizes that it has found all coefficients for all term pairs when the check at step 17C-13 indicates that i=7.
When (as determined at step 17C-13) there remain other term pairs for which coefficients need be determined, the outer loop of the coefficient determination routine is again entered. In this regard, as step 17C-14 various re-initializations and re-settings occurs. For example, the value of the coefficient subscript counter is incremented (e.g., i=i+1); the value of step_size is again reset to its initial value; and active_term=sine). As step 17C-15, a new pair of terms for a new harmonic is added to the waveform equation. Thereafter the outer loop again initiates the inner loop, this time for the new harmonic term pair, by branching back to step 17C-2.
When (as determined at step 17C-13) the optimum values for coefficients for all term pairs of the waveform equation have been determined (at least with respect to the currently considered operational criteria), as step 17C-16 the table generation routine of
10.3.2 Table Generation Routine
The table generation routine of
Entry into the table generation routine is depicted as step 17D-1. At this point, all optimized coefficients for the waveform equation as determined on the optimized criteria are known. As step 17D-2, the waveform optimization program 210 executed by waveform optimizer 200 solves or evaluates the waveform equation (the waveform equation now having the known optimized coefficients) for each point along the waveform, in order to determine an amplitude (e.g., voltage V) for each point along the waveform. Since the waveform period is taken as 360 degrees, the points along the waveform are taken as degrees (or should the number of points be sufficiently great, as fractions of degrees). In the example sinusoidal waveform of
As step 17D-3, the table generation routine builds an initial table using the amplitude values determined at step 17D-2. An example such table has a format generally similar to that of table 212-18A illustrated in
In one implementation, the number of points X for which the waveform equation is evaluated at step 17D-2 may be over one thousand (e.g., ten thousand or even twenty thousand). As a practical matter, however, values for a much smaller number of points are really necessary. Accordingly, as optional step 17D-4, the size of the table generated at step 17D-3 may be reduced by using only selected (preferably evenly spaced) points along the waveform. For example, if the table generated at step 17D-3 has a size of twenty thousand points, the table size may be reduce by utilizing only every one thousandth point along the waveform.
As another optional but preferably action, as step 17D-5 the table generation routine can also include, in the table which it generates, the pulse width modulation values for each of the points X1, X2, etc., which yield the desired respective amplitudes and hence the desired overall waveform. An example format of such a table is illustrated by table 140-18B of
After the table generation routine of
11.0 Drive Circuit: Scheduling Dose Delivery
The internal clock system of microcontroller 116 is used both (1) to generate the signal PWM-A and signal PWM-B for the flyback circuit 102 and (2) to control the applied field reversal. These signals are entirely under software control and thus, the drive amplitude and frequency can be manipulated in real-time and in an unlimited number of ways. For example, a piezoelectric pump can be driven in a traditional fashion of (for example) 400 volts at 60 Hz to produce a continuous flow, or it can be driven in an entirely unconventional and much more complex fashion of say 60 Hz for 1/30 of a second (1 pump “stroke”) at 400 volts every 1 minute to reliably deliver a drop of medication to a patient on schedule. Such unconventional operation can be initiated by delivery scheduler 160, described in conjunction with FIG. 3H(1) and FIG. 3H(2). For such example, the drive circuit changes dynamically the drive signal whereby the drive signal varies over time so that an essentially non-continuous dosage of fluid is delivered by the pump.
In low-flow applications the pump may be driven at extremely slow frequencies (i.e. 1 stroke per minute). The circuit allows for the flyback generation to be interrupted at any time in a way that the pump will electrically “float” for a period of time, holding its position at any point in the mechanical pump stroke cycle. Thus, the micro can float the transducer and go to sleep for a period, knowing that the pump will remain at its last position until flyback generation resumes. This allows for extremely low power consumption in low-flow applications. Extremely long “float” periods can be achieved through slight circuit modifications.
Furthermore, the precise timing capabilities of the microcontroller and delivery scheduler 160 are further employed to control piezo actuators in certain applications in ways that are related to world clock time such as using a piezo pump to water a plant once a day.
12.0 Two-Way Communications with Drive Circuit
Non-volatile on-board memory also allows for each piezoelectric control circuit 18, or piezoelectric-actuated host (utilization) device to be serialized and uniquely identified. This aids in manufacturing quality control and is particularly important when actuators are employed in certain remote system applications. For example, the communications channel 164 as shown in FIG. 3H(2)and communications interfaces can provide 2-way communications between one or more pumps and a controlling entity (e.g.,remote unit 162). Via the serialization described above, each pump in a network can be individually controlled and any local parameters being monitored can be accessed by the system controller.
13.0 Epilogue
The piezoelectric actuator drive circuit 18, preferably but not exclusively embodied in the form of an electronic printed circuit board (PCB), steps a relatively low DC voltage up to a very high AC voltage operating at various frequencies to drive piezoelectric actuator 14. The piezoelectric actuator drive circuit 18 could also drive electromechanical devices other than pumps, such as (for example) oscillating fans, air compressors, speaker exciters, aerosolizers (e.g., ultrasonic agitators), actuators, active valves, precision actuators, to name a few. The piezoelectric actuator drive circuit 18 provides the necessary voltage and frequency to drive piezoelectric elements and other electromechanical devices, and advantageously has onboard capability to vary the voltages and frequencies necessary to optimize the efficiency of the piezoelectric actuator 14.
The piezoelectric actuator drive circuit 18 provides essentially total control over piezo/electromechanical devices in terms of voltage, frequency, waveform and feedback loops. The piezoelectric actuator drive circuit 18 eliminates the need for large testing and driving devices such as power amps, signal generators and oscilloscopes to test, evaluate and run piezoelectric devices. The feedback loops such as pressure and temperature allows the PDC to automatically set the proper frequency for efficient operation.
In a PWM servo mode of operation, the microcontroller 116 continuously monitors the voltage applied to the transducer and dynamically varies the PWM characteristics to regulate the applied voltage in a conventional switching power supply sort of way. Because the microcontroller 116 has access to elements of the pump drive environment-voltage, PWM duty, drive frequency—the load and/or efficiency of the actuator can be measured by correlating drive frequency to load. This is an extremely valuable capability in, for example, piezoelectric pumps. Using this capability the “resonant frequency” of a pump can be dynamically determined and it is anticipated that pump back pressure can be measured.
The piezoelectric actuator drive circuit 18 with its microcontroller 116 can monitor external local inputs such as that provided by adjustment potentiometers and temperature or pressure transducers or even something as simple as an on/off switch. These inputs can be used to control piezoelectric actuator 14 by controlling the drive signal applied thereto.
As described above, the micro has many available digital/analog I/O lines available. These can be used to monitor things such as temperature, pressure, diaphragm position, flow, etc. via either digital or analog sensor means. These inputs can then be used in the micro to control the pump via software in many ways. The inputs can also be fed back out to a controlling system via the 2-wire serial interface for system monitoring.
In accordance with one or more of its plural and distinct aspects, the piezoelectric actuator drive circuit 18 offers several advantages over the electroluminescent (EL) lamp driver and other circuits. Among these advantages, the piezoelectric actuator drive circuit 18 can provide, in accordance with a selected aspect thereof:
In essence, the piezoelectric actuator drive circuit 18 allows the piezoelectric element (e.g., piezoelectric actuator 14) to operate at optimum efficiency and precision within the range of its operation at all times. This allows:
Thus, piezoelectric actuator drive circuit 18 generates the required high-voltage, reversing actuator drive signal; drives piezoelectric elements or electromechanical devices at varying frequencies and voltages; provides means for monitoring many key parameters of the actuator and its environment; as well as receiving external inputs. In accordance with distinctly implementable aspects of piezoelectric actuator drive circuit 18, these parameters and inputs can be acted upon in real-time to control the piezoelectric actuator and optimize its performance. The operating characteristics of the piezoelectric actuator can be programmed into the microcontroller at any time, totally eliminating the “Mona Lisa” characteristics of existing architectures
Further, drive circuits described herein have the capability to vary the frequency or voltage dynamically (e.g., after installed), and thereby facilitate optimization of frequency or voltage to address back pressures, temperatures and other operating conditions.
While the invention has been described in connection with what is presently considered to be the most practical and preferred embodiment, it is to be understood that the invention is not to be limited to the disclosed embodiment, but on the contrary, is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims.
This application is continuation of U.S. patent application Ser. No. 11/902,580 entitled “Piezoelectric Devices and Methods and Circuits for Driving Same”; which in turn is a divisional of U.S. patent application Ser. No. 10/816,000 entitled “Piezoelectric Devices and Methods and Circuits for Driving Same”, which is related to the following United States Patent Applications: U.S. patent application Ser. No. 10/815,975 entitled “Piezoelectric Devices and Methods and Circuits for Driving Same”; U.S. patent application Ser. No. 10/815,999 entitled “Piezoelectric Devices and Methods and Circuits for Driving Same”; and, U.S. patent application Ser. No. 10/815,978 entitled “Piezoelectric Devices and Methods and Circuits for Driving Same”; all of which are incorporated by reference herein in their entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 10816000 | Apr 2004 | US |
Child | 11902580 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11902580 | Sep 2007 | US |
Child | 12929045 | US |