textfiles/programming/FUZZYLOGIC/motor.txt

341 lines
15 KiB
Plaintext
Raw Permalink Blame History

INTRODUCTION
Servo motors are widely used in the field of motion control in
factory automation. The control target can be position, speed, or
force, among others. For this example application we take force
as the control variable.
In order to implement force control, we need to know the
compliance (response) of the controlled object to force. The
feedback gain in the control loop changes as a function of
compliance.
Grasping a range of objects from, for example, a soft tennis
ball to a hard steel ball using conventional servo control is
extremely difficult. The traditional control model does not
handle a variety of objects with differing material
characteristics very well. The system can become unstable. Fuzzy
logic, with its inherent flexibility, can be employed
effectively as an alternative in this situation.
FUZZY FORCE CONTROLLER
Control Objective
Grasp objects of various compliance, ranging, for example, from a
soft tennis ball to a hard steel ball with a constant force.
Control System
The control block diagram is shown in Figure 1. Output force
applied to the object is measured by a sensor and compared
against a reference force to obtain the difference. A control
gain Kg is applied to diminish this force difference. This gain
also varies as a function of the compliance of the grasped
object. Thus, control gain Kg is affected by two
factors: (1) the compliance of the object and (2) the difference
between a reference force and the measured force. Branches
coming off the error (e) node and speed (v) node of the above
diagram are expansions of those nodes, and represent variables
to be used to determine the control gain. They do not represent
additional control paths. We can write the control gain and
diagram its components as shown in Figure 2 below.
Ks (compliance component) is a function of Ke. Kf (force
component) is a function of error e and its time
derivative <20>. Both can be inferred by fuzzy logic.
The compliance Ke is determined by injecting a
speed command v into the servo motor and
measuring the output force f. Compliance is
expressed as follows:
Ke = df/dx = (df/dt)/(dx/dt) = <20>f/v
We obtain
Ke = (fk-f(k-1))/v(k-1)
Compliance can be thought of as the change in force (df) required
for a given deformation (dx) of an object. For example, a tennis
ball has a large compliance because the force needed to initiate
deformation is small, but increases significantly as the
deformation process proceeds. The change in force from initiation
to termination is large. At the other extreme is the steel ball,
which has small compliance. Although the force required to
initiate deformation is large, the force to continue deformation
does not change significantly. Consequently, the change from
initiating to terminating force is small.
It is known that the control gain Kg is the
reciprocal of the compliance Ke, so Ks can be inferred from Ke
by the following fuzzy rules:
If Ke is small then Ks is large
If Ke is large then Ks is small
These two rules make up the fuzzy inference unit A which connects
Ke with Ks.
Definition of Input/Out Variables for Unit B
Now let us consider fuzzy inference unit B, inferring Kf from e
and <20>. The two inputs into Unit B are error e and its time derivative
<20>. e is the difference between a reference force and the
applied output force. Labels and membership functions for e and
<20> are defined as shown in Figure 3a, 3b respectively. Figure 3c shows
the labels and membership functions for Kf.
FIU Source Code of Unit B
The following is the source code of Unit B written in FIDE's
Fuzzy Inference Language (FIL). Note that in the definition of
input variable Error, the value of P_VerySmall is given as (@-3,
0, @0, 1, @50, 0), and that of N_VerySmall is (@-50, 0,
@0, 1, @3, 0). We use -3 and 3 instead of -1 and 1
respectively because the data range of Error must be accommodated
in a resolution of 8 bits. This means the smallest interval of
Error is 600/256 = 3. The membership functions of these
fuzzy sets are shown in Figure 3a, 3b, and 3c as we have seen.
$ FILENAME: motor/motor1.fil
$ DATE: 08/12/1992
$ UPDATE: 08/14/1992
$ Two inputs, one output, to determine control gain
$ INPUT(S): Error, Derivative(_of_Error)
$ OUTPUT(S): Gain
$ FIU HEADER
fiu tvfi (min max) *8;
$ DEFINITION OF INPUT VARIABLE(S)
invar Error " " : -300 () 300 [
P_Large (@100, 0, @200, 1, @300, 1),
P_Medium (@50, 0, @100, 1, @200, 0),
P_Small (@0, 0, @50, 1, @100, 0),
P_VerySmall (@-3, 0, @0, 1, @50, 0),
N_VerySmall (@-50, 0, @0, 1, @3, 0),
N_Small (@-100,0, @-50, 1, @0, 0),
N_Medium (@-200,0, @-100, 1, @-50, 0),
N_Large (@-300,1, @-200, 1, @-100,0)
];
invar Derivative " " : -30 () 30 [
P_Large (@10, 0, @20, 1, @30, 1),
P_Medium (@5, 0, @10, 1, @20, 0),
P_Small (@0, 0, @5, 1, @10, 0),
P_VerySmall (@-1, 0, @0, 1, @5, 0),
N_VerySmall (@1, 0, @0, 1, @-5, 0),
N_Small (@0, 0, @-5, 1, @-10,0),
N_Medium (@-5, 0, @-10, 1, @-20,0),
N_Large (@-10, 0, @-20, 1, @-30,1)
];
$ DEFINITION OF OUTPUT VARIABLE(S)
outvar Gain " " : -2 () 2 * (
P_Large = 2.00,
P_Medium = 1.00,
P_Small = 0.50,
P_VerySmall = 0.25,
Zero = 0.00,
N_VerySmall = -0.25,
N_Medium = -1.00
);
$ RULES
if Error is N_Large and Derivative is P_Large then Gain is P_Medium;
if Error is N_Large and Derivative is P_Medium then Gain is P_Medium;
if Error is N_Large and Derivative is P_Small then Gain is P_Medium;
if Error is N_Large and Derivative is P_VerySmall then Gain is P_Medium;
if Error is N_Large and Derivative is N_VerySmall then Gain is P_Medium;
if Error is N_Large and Derivative is N_Small then Gain is P_Medium;
if Error is N_Large and Derivative is N_Medium then Gain is P_Small;
if Error is N_Large and Derivative is N_Large then Gain is P_Small;
if Error is N_Medium and Derivative is P_Large then Gain is P_Medium;
if Error is N_Medium and Derivative is P_Medium then Gain is P_Medium;
if Error is N_Medium and Derivative is P_Small then Gain is P_Medium;
if Error is N_Medium and Derivative is P_VerySmall then Gain is P_Medium;
if Error is N_Medium and Derivative is N_VerySmall then Gain is P_Medium;
if Error is N_Medium and Derivative is N_Small then Gain is P_Medium;
if Error is N_Medium and Derivative is N_Medium then Gain is P_Small;
if Error is N_Medium and Derivative is N_Large then Gain is Zero;
if Error is N_Small and Derivative is P_Large then Gain is P_Medium;
if Error is N_Small and Derivative is P_Medium then Gain is P_Medium;
if Error is N_Small and Derivative is P_Small then Gain is P_Medium;
if Error is N_Small and Derivative is P_VerySmall then Gain is P_Medium;
if Error is N_Small and Derivative is N_VerySmall then Gain is P_Medium;
if Error is N_Small and Derivative is N_Small then Gain is P_Small;
if Error is N_Small and Derivative is N_Medium then Gain is P_VerySmall;
if Error is N_Small and Derivative is N_Large then Gain is N_VerySmall;
if Error is N_VerySmall and Derivative is P_Large then Gain is P_Medium;
if Error is N_VerySmall and Derivative is P_Medium then Gain is
P_Medium;
if Error is N_VerySmall and Derivative is P_Small then Gain is P_Medium;
if Error is N_VerySmall and Derivative is P_VerySmall then Gain is
P_Medium;
if Error is N_VerySmall and Derivative is N_VerySmall then Gain is
P_Large;
if Error is N_VerySmall and Derivative is N_Small then Gain is
P_VerySmall;
if Error is N_VerySmall and Derivative is N_Medium then Gain is
N_VerySmall;
if Error is N_VerySmall and Derivative is N_Large then Gain is
N_Medium;
if Error is P_VerySmall and Derivative is P_Large then Gain is
N_Medium;
if Error is P_VerySmall and Derivative is P_Medium then Gain is
N_VerySmall;
if Error is P_VerySmall and Derivative is P_Small then Gain is
P_VerySmall;
if Error is P_VerySmall and Derivative is P_VerySmall then Gain is
P_Large;
if Error is P_VerySmall and Derivative is N_VerySmall then Gain is
P_Medium;
if Error is P_VerySmall and Derivative is N_Small then Gain is
P_Medium;
if Error is P_VerySmall and Derivative is N_Medium then Gain is
P_Medium;
if Error is P_VerySmall and Derivative is N_Large then Gain is
P_Medium;
if Error is P_Small and Derivative is P_Large then Gain is N_VerySmall;
if Error is P_Small and Derivative is P_Medium then Gain is
P_VerySmall;
if Error is P_Small and Derivative is P_Small then Gain is P_Small;
if Error is P_Small and Derivative is P_VerySmall then Gain is
P_Medium;
if Error is P_Small and Derivative is N_VerySmall then Gain is
P_Medium;
if Error is P_Small and Derivative is N_Small then Gain is P_Medium;
if Error is P_Small and Derivative is N_Medium then Gain is P_Medium;
if Error is P_Small and Derivative is N_Large then Gain is P_Medium;
if Error is P_Medium and Derivative is P_Large then Gain is Zero;
if Error is P_Medium and Derivative is P_Medium then Gain is P_Small;
if Error is P_Medium and Derivative is P_Small then Gain is P_Medium;
if Error is P_Medium and Derivative is P_VerySmall then Gain is
P_Medium;
if Error is P_Medium and Derivative is N_VerySmall then Gain is
P_Medium;
if Error is P_Medium and Derivative is N_Small then Gain is P_Medium;
if Error is P_Medium and Derivative is N_Medium then Gain is P_Medium;
if Error is P_Medium and Derivative is N_Large then Gain is P_Medium;
if Error is P_Medium and Derivative is P_Large then Gain is P_Small;
if Error is P_Medium and Derivative is P_Medium then Gain is P_Small;
if Error is P_Medium and Derivative is P_Small then Gain is P_Medium;
if Error is P_Medium and Derivative is P_VerySmall then Gain is
P_Medium;
if Error is P_Medium and Derivative is N_VerySmall then Gain is
P_Medium;
if Error is P_Medium and Derivative is N_Small then Gain is P_Medium;
if Error is P_Medium and Derivative is N_Medium then Gain is P_Medium;
if Error is P_Medium and Derivative is N_Large then Gain is P_Medium
end
Input/Output Response
Figure 4 shows the response surface of the FIU defined above.
This surface is obtained by using the Analyzer tool provided in
FIDE.
COMMENTS
Through experimentation, we can obtain a set of rules to infer
compliance Ke from speed v, and the measured force f. The rules
are in essence as follows:
If v is large and <20> is small, then Ke is very small
If v is large and <20> is medium,then Ke is small
If v is large and <20> is large, then Ke is medium
If v is small and <20> is small, then Ke is medium
If v is small and <20> is medium,then Ke is large
If v is small and <20> is large, then Ke is very large
The label names used here give an intuitive sense of how the
rules apply. However, even though label names are the same for
different variables, the fuzzy sets associated with these labels
may be different. For speed v, the label large
may be a fuzzy set as shown in Figure 5a, and for compliance
Ke, label large could be another fuzzy set as shown in Figure 5b.
The ranges of these variables can be determined by experiment on
the devices and objects of interest. For example, compliance data
gathered from a soft tennis ball and a hard steel ball can be
used to define large and small labels respectively for variable
Ke.
If we use an FIU to infer compliance Ke, the control gain
function now becomes three FIUs and an operations block (FOU) as
shown in Figure 6. The FOU implements Kg = Ks . Kf . Using
Fide's Composer capability, these four blocks can be combined
into a single system for analysis and simulation purposes.
(Weijing Zhang, Applications Engineer, Aptronix Inc.)
For Further Information Please Contact:
Aptronix Incorporated
2150 North First Street #300
San Jose, CA 95131
Tel (408) 428-1888
Fax (408) 428-1884
FuzzyNet (408) 428-1883 data 8/N/1
Aptronix Company Overview
Headquartered in San Jose, California, Aptronix develops and
markets fuzzy logic-based software, systems and development
tools for a complete range of commercial applications. The
company was founded in 1989 and has been responsible for a
number of important innovations in fuzzy technology.
Aptronix's product Fide (Fuzzy Inference Development
Environment) -- is a complete environment for the development of
fuzzy logic-based systems. Fide provides system engineers with
the most effective fuzzy tools in the industry and runs in
MS-Windows(TM) on 386/486 hardware. The price for Fide is $1495 and
can be ordered from any authorized Motorola distributor. For a
list of authorized distributors or more information, please
call Aptronix. The software package comes with complete
documentation on how to develop fuzzy logic based applications,
free telephone support for 90 days and access to the Aptronix
FuzzyNet information exchange.
Servo Motor Force Control
FIDE Application Note 003-140892
Aptronix Inc., 1992