An atomic force microscope (AFM) captures an image by scanning a mechanical probe tip across a surface of a sample. The probe tip senses molecular forces or friction between the probe tip and the sample. This sensing can be performed in different ways according to different AFM modes. For example, in a contact mode, the probe tip is mounted on a cantilever that is deflected in response to the forces between the probe tip and the sample. This deflection is measured in order to translate the detected forces into a representation of the sample's surface features.
As the probe tip is scanned across the sample, it may require height adjustment in order to accurately track the surface topology. In general, the probe tip should be maintained close enough to the surface for accurate sensing, but not so close that the force between the tip and sample becomes large enough to damage the probe tip and the sample.
The height of the probe tip is adjusted by a controller having a feedback loop. The controller outputs a control signal to an actuator to move the probe tip up or down by a desired amount, and it receives a feedback signal through the feedback loop to determine any necessary adjustments to the control signal. Components located between the control signal and the feedback loop are referred to collectively as the physical system of the AFM. The feedback signal can indicate, for instance, a difference between the desired movement of the probe tip and actual movement of the probe tip. It can also indicate interactions between the probe tip and the sample.
To safely image a surface, the controller must be able to adjust the probe tip height in a timely and accurate manner as the probe tip is scanned along the sample surface. Otherwise, the probe tip may crash into the sample surface before the controller can make required adjustments. Consequently, a safe scanning speed of the probe tip is limited by the bandwidth of the controller feedback loop.
In many commercial AFM controllers, the feedback loop uses a proportional-integral (PI) filter or a proportional-integral derivative (PID) filter to update the control signal. Due to the simplicity of these filters, however, the feedback loop is unable to correct for higher order vibrational resonances that may affect the height of the probe tip. This inability to correct for higher order resonances means that the probe tip must be moved at a slower rate to provide stable operation. Moreover, most AFMs require a user to tune the parameters of the feedback loop, but most users cannot properly configure parameters required to correct for higher order resonances.
Academic control theorists have designed more sophisticated AFM controllers to increase the feedback bandwidth of the AFM, but these AFM controllers have significant weaknesses as well. These AFM controllers are typically designed by constructing an analytical model of an AFM system in a process referred to as system identification, and then generating a formula for an AFM controller that will satisfy some design goal with respect to the modeled AFM system. For example, an analytical model of an AFM system can be constructed by measuring the frequency response of the AFM system and then generating an equation that captures all of the complex-valued poles and zeros of the measured system. A formula for an AFM controller can then be generated based on the AFM system equation.
One weakness of academic-designed AFM controllers is that system identification is imprecise, so it produces a flawed analytical model of an AFM system. This can result in a theoretically optimal controller that performs poorly in practice. Another weakness of academically-designed AFM controllers is that the tools to perform system identification and subsequent controller design tend to fail for systems with many (possibly weakly damped) poles and zeros and with time delays, which is typical for AFMs.
Due to the above shortcomings of commercially available and academically-designed AFM controllers, most existing AFM controllers are designed with a great deal of human interaction and verification. In other words, there are no automatic methods for creating sophisticated and stable AFM controllers.
What is needed, therefore, are automatic methods for designing AFM controllers that are more sophisticated than traditional PI or PID based AFM controllers.
In accordance with an example embodiment, a method is provided for tuning an AFM comprising a physical system and a controller configured to control the physical system. The method comprises determining a loop response of the AFM based on a frequency response of the physical system and a frequency response of the controller, determining a cost function indicating a difference between the loop response and a target response characteristic, and adjusting the frequency response of the controller to reduce the difference.
In accordance with another example embodiment, a method is provided for tuning an AFM comprising a physical system and a controller configured to control the physical system. The method comprises determining a frequency response of the controller based on a set of filter coefficients, determining a loop response of the controller and the physical system based on the determined frequency response of the controller and a measured frequency response of the physical system, aligning a magnitude of the determined loop response with a desired loop shape, determining a value of an error function between the aligned magnitude of the determined loop response and the desired loop shape, and adjusting the set of filter coefficients to improve the value of the error function.
In accordance with another example embodiment, a system is provided for tuning an AFM comprising a physical system and a controller comprising a plurality of digital filters and configured to control the physical system. The system comprises a loop shaping component that performs automatic loop shaping on a loop response defined by a frequency response of the physical system and a frequency response of the controller, and a gain adjustment component that adjusts a gain of the controller according to a local maximum magnitude of the loop response.
The described embodiments are best understood from the following detailed description when read with the accompanying drawing figures. Wherever applicable and practical, like reference numerals refer to like elements.
In the following detailed description, for purposes of explanation and not limitation, representative embodiments disclosing specific details are set forth in order to provide a thorough understanding of the present teachings. However, it will be apparent to one having ordinary skill in the art having had the benefit of the present disclosure that other embodiments according to the present teachings that depart from the specific details disclosed herein remain within the scope of the appended claims. Moreover, descriptions of well-known apparatuses and methods may be omitted so as to not obscure the description of the example embodiments. Such methods and apparatuses are clearly within the scope of the present teachings.
The terminology used herein is for purposes of describing particular embodiments only, and is not intended to be limiting. The defined terms are in addition to the technical and scientific meanings of the defined terms as commonly understood and accepted in the technical field of the present teachings. As used in the specification and appended claims, the terms ‘a’, ‘an’ and ‘the’ include both singular and plural referents, unless the context clearly dictates otherwise. Thus, for example, ‘a device’ includes one device and plural devices.
The described embodiments relate generally to methods of tuning an AFM comprising a physical system and a controller that controls the physical system. In certain embodiments, the AFM is tuned by measuring a frequency response P(ω) of the physical system, and then adjusting a frequency response C(ω) of the controller such that a combined frequency response of the physical system and the controller satisfies some design goal. The combined frequency response, also referred to as a loop response, is defined as L(ω)=P(ω)C(ω). The design goal can be, for instance, maximizing bandwidth of the loop response L(ω) to account for higher order resonances in the physical system while keeping the AFM stable.
One way to achieve the desired bandwidth and stability is to first tune the controller response such that a magnitude |L(ω)| of the loop response matches a magnitude |L0(ω)| of a desired loop shape, and then to adjust the gain of the controller to further improve the bandwidth of the loop response L(ω). The loop shape is defined as the relative structure of a response curve independent of its overall gain. For example, an integrator shape is given by |L(ω)|=k/w.
The controller typically comprises a set of digital filters arranged in a cascaded configuration, and C(ω) is determined by coefficients of the filters. Accordingly, L(ω) can be calculated by first measuring P(ω) and then calculating C(ω) based on the filter coefficients. An example of a measured P(ω) is shown by a curve 805 in
With the ability to calculate L(ω), the filter coefficients in the AFM controller can be numerically optimized to minimize some cost function ε that related to a difference between |L(ω)| and |L0(ω)|. One example of the cost function is ε=rms[δ(ω)], where rms[δ(ω)] is a root mean squared difference, or sum of squared differences, of a difference function δ(ω)=20 log10(|L(ω)|/L0(ω)|). An example of the difference function is shown by a curve 825 in
The difference function δ(ω) is typically calculated for logarithmic values of L(ω) and L0(ω) because these functions span many orders of magnitude. An example of using logarithmic scaling in the curve fitting, as well as using the magnitude response for the curve fit, is described in Sidman et al., “Parametric System Identification on Logarithmic Frequency Response Data,” IEEE TRANSACTIONS ON AUTOMATIC CONTROL, VOL. 36, No. 9, SEPTEMBER 1991, the subject matter of which is hereby incorporated by reference. In general, the use of logarithmic scaling allows ε to be equally weighted across many decades of frequency, while P(ω) is measured at logarithmically spaced frequencies. As a result, controller optimization can be performed by a standard multi-parameter fit of log10(L(ω)) to log10(L0(ω)) evaluated at the measured values of ω.
After computing δ(ω), a filter can be fitted to the difference function, as illustrated by a curve 830 in
In shaping the loop response, the phase of L(ω) can sometimes be ignored because magnitude and phase are related. Bode's well known gain-phase relationship states that for a stable, minimum phase system (one with no poles or zeros in the unstable portion of the complex plane), the phase and gain are uniquely related. Thus, shaping |L(ω)| correspondingly shapes this part of the phase of L(ω). The presence of poles and or zeros in the unstable portion of the complex plane result in an excess of negative phase as does time delay. This extra negative phase due to time delay places a limit on the bandwidth of the controller even after |L(ω)| has been properly shaped.
After the magnitude is shaped, the overall gain of the controller is adjusted to achieve some design goal and/or given robustness margin. In adjusting the gain, the full loop response L(ω) is taken into account, including magnitude and phase. For example, the overall gain can be maximized subject to requirements on phase and gain margins, ensuring that the controller will be stable and robust. Alternatively, the gain can be tuned below its maximum value to achieve a desired crossover frequency or closed-loop bandwidth.
Unlike conventional methods, the above methods can be used to address higher order resonances by tuning the controller automatically. This can eliminate a need for user intervention or expert analysis, and it can allow more sophisticated AFM systems to be used.
Referring to
During image capture, actuator 110 moves cantilever arm 115 and probe tip 120 up or down with respect to measurement surface 105 to maintain a substantially constant force between probe tip 120 and measurement surface 105. In some embodiments, actuator 110 can be a piezoelectric actuator, for example, such as described in commonly owned U.S. patent application Ser. No. 12/890,894, filed on Sep. 27, 2010, entitled “Tandem Piezoelectric Actuator and Single Drive Circuit for Atomic Force Microscopy,” to D. Schroeder, et al., the subject matter of which is hereby incorporated by reference. Alternatively, actuator 110 can be an electrostatic “nanostepper” actuator, for example, such as described in commonly owned U.S. Pat. No. 5,986,381 to S. Hoen et al., dated Nov. 16, 1999, entitled “Electrostatic Actuator with Spatially Alternating Voltage Patterns,” the disclosure of which is hereby incorporated by reference.
Laser 125 (or another suitable light source) is disposed above measurement surface 105. It directs light that is reflected at cantilever arm 115 and is incident on detector 130. Detector 130 generates a deflection signal determined by an angle at which light is reflected off of cantilever arm 115 at probe tip 120, and it transfers the deflection signal to an analog-to-digital converter (ADC). The ADC digitizes the deflection signal to produce a cantilever deflection signal, which is transmitted to controller 135. The deflection signal indicates of movement of probe tip 120 in a Z-direction relative to measurement surface 105. In response to the deflection signal, controller 135 generates a controller output signal to actuator 110 via a digital-to-analog converter (DAC) to raise or lower the cantilever arm 115 and probe tip 120 to maintain a constant deflection equal to a deflection setpoint, leading to a constant force between probe tip 120 and measurement surface 105 in contact-mode.
Among other functions, controller 135 can be configured to account for resonance conditions that can occur when cantilever arm 115 is off measurement surface 105 (“off-surface resonance conditions”), as described in commonly owned International Application PCT/US11/26191, filed on Feb. 25, 2011, entitled “Atomic Force Microscopy Controller and Method” to C. Moon, the disclosure of which is hereby incorporated by reference.
Controller 135 can be implemented in whole or in part by a processing device, such as a processor or central processing unit (CPU), application specific integrated circuits (ASICs), field-programmable gate arrays (FPGAs), or combinations thereof, using software, firmware, hard-wired logic circuits, or combinations thereof. Details of certain aspects of the functions of controller 135 are provided below in connection with the representative embodiments. In some embodiments, controller 135 is implemented on a real-time operating system (OS) used in AFM 100 or as a standalone device. When using a processor or CPU, a memory (not shown) is included for storing executable software/firmware and/or executable code that controls the signal from controller 135 to actuator 110. The memory may be any number, type and combination of nonvolatile read only memory (ROM) and volatile random access memory (RAM), and may store various types of information, such as computer programs and software algorithms executable by the processor or CPU. The memory may include any number, type and combination of tangible computer readable storage media, such as a disk drive, an electrically programmable read-only memory (EPROM), an electrically erasable and programmable read only memory (EEPROM), a CD, a DVD, a universal serial bus (USB) drive, and the like.
For example, controller 135 can include an FPGA onto which hardware description language (such as Verilog or VHDL) code has been compiled and uploaded. The deflection signal from detector 130 is digitized by the ADC. Based on the deflection signal, the FPGA creates the controller output signal that emerges from the DAC, is amplified, and then provided to actuator 110. Controller 135 illustratively includes a proportional-integral-differential (PID) filter block and a series of digital biquadratic filters, for example, known to one of ordinary skill in the art. The PID filter block and the digital biquadratic filters of controller 135 have coefficients useful in establishing the filter characteristics, discussed below. The coefficients can be dynamically reconfigured to change the filter characteristics, such as by a remote computer (e.g. a computer hosting a graphical user interface for AFM 100 and communicating via a communication protocol, such as Ethernet). Alternatively, controller 135 can be tuned to automatically to compensate for the motor dynamics, as described in commonly owned U.S. Pat. No. 7,987,006 by D. Abramovitch et. al., which is hereby incorporated by reference.
The frequency response of controller 135 (controller response) is a function of the filter coefficients, and methods for calculating theoretical frequency responses for digital filters are well-known. Illustratively, the frequency responses of controller 135 can be calculated using known programming software (e.g., Matlab). For example, a notch filter for use in mitigating off-surface resonances of cantilever arm 115, as described by commonly owned International Application PCT/US11/26191 to C. Moon, which is hereby incorporated by reference, can be specified by a center frequency, a depth, and a width (quality (Q) or damping factor).
Referring to
Controller 135 is characterized by a frequency response C(ω), and system 205 is characterized by a frequency response P(ω). Accordingly, an overall loop response L(ω) of AFM 100 can be defined as L(ω)=P(ω) C(ω), or L=PC. In some embodiments, P(ω) is measured directly, and then C(ω) is tuned by varying certain parameters of controller 135 to achieve a desired loop response L(ω). In some embodiments, the frequency response P(ω) can be measured using built-in capabilities of AFM 100. For example, controller 135 can apply a sine wave to system 205 as the controller output signal and then measure the resulting cantilever deflection signal to determine P(ω). For many electromechanical systems, such as an AFM, direct measurement of P(ω) is difficult and P(ω) C(ω) is measured when the system is in closed-loop, or extracted from the closed-loop response, typically denoted by T(ω)=L(1+L)−1. From these combined measurements, P(ω) is extracted and C(ω) can be verified against the controller model.
The exact quantities involved in the calculation of frequency response P(ω) depend on the mode of AFM 100. For instance, in contact mode, P(ω) is the response of the cantilever deflection signal to the controller output signal. As illustrated by curve 805 in
Referring to
Referring to
After the loop response has been shaped, the gain of controller 135 is adjusted to achieve some design goal and/or given robustness margin (S410). An example of this gain adjustment is illustrated in
Referring to
Next, the method calculates a resulting loop shape using the equation L(ω)=P(ω)C(ω) (S510). Then, the magnitude of the calculated loop response L(ω) is aligned with a desired loop at low frequency to create an aligned response L0(ω) (S515). In other words, aligning the magnitude of the determined loop response with the desired loop shape comprises aligning a low frequency region of the magnitude of the determined loop response with a low frequency region of the desired loop shape. An example of this low frequency alignment is illustrated by an alignment between curves 815 and 820 in
After aligning |L(ω)| and |L0(ω)|, the method calculates a magnitude difference δ(ω) between |L(ω)| and |L0(ω)| in decibels (dB) using the equation δ(ω)=20 log10(|L(ω)|/L0(ω)|) (S520). Finally, the method adjusts the filter coefficients to minimize a cost function ε=rms[δ(ω)] (S525).
The process of adjusting the filter coefficients can be performed in a variety of ways, including certain iterative methods. For example, in some embodiments, controller 135 comprises a PID arranged in a cascaded sequence with a plurality of biquadratic filters. In such embodiments, the PID and biquadratic filters can be tuned one at a time, with each successively tuned filter being appended onto the previously tuned filters already included in controller 135.
The PID is typically tuned by recasting it as an equation I(1/s+P/I+(D/I)s), where s=iω, and P, I, and D are the PID coefficients, discretizing the equation, pulling out the integral term as an overall gain factor that will be determined later by required robustness margins, and then optimizing P/I and D/I to minimize the cost function ε.
The biquadratic filters can be chosen so as to have 4 independent parameters and a DC gain of 1. Furthermore, a scaling factor that makes the overall gain 1 can be grouped with scaling factors from other filter sections so as to minimize latency, as described, for instance, in commonly owned International Application PCT/US11/26555, filed on Feb. 28, 2011, entitled “Multiple Filters in Fixed Point Math” to D. Abramovitch and C. Moon. The parameters of the biquadratic filters can be mapped to a frequency and quality factor (Q) as a numberator and denominator, respectively. Because the cost function ε may have many local minima in the space of these coefficients, and because each biquadratic may affect only a narrow frequency range, it may be beneficial to provide each biquadratic fit with an intelligent initial guess. Accordingly, the numerator and denominator frequencies can be seeded at prominent features of the magnitude difference curve δ(ω) as illustrated, for example, by the curve 830 in
Notably, not all peaks and valleys in δ(ω) are important, so the biquadratic filters should target frequencies where poor shaping is limiting performance of the AFM. In general, there are two ways for the attainable bandwidth to be limited. First, a peak at high frequency can cause the loop response to be unstable if the gain is increased. Second, phase can limit the gain at a crossover frequency. More specifically, the system can be phase-limited due to poor shaping near crossover or due to an unavoidable non-minimum phase.
Both of the above limitations tend to be expressed where |L(ω)| is close to 1. Moreover, below crossover, where |L(ω)| is greater than one, deviations from the intended shape will cause distortions in AFM images, so they must also be corrected even if they do not limit the AFM bandwidth. Finally, it is beneficial to avoid large peaks in a closed-loop response function T(ω)=L(1+L)−1 in order to prevent ringing in the output of controller 135. Based on these and other considerations, a weighting function can be designed for properly initializing the biquadratic filters. One example of such a weighting function is provided by an equation w(ω)=min(|L|,1)|T|2.
Referring to
After the filter coefficients are initialized, the method appends the i-th filter to controller 135 (S615). For example, after a first filter is appended to controller 135, the controller may have only one filter, so the controller response will be determined by the characteristics of that filter. However, a second filter can be subsequently appended to controller 135 by adding it to the first filter in a sequential fashion, e.g., as illustrated in
Next, the loop response L(ω) is calculated based on the measured frequency response P(ω) in combination with the frequency response C(ω) of controller 135 having the first through i-th filters (S620). Then, a cost function is computed with respect to the calculated loop response (S625), and the cost function is evaluated to determine whether it satisfies some goal (S630). In this case, the goal may be, for example, minimizing the cost function for controller 135 having the first through i-th filters. The cost function can be ε, as described above, or some other similarity metric between the loop response L(ω) and a target response characteristic.
If the cost function satisfies the goal (S630=YES), the method then determines whether each of the n filters have been appended to controller 135 (S640). If not (S640=NO), the method increments the index i and returns to step S610. Otherwise (S640=YES), the method proceeds to step S410 of
Referring to
Next, the method calculates the weighting function w(ω) to determine the importance of each maximum or minimum (S710), and then it locates the peak (or valley) with the highest weighted error w(ω)|δ(ω)| and pairs it with a closest neighboring valley (or peak) (S715). The weighting function (i.e., a weight for each of various different values of ω) can be calculated as described above in relation to
In
In
In
In
In
In
In
Note that the biquadratic filters of
As described above, controller 135 can be tuned using an iterative approach or various alternative approaches. In certain alternative approaches, the PID filter and one or more biquadratic filters are re-optimized simultaneously, or multiple biquadratic filters are fit simultaneously. Moreover, in some alternative approaches, the entire controller is designed by simultaneously tuning all of the filters. Nevertheless, optimization algorithms in large parameter spaces are slow and vulnerable to falling into shallow local minima. Accordingly, iterative methods such as those described above can be used to reduce the space for a given fit and enable effective initial guesses that target limiting areas. A potential shortcoming of iterative methods is that they may fail to find a global optimum. However, there are ways to addresses this shortcoming, such as retuning each filter once, refitting it in the presence of the other filters.
Although several methods have been described for improving feedback bandwidth with respect to a height signal, or z value of a cantilever arm, these methods can be adapted or modified to improve feedback bandwidth with respect to other signals, such as x and y values of the cantilever arm, alternating current (AC) amplitude, AC frequency, and tip bias signals. Moreover, the described methods can also be adapted for use in both feedback and feed-forward controllers. In each of these adaptations, controller adjustments can be made to achieve a desired loop shape. Moreover, the above methods are not limited to AFM, and could be used to improve any feedback system that is limited by an overly simple controller.
In certain embodiments, controller 135 can be implemented in reconfigurable hardware. For example, a PID filter and multiple biquadratic filters can be programmed into an FPGA based on tuning parameters obtained on a CPU. The described embodiments, however, are not limited to specific implementations or components such as an FPGA or CPU. Rather, they can be implemented in any combination of elements capable of performing the described functionality.
While representative embodiments are disclosed herein, one of ordinary skill in the art appreciates that many variations that are in accordance with the present teachings are possible and remain within the scope of the appended claims. The invention therefore is not to be restricted except within the scope of the appended claims.