Recherche Images Maps Play YouTube Actualités Gmail Drive Plus »
Recherche avancée dans les brevets | Historique Web | Connexion

Brevets

Numéro de publicationUS5486996 A
Type de publicationOctroi
Numéro de demande08/008,963
Date de publication23 janv. 1996
Date de dépôt22 janv. 1993
Date de priorité
22 janv. 1993
Autre référence de publication
Numéro de publication
US 5486996 A
US 5486996A
US5486996 A
US5486996A
Inventeurs
Cessionnaire d'origine
Classification aux États-Unis
Classification internationale
Classification coopérative
Classification européenne
G05B 13/02C1
Références
Liens externes
Parameterized neurocontrollers
US 5486996 A
Résumé

A controller based on a neural network whose output is responsive to input signals that represent user or designer defined control system parameters which may include process parameters, control parameters and/or disturbance parameters. The neural network can be "trained" to mimic an existing controller which may or not receive inputs of control system parameters. The trained neural network controller may have advantages of faster execution and reduced code size. The neural network can also be trained to result in a nonlinear controller that is more powerful than an existing controller.

Revendications
We claim:

1. A controller of a process which accepts modification of its behavior through input signals representative of parameters that are members of a set of parameters including: control parameters p.sub.c, process parameters p.sub.p, and disturbance parameters p.sub.d (which may collectively be called P) wherein said controller comprises a neural network;

wherein the neural network is trained to mimic an existing controller which receives inputs from the set of all P inputs or any subset thereof (except only the subset including only P, I and D inputs), and x.sub.p, y, y.sub.r, u and all algebraic, differential and integral operators of these x.sub.p, y, y.sub.r and u inputs, and has an output in a closed loop use, said training occurring by:

collecting said P parameters, said x.sub.p, y.sub.r, y, u and any other of said inputs as data, and

using said collected data as training data in a learning program which modifies the neural network in a training phase at least until an output from said neural network is similar or identical to the acceptable output generated by said existing controller; wherein:

x.sub.p is dynamic state variables of the process,

y is a process output signal,

y.sub.r is a reference input signal, and

u is a control adjustment signal and,

coupling said modified neural network to a second process similar to a first process previously controlled by the existing controller; and

applying said neural network to the second process using inputs that the existing controller would have used to control the first process so that the neural network controls the second process.

2. A controller as set forth in claim 1 wherein said controller comprises an input controller processor and a plurality of other controllers, at least one of which other controllers is a neural network.

3. A controller as set forth in claim 2, wherein said input controller processor passes data to inputs of the plurality of other controllers and wherein at least one of said plurality of other controllers further comprises an output controller processor that reviews outputs of said input controller processor and said plurality of other controllers and determines which of those outputs is used as input to the process.

4. A controller as set forth in claim 1 wherein the neural network is trained to extremize criteria using any training method from the set of training methods: Stochastic, non-gradient based, nonlinear; genetic; steepest descent; and second order methods.

5. A controller as set forth in claim 1 wherein training is done off-line over a variety of process models.

6. A controller as set forth in claim 1, wherein the neural network is trained to mimic an existing controller which receives inputs from the set of all P inputs or any subset thereof (except only the subset including P,I and D inputs), and x.sub.p, y, y.sub.r, u and all algebraic, differential and integral operators of these x.sub.p, y, y.sub.r and u inputs, with an output in a closed loop use, said training occurring by:

placing said neural network into the closed control loop so as to receive said P parameters, said x.sub.p, y.sub.r, y, u and any other of said inputs and also input from a learning program which modifies the network in a training phase at least until the u output from said neural network is similar or identical to the output generated by said existing controller,

allowing said existing controller to run in said closed-loop use until said training phase is accomplished; and,

placing the trained neural network in the closed loop so as to run the process in said closed-loop use.

7. A controller as set forth in claim 6 wherein said neural network, after said training phase, is employed to run said closed-loop use.

8. A controller of a process which accepts modification of its behavior through input signals representative of parameters that are members of a set of parameters including: control parameters p.sub.c, process parameters p.sub.p, and disturbance parameters p.sub.d (which may collectively be called P) wherein said controller comprises a neural network;

wherein said inputs received by said controller are from the set of inputs including all P inputs or any subset thereof (except only P,I,D inputs), and x.sub.p, y, y.sub.r, u and all algebraic, differential and integral operators of these x.sub.p, y, y.sub.r and u inputs;

wherein training is done off-line over a variety of process models, and further comprising:

an input controller processor means for passing data to other controllers and wherein said input controller processor means further comprises an output controller processor that reviews the outputs of other controllers and determines which of those is used as input to the process, wherein:

x.sub.p is dynamic state variables of the process,

y is a process output signal,

y.sub.r is a reference input signal, and

u is a control adjustment signal; and

wherein the output controller processor provides an output signal that is used as input to the process as determined by said output controller processor.

9. A controller of a process which accepts modification of its behavior through input signals representative of parameters that are members of a set of parameters including: control parameters p.sub.c, process parameters p.sub.p, and disturbance parameters p.sub.d (which may collectively be called P) wherein said controller comprises a neural network;

wherein said inputs received by said controller are from the set of inputs including all P inputs or any subset thereof (except only P,I,D inputs), and x.sub.p, y, y.sub.r, u and all algebraic, differential and integral operators of these x.sub.p, y, y.sub.r and u inputs;

wherein said controller comprises an input controller processor and a plurality of other controllers, at least one of which other controllers is a neural network; and wherein:

x.sub.p is dynamic state variables of the process,

y is a process output signal,

y.sub.r is a reference input signal, and

u is a control adjustment signal; and

wherein said controller provides a control signal to at least one actuator associated with the process so that a detectable physical change occurs in the characteristics of the process.

Description
DETAILED DESCRIPTION OF THE DRAWINGS

FIG. 1 describes a generalized control system 10 having a process (P) 12 (which could include an environment, a processing plant of various kinds, existing control systems or some other kind of system), which receives control adjustment signals as input (u) 13 which are the output of the controller 11 (here, the controller is a parameterized neurocontroller (PNC)). A measure of the output of the process y is produced as a signal on line 14 which is fed back to the PNC on line 18 to input 15. The PNC continues its control moves based on whatever is appropriate vis-a-vis the reference input y.sub.r on line 17 to input 16. In the example of the parameterized neurocontroller, the user or some automatic system could feed inputs representing the desired p.sub.c, p.sub.p, and/or p.sub.d parameter values (19). There may be any number (from zero to whatever number runs out the controller capacity or designer patience) of parameters selected from any one, two, or all three of the P groups of parameters. As in any real-world process, the process 12 can be disturbed by disturbances, D.

The process itself may be characterized by certain parameters, here, for example, in dotted line K, τ, and Θ (these are of the p.sub.p variety).

If desired, these process parameters may be identified by a process identifier 20 which receives the inputs to the process (u on line 23) and the outputs from the process (y on line 22). The identifier can produce a representation of the parameters which are used in the process identification K, τ, and Θ. If desired, the identifier 20 could be constructed as part of the controller 11. The identified process parameters could be input to the PNC, thus supplying some or all of the p.sub.p.

In general, processes can be defined by the following algebro-differential system: ##EQU1##

For many processes, a simplified form of this system suffices in which the set of algebraic equations, 0=g(.), is not needed.

In these equations, x.sub.p represents the dynamic state variables of the process, u represents process inputs, y represents process outputs, and p represents parameters that characterize the system. The T.sub.i and τ.sub.i are state and input time delays, and, along with p, constitute the process parameters p.sub.p. In the general case, u, x.sub.p, p and y are all vectors of appropriate sizes. The process parameters determine the dynamic behavior of the process. In a room temperature control application, for example, the volume (size) of the room, the heat conductances of the walls and floors, etc., would be process parameters. The process parameters can vary over time. Thus, if a door to an adjoining room was opened, the effective volume for heating or cooling purposes would be increased.

Any kind of process parameter is acceptable for use with a Parameterized Neurocontroller. It should be noted that while process state variables or estimates thereof can be inputs to the neural network (e.g., the neural network could be a state feedback controller), at least one process, control or disturbance parameter must also be an input.

State variables have been input to neurocontrollers as shown in; T. Troudet, S. Garg and W. Merrill, Design and Evaluation of a Robust Dynamic Neurocontroller for a Multivariable Aircraft Control Problem. Proc. International Joint Conference on Neural Networks, Vol. 1, Baltimore, pp. 308-314, 1992. However, they do not teach input of the process, control or disturbance parameter(s).

Another configuration would be to have a plurality of neural network PNC's with a rule-based processor up front, selecting the one best trained based on the value of the P input.

The description of the parameters (P) which may be fed to the PNC has already been made in the background section of this application.

There has also been discussion concerning the various forms the individual neural network for the PNC's could take, in the summary above. To further generalize, a set of equations could be used to define the controller output u from the neural network. Neural networks may be defined by their function. The algebraic types can be defined generally by the following functions: ##EQU2## where w represents the weights of the network and x.sub.p represents the process state variables (or estimates thereof), ##EQU3## e (t) is the rate of change of error at time t, and T.sub.e,i, T.sub.y,i, T.sub.yr,i and T.sub.xp,i are time delays (not necessarily non-zero) in values or e, y, y.sub.r and x.sub.p, respectively.

The dynamic, continuous time type neural networks intended for use with these inventions have their output defined by the following dynamical system:

x(t)=f (x(t), p.sub.c, p.sub.p, p.sub.d, w, e(t))

u(t)=g (x(t), p.sub.c, p.sub.p, p.sub.d, w, e(t))

x(o)=x.sub.o, where x is the state vector for the neural network.

The dynamic, discrete time type neural networks may be defined by the following dynamical system:

x(t)=f (x(t-δt), p.sub.c, p.sub.p, p.sub.d, w, e(t))

u(t)=g (x(t-δt), p.sub.c, p.sub.p, p.sub.d, w, e(t))

x(o)=x.sub.o

None of the above defining equations is intended to be limiting and it will be noted by one of ordinary skill that weights and errors and y, x.sub.p and y.sub.r parameters and time, and time-delayed values, may be added to or removed while still being capable of defining useable neural networks. These may also be used with this invention.

It should also be recognized that this invention is not limited to Single-Input Single-Output controller applications. Multiple sets of y, y.sub.r and x.sub.p inputs and multiple u outputs may readily be accepted and trained into either Multiple-Input Single-Output or Multiple-Input Multiple-Output versions of one of the varieties of neural networks used for this invention. No restriction is implied that y, y.sub.r, x.sub.p and u are scalar quantities. They may be vectors of arbitrary dimension.

Referring now to FIG. 2 (an example for illustration only--other types of references and curves are easily imaginable by those of ordinary skill in the art), three distinct curves are shown, C.sub.1, C.sub.2 and C.sub.3 for achieving the desired process output at a level represented by y.sub.r. For illustrative purposes only, the curve C.sub.1 indicates the kind of response a process is likely to give if pushed very hard and very fast to achieve the desired setpoint or reference value as quickly as possible. The likelihood is that there will be substantial overshoot and perhaps also oscillation until setpoint is achieved. Curve C.sub.2 has very little overshoot but achieves setpoint somewhat later, and curve C.sub.3 achieves setpoint later still. Note that the rise time does not begin until some time after t.sub.o, indicating that there is some delay between the time a control signal can be sent and the time that the process responds for this example. A change in an element of p.sub.c, e.g., the proportional controller gain, could accomplish similar changes in the response characteristics as shown in FIG. 2. For example, if the proportional gain is turned up, the curve would look more like C.sub.1, and if the proportional gain is turned down, the curve would look more like C.sub.3. The characteristics of the response curves would also be varied if there were changes in the process disturbances, or measurement noise. For example, if the controller is controlling the amount of chemicals that is being added to a reaction chamber and the speed of the reaction changes tremendously when a certain concentration of one of the chemicals is reached vis-a-vis the rest of the chemicals in the chamber, a process parameter could be incorporated into the inputs received by the PNC in order to account for this expected result. Thus, for example, if the output of the sensor indicated the degree of acidity (or some other measurable quantity) had passed or was approaching a certain point at which the reaction speed would increase dramatically, the failure of the controller to close down the valve releasing the more acid chemical could cause a response curve more similar to C.sub.1 or, in fact, allow for a runaway reaction.

As another example, a noise or disturbance parameter change might be appropriately fed into the controller where, for example, it is controlling the heating of a building space. In such a case where the day is unusually bright and sunny and the outside temperature is very warm, the heat load on the building and its ability to dissipate heat into the atmosphere would be reduced. Accordingly, if the operator of a controller desires a response curve similar to C.sub.2, different control moves than would ordinarily be required to achieve such a curve need to be output (u) by the PNC to accommodate the disturbances.

Referring now to FIG. 3 in which a controlled system 30 is shown having an extant controller 31 (C), a controlled process (P) 32, wherein the control signal output (u) is forwarded to the process (P) on line 34 and the output y from the process is output on line 35. The output y is also fed on line 36 back into the extant controller 31 and the PNC 33. Both produce their control signals in response to the output y and the desired output y.sub.r received from the input line 37. In this instance, the extant controller 31 produces satisfactory output u for controlling the process 32. The PNC in this case is used either to eventually replace the extant controller 31 or to act as a redundancy system, a back-up, or a system trained in environment of a process 32 which is replicated in many instances. In the last case, the PNC, once trained, can be removed from this one particular instance of process 32 and used in other similar processes.

Parameters p.sub.c, p.sub.p, p.sub.d 43 are normally input in this situation on line 42 into both the PNC and the extant controller 31. However, in many instances, the controller C 31 may have a different set of parameters input to it.

A processor 39 takes the difference of the outputs from line 34a(u.sub.PNC) and 38(u). This difference figure is fed to the learning algorithm 40 contained within the processor 39. The learning algorithm may be of various different types discussed ad nauseam in the literature. These include, for example, the well known methods of back-propagation, conjugate gradient algorithms and genetic algorithms, as well as numerous other possible training methods.

The result of the learning algorithm processing is a signal (line 41) to the PNC 33 to adjust the internal weights or, in fact, its configuration, if that is desired.

It should be noted that if an existing controller is available that provides satisfactory, robust performance, a neural network can be trained to mimic it, as shown here. That is, given the same input, if it is desired that the neural network and the existing controller provide the same output, this is possible. It is also possible to adjust the output so that it still mimics the existing controller based on input parameters 43 that may or may not be input to the extant controller 31. If the existing controller currently requires some parameters that are difficult to supply (e.g., their computation may be involved), the PNC can be provided some more readily available parameters instead. The PNC will then attempt to duplicate the extant controller behavior as accurately as possible given the new parameters. The neural network controller cannot be trained to outperform the existing controller in the set up. However, there are other advantages that still remain for this situation. It is likely that execution will be faster, code size and implementation will be reduced, the training can be done on-line without removing the extant controller 31 from the closed-loop, and different input parameters may be used.

We next describe an alternative approach to PNC development that does not require an existing controller to be available. This approach can result in nonlinear controllers which are substantially more powerful than existing controllers. This approach can also be used for processes that are difficult to control with conventional technology.

For example, the network can be trained so that the controller reduces, minimizes or optimizes criteria such as control energy, servo-response (including response time, maximum percent overshoot, bandwidth), disturbance rejection (including time to return to setpoint and maximum deviation from setpoint) and stability, to name a few. The trained neural network PNC using control parameters p.sub.c can allow on-line trade-offs between competing objectives. An example of a criterion would be a weighted sum of control energy and response error over some time interval, T. In this case, p.sub.c consists of two matricies, R and Q, ##EQU4##

The parameterized neurocontroller would be trained over a range of R and Q parameters (as well as over some simulated process world). Once trained, a user could adjust the controller parameters (p.sub.c) in accordance with whatever his current control objectives are.

Optimal PNC development requires the specification of the following information (although suboptimal development may ignore some of this):

One or more process models representative of the application or applications for which the PNC is intended. (For example, these models could be algebraic and/or dynamic; linear and/or nonlinear, lumped or distributed, as chosen by the user.)

A disturbance model (optional).

The control criterion, which may itself be parameterized (e.g., relative weightings on control action vs. servo response).

The inputs to the PNC. These include feedback inputs such as the error, the integrated error, the derivatives of the error, the setpoint, the process output, etc., as well as the controller parameters, including control, process and disturbance parameters. At least one control system parameter P must be included. Disturbance parameters can only be included if a disturbance model is specified.

Ranges should be specified for all process model parameters, including those that are not used as PNC input.

If the disturbance model is parameterized, ranges should be specified for all disturbance parameters, including those that are not used as PNC input.

Ranges for all control parameters must be specified.

The class of input signals to be used for PNC development must be specified. In most cases, it is expected that this will be step inputs (e.g., setpoint changes) of magnitudes within a specified interval.

It should be noted that ranges for all parameters need not be independent. In fact, in many cases it is expected that there will be significant dependencies. Thus, appropriate or reasonable values for control parameters could depend on process parameter values. Ranges can also be points--the corresponding parameter would be held constant. (To accomplish this in training, a module such as module 71 of FIG. 4 may be used.)

PNC development can be initiated once this information is specified. The development process is schematically depicted in FIG. 4. A parameterized neurocontroller 53 is placed in a simulated control loop with a generalized process model 54 in a closed-loop simulation system 52 which interacts with the PNC training algorithm 60. Input signals for the closed-loop, and parameter values for the process model 56 and for the PNC (55) are generated by a Consistent Parameter and Input Generation module (see infra). The closed-loop simulation system has the capability to evaluate the control criterion on the basis of the results of closed-loop simulations. It also has the ability to calculate gradients of the control criterion relative to the weights of the neural network when this information is needed. The criterion value is passed to the PNC Training Algorithm on line 62 and the gradients are passed to the PNC Training Algorithm (when needed) on line 63.

The function of the PNC Training Algorithm is essentially to configure the PNC to minimize the control criterion. This is done by determining the values of PNC weights but could also involve configuring the network itself, depending on the kind of training used. The PNC Training Algorithm 60 solves this problem in an iterative fashion, successively refining the network and/or its weight values until a minimum is reached. Many specific algorithms can be used for this purpose. Some of these require gradient computation while others do not. In a preferred embodiment a genetic algorithm is used. Genetic algorithms are powerful optimization algorithms. They allow an arbitrarily complex criterion and do not require gradient computation.

Referring again to FIG. 4, a parameterized neurocontroller 53 is placed into a simulated control loop with the process 54 in a closed loop simulation system 52 which interacts with the PNC training algorithm 60 and receives simulated parameter input 55s, while the process receives simulated parameter input on line 56s. The complete set of process model parameters is referred to as p.sub.p, the full set of disturbance model parameters are referred to as P.sub.d. These Parameters p.sub.p and p.sub.d are input into the process in simulation. A disturbance D is input to the process from box 71 through line 56a. These are a superset of parameters available in p.sub.p and p.sub.d to the PNC in simulation. These originate from the Consistent Parameter and Input Generator processor 71.

The output y and all the other signals relevant to evaluation by criterion set by the user are entered into the criteria evaluation unit 58 and the gradient computation unit 59. These units produce signal output representing J and ∇.sub.w J, respectively, where J is the control criterion and ∇.sub.w J, represents the gradients (partial derivatives) of J with respect to each weight in w.

Examples of how the PNC training algorithm 60 may work follow. In both cases, an initial set of weights w.sub.o is generated and then iteratively adjusted. Both of these examples assume network configuration is fixed. These examples are only that and not to be taken as limiting, since for various criterion and situations different methods may be preferred. (The best algorithm to use for a given situation may not be one of the two which follow.)

______________________________________A simple Gradient-Based Training Algorithm:______________________________________    w.sub.o  randomly generated    Repeat      w = w + η∇.sub.w J(w)    until ∇wJ(w) < E______________________________________

(Where η is a constant (learning rate parameter) and E is a small number (e.g., 0.001). When ∇wJ(w)<E, J is effectively minimized.)

______________________________________A simple Non-Gradient-Based Training Algorithm:w.sub.o randomly generated1          while J(w) < E22            generate w' in neighborhood of w3            if J(w') < J(w) then        w = w'4            else        goto 15          end while______________________________________

(where E2 is a small number).

This training simulator system 50 may be built as some combination of hardware and software, or all software, if desired. Lines 55 and 56 can provide either simulated or user adjusted parameter inputs. The setpoint or desired response input signal 61 (y.sub.r) may also be user defined or be provided in simulation.

The Consistent Parameter and Input Generator for processor or module 71 can include user specified classes of input signals, user specified ranges for parameters, and any dependencies among these ranges. This processor 71 may be a separate piece of hardware, or software, or integrated within the simulation processor. This information may be stored in box 71 preferably. This information is used to provide appropriate parameters and input signals to the closed loop simulation.

Numerous ways to connect the parameterized neurocontroller into the controlled system may be contemplated that are within the scope of this invention. See for example FIGS. 5a, 5b and 5c. In FIG. 5a an algorithm in the chooser may select the preferred output between the PNC output and that of, in this example, a PID controller. In FIG. 5b the PNC output is molded with the output of another controller, "Controller X" to produce u. Depending on the application and on the type of controller used, the closed-loop simulator training or extant-controller-based training may also comprehend the controller identified as "Controller X".

See also FIG. 5c, where an input controller, IC.sub.1, decides which of a series of differently trained (or having different P inputs) PNC's is appropriate for the error or the current operating point of the process. It (IC.sub.1) informs the process of its decision either by turning on one of the PNC's (PNC.sub.1 . . . PNC.sub.n) with an input on one of the lines 81 or by only allowing the signal output of the appropriate PNC to reach the process using a multiplexer type arrangement at the output. The latter arrangement would allow for simultaneous processing, giving IC.sub.1 more time to decide which PNC output to use. An alternate form IC.sub.2 (in dotted (an output controller)) is also shown in this figure. In this alternative, the suggested control moves are reviewed by IC.sub.2 and only the appropriate one is chosen. (It should be noted that one or more of the PNC's could be substituted with a more conventional controller in this figure.) All the forms suggested by these figures do not describe all the applications to which this PNC controller may be put, but are set out as examples to teach that what is claimed may be applied very broadly.

In general, it should be recognized that the use of references to x.sub.p, y, y.sub.r and u refers to these as vectors of arbitrary dimension (which also includes the scalar case of dimension=1). As multidimensional vectors, they may comprehend a single series or multiple series of values, thus including both SISO and MISO/MIMO configurations.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 is a block diagram of a parameterized neurocontroller (PNC) in a closed loop system where it provides signals representing control moves to the process.

FIG. 2 is a graph of time vs. the process output y, indicating various control curves achievable using different control strategies.

FIG. 3 is a block diagram illustrating a preferred embodiment configuration for training a PNC based on an extant controller.

FIG. 4 is a heuristic block diagram illustrating closed loop simulation training of a PNC.

FIG. 5a is a block diagram of a potential control system in which this invention can be employed.

FIGS. 5c and 5b are also block diagrams of other configurations of a control system to which this invention can be applied.

This patent relates to controllers that supply signals to controlled processes enclosed with control systems and, more particularly, to those controllers that are responsive to process variation, to changing objectives on the part of the user of the controlled system or process, and to disturbance features of the process (such as noise), as well as to how the process is controlled.

BACKGROUND OF THE INVENTION

Algorithmic controllers need to be extraordinarily complex to provide the features provided by a neural network controller as described in this patent. Accordingly, a tremendous amount of development time is avoidable by using the teachings of this invention.

Artificial neural networks have the potential to provide revolutionary capabilities to control systems, including the ability to accurately model, based on input/output data, highly nonlinear and multidimensional functions and dynamical systems. They can provide compact, efficient implementations with high degrees of generalization and robustness, and are highly suitable for hardware implementation at the present time.

However, except for the applicant's NeuroPID Controller (the subject of U.S. patent application Ser. No. 07/829,996, filed Jan. 31, 1992), now U.S. Pat. No. 5,396,415 issued Mar. 7, 1995 no neural net controller implementation comes close to achieving these potential advantages, and its application is limited as will be discussed later. In the NeuroPID, the controller is application independent, an important feature. Controller behavior can be adjusted for different applications through a specific set of controller parameters, i.e., the Proportional, the Integral, and the Derivative gains. These are the same parameters that are employed by conventional linear PID controllers. The NeuroPID implements an optimized nonlinear controller with a PID interface.

The NeuroPID can be contrasted with the prior art teachings for developing neural network controllers. In prior neural network controllers, neural networks are developed for specific process models and no explicit allowance is made for different processes, for process variation, for disturbances or for changing requirements (due to user demand) for the control system.

Other examples of the use of neural networks in control applications includes system identification, both structural and parameter identification and automatic tuning. In these cases (and unlike the NeuroPID controller and Parameterized Neurocontrollers), the neural network is not itself a controller, but provides information that is useful to improve the performance of a separate, non-neural controller.

Although the NeuroPID controller is a significant advance over the prior art, the restriction to the three PID parameters renders it of limited utility to many applications--in particular, to multivariable processes, highly nonlinear processes, and processes with significant time delays.

It has been discovered that the concepts described in the NeuroPID Controller can be generalized to comprehend significantly broader applications. This generalization is achieved by allowing a greater variety of parameters as input to the controller. The generalized parameters allow the behavior of the neural net controller to be modified by a user, a software, or a hardware system that are linked to the controller in some appropriate way. Any parameters or sets thereof may be used with this invention. No previous neural network controllers could do that.

There are three different kinds of parameters which may be allowed as input to the neural net controller. These are: Control Parameters, p.sub.c, Process Parameters, p.sub.p, and Disturbance Parameters, p.sub.d. Control parameters are generally the kind of parameters that allow modification of controller behavior for any given process. Examples of control parameters are: relative weightings for servo-response accuracy vs. control energy; time to reach set point; time to return to set point after a disturbance; rise time; settling time; the horizon (over which the future is judged in making determinations about whether a series of control moves is satisfactory or not); the maximum allowable rate of actuator movement; proportional, integral and derivative (PID) gain parameters; and reference model parameters, future reference responses, etc.

Process parameters relate to distinguishing aspects of the particular processes the controller is developed for. These include: dead time or delay; the process time constant; the process gain; process damping coefficient; process dynamic order; relative amounts of various nonlinear characteristics (e.g., exponential, quadratic, logarithmic, hysteretic); and other parameters which may be used to encode a broad range of nonlinearities in the process; among others.

Disturbance parameters relate to factors external to the process but which affect its behavior. These are commonly thought of in many control situations as noise. Examples include (in a building temperature control application): people entering or leaving; changes in environmental conditions, including overcast weather vs. sunny days; ambient external temperature; and so forth. In order for these types of parameters, p.sub.d, to be used as inputs to a neural network controller (and perhaps to any controller), the disturbance parameters must be either measurable, modelable or predictable.

In any specific parameterized neurocontroller, any one or two, or even all three of these parameter types may be used. Each one of these parameter types may consist of any number of individual parameters depending on the desired result.

SUMMARY OF THE INVENTION

This invention teaches a controller based on a neural network whose output is responsive to input signals that represent user defined, or designer defined, parameters which may include parameters from all or some of the parameter types; process parameters (p.sub.p), control parameters (p.sub.c), and disturbance parameters (p.sub.d). When referred to together these are called control system parameters P. There may be any number (from zero to whatever number runs out the controller capacity or designer patience) of parameters selected from any one, two, or all three of the P groups of parameters.

In the preferred embodiment, the neural network is a dynamic or algebraic (e.g., feed forward) network. Examples include multilayer perceptron networks described by David E. Rumelhart, Geoffrey E. Hinton and Ronald J. Williams (Learning internal representations by error propagation. In "Parallel Distributed Processing: Explorations in the Microstructure of Cognition, Vol. 1", D. E. Rumelhart and J. L. McClelland (Eds.), Cambridge, Mass.: MIT Press, 1986), and radial-basis function networks by John Moody and Christian J. Darken (Fast learning in networks of locally-tuned processing units. "Neural Computation", 1, pp. 281-294, 1989), which are well known algebraic forms.

Barak A. Perlmutter (Learning state space trajectories in recurrent neural networks. "Neural Computation", 1, pp. 263-269, 1989) describes a dynamic, continuous time type network which could be used. Jeffrey L. Elman ("Finding Structure in Time", Technical Report 8801, Center for Research in Language, University of California, San Diego, La Jolla, Calif. 92093, 1988), describes a dynamic, discrete time type network which could also be used. In fact, nearly any type of neural network can be used.

However, we have some concerns about the typical Hopfield variety which is constrained in that it accepts one and only one input to each node from outside the network and each node communicates with every other node, and where any two nodes (i,j) share weight values (such that w.sub.ij =w.sub.ji). Such networks are likely to be unsatisfactory.

In general, the network produces output that is some function of the P parameters used, the weights in the network, and error feedback inputs. Error feedback inputs may include the process output, the setpoint or reference model output, the error between the setpoint and the actual output, integrals and/or derivatives of this error, process state variable estimates, and so forth.

Such a neural network can be trained to mimic an extant controller, in one preferred embodiment, by the addition of a processor for running the learning algorithm which receives output from the parameterized neurocontroller (hereinafter "PNC") and the extant controller. Either before or in the learning algorithm processor, a comparison of the two is done until an appropriate level of proficiency is demonstrated by the neural network controller. The extant controller output is taken on-line in the closed loop. The training can be done on-line, or later with collected data.

Training can also be done off-line over a variety of process models. A development system for creating PNC's is also described.

Training of the neural network is generally based on determining values of network weights that optimize some criterion of interest. A number of specific stochastic and deterministic algorithms can be used, including genetic algorithms, "chemotaxis", back propagation, counter propagation, conjugate gradient, and other first and second order methods known to those of skill in the art. Network "training" may also actually involve configuring or determining the structure of the nodes and their relations using genetic algorithms or other methods known to those of skill in the art. The criteria are selected by the user or customer for the controller.

Citations de brevets
Brevet cité Date de dépôt Date de publication Déposant Titre
US5111531 *8 janv. 19905 mai 1992Automation Technology, Inc.Process control using neural network
US5142612 *3 août 199025 août 1992E. I. Du Pont De Nemours & Co. (Inc.)Computer neural network supervisory process control system and method
US5159660 *11 oct. 199027 oct. 1992Western ThunderUniversal process control using artificial neural networks
US5268834 *24 juin 19917 déc. 1993Massachusetts Institute Of TechnologyStable adaptive neural network controller
EP0519502A1 *19 juin 199223 déc. 1992Nisshinbo Industries, Inc.Pulp-like composite material and process for production thereof
Citations hors brevets
Référence
1 *C. C. Ku et al., System Identification and Control Using Diagonal Recurent Neural Networks , Jun., 1992, 1992 American Control Conference, at Chicago, Ill., vol. 2, pp. 545 549.
2C.-C. Ku et al., "System Identification and Control Using Diagonal Recurent Neural Networks", Jun., 1992, 1992 American Control Conference, at Chicago, Ill., vol. 2, pp. 545-549.
3 *H T. Su et al., Control and System Identification Using Elements of Neural Network Computation Engineering , Jun., 1992, 1992 American Control Conference, at Chicago, Ill., vol. 1, pp. 485 489.
4H-T. Su et al., "Control and System Identification Using Elements of Neural Network Computation Engineering", Jun., 1992, 1992 American Control Conference, at Chicago, Ill., vol. 1, pp. 485-489.
5J. J. Helferty et al., "Experiments in Adaptive Control Using Artificial Neural Networks", Aug., 1990, IEEE International Conference on Systems Engineering, in Pittsburgh, Pa., pp. 339-342.
6 *J. J. Helferty et al., Experiments in Adaptive Control Using Artificial Neural Networks , Aug., 1990, IEEE International Conference on Systems Engineering, in Pittsburgh, Pa., pp. 339 342.
Référencé par
Brevet citant Date de dépôt Date de publication Déposant Titre
US5745385 *25 avr. 199428 avr. 1998International Business Machines CorproationMethod for stochastic and deterministic timebase control in stochastic simulations
US5826065 *13 janv. 199720 oct. 1998International Business Machines CorporationSoftware architecture for stochastic simulation of non-homogeneous systems
US5828567 *7 nov. 199627 oct. 1998Rosemount Inc.Diagnostics for resistance based transmitter
US5956663 *26 mars 199821 sept. 1999Rosemount, Inc.Signal processing technique which separates signal components in a sensor for sensor diagnostics
US6017143 *28 mars 199625 janv. 2000Rosemount Inc.Device in a process system for detecting events
US6047220 *29 déc. 19974 avr. 2000Rosemount Inc.Device in a process system for validating a control signal from a field device
US6078843 *24 janv. 199720 juin 2000Honeywell Inc.Neural network including input normalization for use in a closed loop control system
US6119047 *10 nov. 199712 sept. 2000Rosemount Inc.Transmitter with software for determining when to initiate diagnostics
US6187145 *19 mars 199613 févr. 2001Siemens AktiengesellschaftMethod for process management in paper and cardboard manufacture
US623006230 juin 19998 mai 2001Voyan TechnologyAdaptation to unmeasured variables
US6278898 *30 juin 199921 août 2001Voyan TechnologyModel error bounds for identification of stochastic models for control design
US629845422 févr. 19992 oct. 2001Fisher-Rosemount Systems, Inc.Diagnostics in a process control system
US635619117 juin 199912 mars 2002Rosemount Inc.Error compensation for a process fluid temperature transmitter
US64045814 oct. 200011 juin 2002Voyan TechnologyAdaptation to unmeasured variables
US6430452 *15 oct. 19976 août 2002AlcatelControl circuit for regulating at least two controlled variables
US6493596 *28 févr. 200010 déc. 2002Pavilion Technologies, Inc.Method and apparatus for controlling a non-linear mill
US6556980 *28 août 199829 avr. 2003General Cyberation Group, Inc.Model-free adaptive control for industrial processes
US65571188 mars 200129 avr. 2003Fisher Rosemount Systems Inc.Diagnostics in a process control system
US66150907 févr. 20002 sept. 2003Fisher-Rosemont Systems, Inc.Diagnostics in a process control system which uses multi-variable control techniques
US66337827 févr. 200014 oct. 2003Fisher-Rosemount Systems, Inc.Diagnostic expert in a process control system
US6684112 *11 avr. 200127 janv. 2004General Cybernation Group, Inc.Robust model-free adaptive control
US6684115 *11 avr. 200127 janv. 2004General Cybernation Group, Inc.Model-free adaptive control of quality variables
US6735483 *9 déc. 200211 mai 2004Pavilion Technologies, Inc.Method and apparatus for controlling a non-linear mill
US674508714 déc. 20001 juin 2004Tokyo Electron LimitedMethod for control of a plant
US6745169 *26 juil. 19961 juin 2004Siemens AktiengesellschaftLearning process for a neural network
US6757570 *31 mai 200029 juin 2004Guided Systems Technologies, Inc.System and method for adaptive control of uncertain nonlinear processes
US679579810 mai 200121 sept. 2004Fisher-Rosemount Systems, Inc.Remote analysis of process control plant data
US681353228 févr. 20022 nov. 2004Fisher-Rosemount Systems, Inc.Creation and display of indices within a process plant
US691523513 mars 20035 juil. 2005Csi Technology, Inc.Generation of data indicative of machine operational condition
US692533828 févr. 20022 août 2005Fisher-Rosemount Systems, Inc.Fiducial technique for estimating and using degradation levels in a process plant
US695471310 janv. 200211 oct. 2005Fisher-Rosemount Systems, Inc.Cavitation detection in a process plant
US696580628 févr. 200215 nov. 2005Fisher-Rosemount Systems Inc.Automatic work order/parts order generation and tracking
US697521929 juin 200113 déc. 2005Fisher-Rosemount Systems, Inc.Enhanced hart device alerts in a process control system
US7016743 *14 janv. 200421 mars 2006General Cybernation Group, Inc.Model-free adaptive control of quality variables
US7024252 *26 sept. 20054 avr. 2006Pavilion Technologies, Inc.Kiln thermal and combustion control
US703074726 févr. 200418 avr. 2006Fisher-Rosemount Systems, Inc.Method and system for integrated alarms in a process control system
US703947322 mars 20042 mai 2006Guided Systems Technologies, Inc.System and method for adaptive control of uncertain nonlinear processes
US7047089 *11 mai 200416 mai 2006Pavilion TechnologiesKiln thermal and combustion control
US707998422 oct. 200418 juil. 2006Fisher-Rosemount Systems, Inc.Abnormal situation prevention in a process plant
US710342728 févr. 20035 sept. 2006Fisher-Rosemont Systems, Inc.Delivery of process plant notifications
US711083423 sept. 200319 sept. 2006Pavilion Technologies, Inc.Kiln thermal and combustion control
US713961922 déc. 200521 nov. 2006Pavilion Technologies, Inc.Kiln free lime control
US71495903 janv. 200512 déc. 2006Pavilion Technologies, Inc.Kiln control and upset recovery using a model predictive control in series with forward chaining
US71520728 janv. 200319 déc. 2006Fisher-Rosemount Systems Inc.Methods and apparatus for importing device data into a database system used in a process plant
US716253410 juil. 20019 janv. 2007Fisher-Rosemount Systems, Inc.Transactional data communications for process control systems
US71777107 juin 200513 févr. 2007Guided Systems Technologies, Inc.System and method for adaptive control of uncertain nonlinear processes
US718165417 sept. 200420 févr. 2007Fisher-Rosemount Systems, Inc.System and method for detecting an abnormal situation associated with a reactor
US729941516 juin 200320 nov. 2007Fisher-Rosemount Systems, Inc.Method and apparatus for providing help information in multiple formats
US7321882 *5 oct. 200122 janv. 2008Fraunhofer-Gesellschaft Zur Foederung Der Angewandten Forschung E.V.Method for supervised teaching of a recurrent artificial neural network
US7363094 *9 janv. 200622 avr. 2008General Electric CompanyMultivariable controller design method for multiple input/outputs systems with multiple input/output constraints
US738920422 oct. 200417 juin 2008Fisher-Rosemount Systems, Inc.Data presentation system for abnormal situation prevention in a process plant
US7415446 *19 oct. 200419 août 2008General Cybernation Group, Inc.Model-free adaptive (MFA) optimization
US741830121 févr. 200626 août 2008Pavilion Technologies, Inc.Method and apparatus for approximating gains in dynamic and steady-state processes for prediction, control, and optimization
US749331021 mars 200317 févr. 2009Fisher-Rosemount Systems, Inc.Data visualization within an integrated asset data system for a process plant
US749641413 sept. 200624 févr. 2009Rockwell Automation Technologies, Inc.Dynamic controller utilizing a hybrid model
US751597730 mars 20047 avr. 2009Fisher-Rosemount Systems, Inc.Integrated configuration system for use in a process plant
US753627414 mars 200519 mai 2009Fisher-Rosemount Systems, Inc.System and method for detecting an abnormal situation associated with a heater
US760023410 déc. 20026 oct. 2009Fisher-Rosemount Systems, Inc.Method for launching applications
US761010821 févr. 200627 oct. 2009Rockwell Automation Technologies, Inc.Method and apparatus for attenuating error in dynamic and steady-state processes for prediction, control, and optimization
US763438418 mars 200315 déc. 2009Csi Technology, Inc.Asset optimization reporting in a process plant
US7637735 *19 avr. 200729 déc. 2009Powitec Intelligent Technologies GmbhProcedure for regulating a combustion process
US765739925 juil. 20062 févr. 2010Fisher-Rosemount Systems, Inc.Methods and systems for detecting deviation of a process variable from expected values
US76607019 juin 20059 févr. 2010Fisher-Rosemount Systems, Inc.System and method for detecting an abnormal situation associated with a process gain of a control loop
US7668795 *29 août 200523 févr. 2010Fuji Xerox Co., Ltd.Data analyzer utilizing the spreading activation theory for stemming processing
US767628722 oct. 20049 mars 2010Fisher-Rosemount Systems, Inc.Configuration system and method for abnormal situation prevention in a process plant
US782700631 janv. 20072 nov. 2010Fisher-Rosemount Systems, Inc.Heat exchanger fouling detection
US785333928 sept. 200714 déc. 2010Fisher-Rosemount Systems, Inc.Statistical signatures used with multivariate analysis for steady-state detection in a process
US785343120 mars 200714 déc. 2010Fisher-Rosemount Systems, Inc.On-line monitoring and diagnostics of a process using multivariate statistical analysis
US791267625 juil. 200622 mars 2011Fisher-Rosemount Systems, Inc.Method and system for detecting abnormal operation in a process plant
US791724020 mars 200729 mars 2011Fisher-Rosemount Systems, Inc.Univariate method for monitoring and analysis of multivariate data
US793716428 sept. 20073 mai 2011Fisher-Rosemount Systems, Inc.Multivariate detection of abnormal conditions in a process plant
US795384219 févr. 200331 mai 2011Fisher-Rosemount Systems, Inc.Open network-based data acquisition, aggregation and optimization for use with process control systems
US795793611 févr. 20087 juin 2011Fisher-Rosemount Systems, Inc.Presentation system for abnormal situation prevention in a process plant
US796614928 sept. 200721 juin 2011Fisher-Rosemount Systems, Inc.Multivariate detection of transient regions in a process control system
US801488020 mars 20076 sept. 2011Fisher-Rosemount Systems, Inc.On-line multivariate analysis in a distributed process control system
US80323404 janv. 20074 oct. 2011Fisher-Rosemount Systems, Inc.Method and system for modeling a process variable in a process plant
US80323414 janv. 20074 oct. 2011Fisher-Rosemount Systems, Inc.Modeling a process using a composite model comprising a plurality of regression models
US80367639 janv. 200911 oct. 2011Rockwell Automation Technologies, Inc.Dynamic controller utilizing a hybrid model
US814535825 juil. 200627 mars 2012Fisher-Rosemount Systems, Inc.Method and system for detecting abnormal operation of a level regulatory control loop
US831167321 févr. 200613 nov. 2012Rockwell Automation Technologies, Inc.Method and apparatus for minimizing error in dynamic and steady-state processes for prediction, control, and optimization
WO2000013071A124 août 19999 mars 2000General Cybernation Group, Inc.Model-free adaptive control for industrial processes
WO2000060423A1 *7 avr. 200012 oct. 2000Voyan TechnologyModel error bounds for identification of stochastic models for control design