Developing Networked Control Labs: A Matlab and Easy Java Simulations Approach

Download as pdf or txt
Download as pdf or txt
You are on page 1of 10

3266 IEEE TRANSACTIONS ON INDUSTRIAL ELECTRONICS, VOL. 57, NO.

10, OCTOBER 2010

Developing Networked Control Labs: A Matlab and


Easy Java Simulations Approach
Gonzalo Farias, Robin De Keyser, Sebastián Dormido, and Francisco Esquembre

Abstract—The new information technologies provide great op- control labs (see, for instance, [4] and [8]). Our approach uses
portunities in control education. One of them is the use of remote an alternative architecture, considering the controller at the
control labs to teach the behavior of control systems through client side. The insertion of the communication network in the
a network. In this paper, a new approach to create interactive
networked control labs is described. Two main software tools are feedback control loop makes the analysis and design of these
used: Matlab and Easy Java Simulations. The first one is a widely systems complex. Network delays in control loops can impose
used tool in the control community, whereas the second one is an severe degradation on system performance. These delays have
authoring tool, designed to build interactive applications in Java interesting consequences from the control education point of
without special programming skills. The remote labs created by view, and they will be analyzed for a particular plant.
this approach give to students the opportunity to face the effects of
network delays on the controlled system and also to specify on the The approach presented here considers mainly two software
fly their own control algorithm. tools: Matlab [9] and Easy Java Simulations (EJS) [10], [11].
Matlab is widely used software in the control community, being
Index Terms—Control education, Easy Java Simulations (EJS),
Matlab, networked control labs, virtual labs. one of the reasons why we decided to use this tool to control a
real plant. On the other hand, EJS is an authoring tool which
is designed to create interactive applications in Java without
I. I NTRODUCTION special programming skills. By using these tools, teachers can
build networked control labs with a high degree of interactivity
C ONTROL education has to adapt to the new scenario
that the information technologies provide [1], [2]. In this
context, interactive remote labs take advantage of these new
and visualization.
Commonly, remote labs come with predefined controllers
that can only be tuned or mixed by end users in order to
possibilities to improve the understanding of the system be-
produce a customized controller (see, for example, [4], [6], and
havior [3], [4]. Interactivity is a crucial aspect when designing
[8]). However, and taking advantage that Matlab script is an
software applications that are to be used in the field of control
interpreted language, our approach enhances the customization,
engineering for pedagogical purposes. This interactivity should
also allowing students to define on the fly their own control
allow the student to simultaneously visualize the response of
algorithm, which provides great flexibility for the designing of
the system on the fly to any change, such as a step or a
many control strategies.
new PID configuration, introduced by the user. This immediate
This paper is organized as follows. In Section II, the connec-
observation of the change in the system output, as response to
tion between EJS and Matlab is presented. Section III describes
user interaction, is what really helps the student to get useful
the required process to build a networked control lab. A real
practical insight into control system theory [5].
implementation of a lab is described in Section IV. Finally,
This paper is focused on providing new tools to teachers that
some conclusions of the work are presented.
want to use networked control labs as part of the educational
process in the course on industrial electronic and/or control en-
gineering. A networked control system is a remote lab wherein II. L INKING EJS AND M ATLAB
the control loops are closed through a network [6], [7]. The
In this section, the connection between EJS and Matlab will
location of the controller at the server side, i.e., next to the real
be described in detail.
plant, is a widely used architecture for the design of remote

A. EJS
Manuscript received December 28, 2008; revised May 28, 2009 and
July 31, 2009; accepted December 23, 2009. Date of publication February 8, EJS is a free software tool for rapid creation of applica-
2010; date of current version September 10, 2010. tions in Java with high-level graphical capabilities and with
G. Farias and S. Dormido are with the Department of Computer Science
and Automatic Control, Universidad Nacional de Educación a Distancia, 28040
an increased degree of interactivity. The applications created
Madrid, Spain (e-mail: gfarias@bec.uned.es; sdormido@dia.uned.es). by EJS can be standalone Java applications or applets, and
R. De Keyser is with the Department of Electrical energy, Systems and for simplicity, we call them here EJS applications or simply
Automation, Ghent University, 9000 Ghent, Belgium (e-mail: rdk@autoctrl.
UGent.be). applications. The source files of the EJS applications are saved
F. Esquembre is with the Department of Mathematics, University of Murcia, in a customized xml format. EJS is different from most other
30100 Murcia, Spain (e-mail: fem@um.es). authoring tools in that EJS is not designed to make life easier for
Color versions of one or more of the figures in this paper are available online
at http://ieeexplore.ieee.org. professional programmers but has been conceived for science
Digital Object Identifier 10.1109/TIE.2010.2041130 students and teachers.

0278-0046/$26.00 © 2010 IEEE


FARIAS et al.: DEVELOPING NETWORKED CONTROL LABS: A MATLAB AND EASY JAVA SIMULATIONS APPROACH 3267

Fig. 2. GUI of a simple virtual oscilloscope which uses Matlab to evaluate a


function entered by user.

Fig. 1. GUI of the view section of EJS.

EJS structures the application in two main parts, the model


and the view (see Fig. 1). The model can be described by
means of pages of Java code and ordinary differential equations
or by connecting to external applications (such as Matlab).
The view provides the visualization of the application and
also the user interface elements required for user interaction.
These view elements can be chosen from a set of predefined
components to build a treelike structure. Model and view can
be easily interconnected so that any change in the model state
Fig. 3. Defining Matlab as external application in EJS. Notice that the EJS
is automatically reflected by the view, and vice versa. variables time and value are connected to the Matlab variables t and x,
respectively.

B. Using Matlab as an External Application in EJS command changes the values of the Matlab variables, the virtual
oscilloscope plots the corresponding function.
EJS can set a link with external applications like Scilab,
The required steps to build the virtual oscilloscope in EJS
Sysquake, and Matlab/Simulink [12]. The connection with
will be presented in detail in the following.
Matlab is quite interesting because Matlab is a well-known
technical software tool in the engineering community. This link Steps 1 and 2) To select Matlab as an external application, the
uses the JMatlink library [13] and the Engine library to control authors simply need to introduce the string matlab in
Matlab from EJS applications. the text field External File in the subsection Variables of
Authors can create virtual or remote labs (i.e., pedagogical the Model (see Fig. 3). After that, authors have to create
applications) with a high level of interactivity and visualization and connect EJS variables with Matlab variables using the
using the EJS–Matlab link. In this case, Matlab is used for com- column connected to. In this case, time and value are EJS
puting and processing data by means of the toolboxes, whereas variables which are connected to Matlab variables t and x,
EJS provides the graphical support and the user interaction of respectively. There are also built-in functions in EJS that
the Java application. The procedure to connect the application directly read or write variables in the Matlab workspace.
and Matlab can be summarized in four steps. Step 3) To control the execution of Matlab code from the
Java application, EJS provides different built-in func-
1) Select Matlab as an external application in EJS. tions. One of them is _external.step(), which allows the
2) Create and connect the EJS variables with Matlab. execution of a specific command. Normally, this built-
3) Control the execution of Matlab code. in function is located in the subsection Evolution to
4) Define the view and the user interaction. execute the code in an iterative way. The command
A simple example will be used to explain in more detail has to be previously defined using the built-in function
the link between Matlab and the Java application created by _external.setCommand(commandM). Notice that this func-
EJS. The example is a virtual oscilloscope which shows a tion needs a string variable (in this case, commandM)
plot of a function versus time. The idea is that end users whose value is the command that will be executed by
enter a command which will be evaluated in Matlab, and the _external.step(). In the example (see Fig. 3), the command
application depicts in a plot (see Fig. 2) the values of two to execute has the following initial value: t = t + 0.1 and
Matlab variables (x and t). As the continuous iteration of the x = sin(t).
3268 IEEE TRANSACTIONS ON INDUSTRIAL ELECTRONICS, VOL. 57, NO. 10, OCTOBER 2010

Fig. 4. Properties of the text field used by end users to enter a function. Notice
that the function will be evaluated in Matlab when a user presses the return key
(property Action) in the text field.
Fig. 5. Scheme of the remote Matlab–EJS connection.

Step 4) The initial command can be modified by end users


using the text field of the view, which is highlighted in
Fig. 2. To add this interaction, the text field is connected
to the variable commandM and to the built-in function
_external.setCommand(commandM) using the properties
of the text field (see Fig. 4). This interaction means that,
when end users modify the value of the string in the text
field, the value of the variable commandM will also be
modified, and then, the new command will be executed by
the built-in function _external.step(). Thus, finally, the plot
will show the graphic of the modified function.
EJS also has built-in functions that allow interacting at low
level with Matlab. The three most important functions are as
follows.
1) _external.eval(String): A method to execute a string vari- Fig. 6. Defining remote Matlab as external application in EJS.
able in Matlab (similar to function eval of Matlab).
2) _external.getDouble (“MatlabVariable”): A method
that returns the value of a Matlab variable. by Matlab), whereas the interface is used to show the results
3) _external.setValue (“MatlabVariable,” Value): A method and to support the user interaction.
that modifies the value of a Matlab variable.
In [11], [12], and [14], a more detailed description is pre-
sented about the connection between EJS and Matlab. D. Types of Links in Jim
There are two kinds of link between Jim and EJS applica-
tions, i.e., synchronous and asynchronous. The synchronous
C. Jim Server
link is quite similar to a local connection between an EJS
The previous link between Matlab and the Java application application and Matlab, i.e., the execution of a command is
is direct if both software are in the same computer. However, if done in a coordinated way. This implies that the application
end users do not have Matlab in their computers, they are not decides when Matlab executes a command. The performance
able to execute the Java application which uses the EJS–Matlab of a synchronous link is good when the network delays are
link. For this reason, when Matlab and the application are negligible, as in a local area network. However, in a wide area
located in different computers, we need to use Jim server. This network, e.g., Internet, the time required to exchange informa-
free software tool, written in Java [14], [15], allows for an EJS tion between client and server could become much longer. This
application to use a remote Matlab server. Therefore, using is where the asynchronous link comes in handy, because this
Jim, end users can execute applications which use Matlab, even link has been developed to minimize the effect of the network
though users do not have Matlab in their computers. In order delays. In this case, the application does not continuously
to set the extended link, Jim has to be located in the remote keep coordination with the remote Matlab, and therefore, the
computer where Matlab is installed. In addition, the application command execution in a remote Matlab is indirectly controlled
has to be modified to indicate the remote service. by EJS application.
The remote connection uses a network protocol to support the One of the advantages of the synchronous link is that, when
exchange of information between Jim and the EJS application. an author wants to transform an EJS application that uses
The scheme of the connection between EJS applications, Jim, local Matlab to use a remote Matlab, the required changes are
and Matlab is shown in Fig. 5. At the client side, there is an minimal. For instance, if we decide to transform the virtual
EJS application connected to Jim server by TCP/IP protocol. oscilloscope, in order to use a synchronous link with a remote
At the server side, Matlab is controlled by Jim server in order Matlab, the only one requirement is to modify the source file
to response to the requests of the EJS application. Similar to the to enter in the text field External File the IP address (e.g.,
local link case, the library JMatlink is used to control Matlab 10.195.2.57) and the Port (e.g., 2005) of the server. This change
from Jim server. Normally, a Java application that uses this is shown in Fig. 6. After that, end users are enabled to use the
scheme does most of the computation at the server side (i.e., virtual oscilloscope through a network.
FARIAS et al.: DEVELOPING NETWORKED CONTROL LABS: A MATLAB AND EASY JAVA SIMULATIONS APPROACH 3269

access to the streams of IP cameras is quite direct and simple to


use in EJS.
There are many options when developers require controlling
external hardware (plants) from computers. In our case, differ-
ent DAQ cards could be used; the only one restriction in this
approach is that the selected card has to be compatible with
Matlab. The communication process with the DAQ card can
be done using the Data Acquisition Toolbox. This toolbox is
a collection of M-file functions and Dynamic Link Library that
enable users to interface with specific hardware. The toolbox
provides users with the following main features:
Fig. 7. Elements required for a networked control lab implemented with 1) a framework for bringing live measured data into the
Matlab–EJS approach. MATLAB workspace using PC-compatible plug-in data
acquisition hardware;
The case of the asynchronous link is slightly different be- 2) support for analog input (AI), analog output (AO), and
cause, in addition to the previous changes, authors also need digital I/O subsystems, including simultaneous analog
to use the built-in function _external.synchronize(). Normally, I/O conversions.
this built-in function has to be executed when end users interact For further information about the toolbox, see [16].
with the view of the application (e.g., moving sliders).
The choice between both links depends on the kind of B. Acquisition Process From DAQ Cards
application that the author wants and also the context where
the application is going to be used. From the remote control A typical code to initiate the data acquisition process using
lab point of view, an asynchronous link could be useful if the the toolbox of Matlab is shown in code listing 1. In this case,
controller is located at the server side, which means that the there are two input channels and also two output channels. The
lab is used mainly to monitor a remote plant. Otherwise, if input channels are created to read the position and the speed
the controller is located at the client side, the synchronous of a servo motor. One output channel is used to send out the
link has to be used. For this reason, the approach of this work command signal to the motor, and the other one is used to
uses the synchronous link for the networked control labs. More feed the position sensor (a potentiometer). After the channels
details about the Jim server can be found in [14]. have been created, it is necessary to configure the DAQ card to
continuously acquire the data.

III. B UILDING N ETWORKED C ONTROL L ABS Listing 1. Initiate data acquisition process
%Create input channels
In this section, the main tools and actions required to create a AI = analoginput (“nidaq,” “1”);
networked control lab will be presented. First, the software and Speed = addchannel (AI,1);
hardware issues will be discussed. Later on, the communication Position = addchannel (AI,0);
process with the plant will be detailed. Finally, the core control set (AI, “InputType,” “SingleEnded”);
code of the lab will be presented. AI.Channel.InputRange = [−10 10];
%Create output channels
AO = analogoutput (“nidaq,” “1”);
A. Software and Hardware Required
VoltOutSpeed = addchannel (AO, 0);
The approach presented in this work can be summarized in VoltOutPosition = addchannel (AO,1);
Fig. 7. As shown in this figure, there are other tools in order to %Configurate sampling and trigger
put online the control lab for students. Among others, we need set ([AI, AO], “SampleRate,” 1/0.05);
at least a Web server, an IP camera, and a data acquisition card set (AI, “TriggerType,” “Immediate”);
(DAQ card). set (AO, “TriggerType,” “Immediate”);
The Web server is required if authors want to put the remote %Acquire data continuously
labs as applets. Moreover, a Web server is needed if the teacher set (AI, “SamplesPerTrigger,” inf);
adds some virtual labs, simulations, or documentation in the %Send out initial volts
Web site. A good option to provide this service could be Apache putdata (AO, [0, 1]);
Tomcat. This Web server also offers security features called start ([AO AI]);
authorization, authentication, and access control in order to
allow only access to authorized students. After the initialization has been done, the channels can be ac-
To show students a view of the real plant, a simple Web cessed from the EJS application (by means of the EJS–Matlab
camera can be used. However, it is preferable to use an IP link). The code listing 2 shows the Java code used to read and
camera since it has a built-in Web server that can stream video write the input/output channels. Notice that the code required
images directly to the Internet. Moreover, EJS has a specific to interface the DAQ card is sent to Matlab from the application
visual element to display the video from stream servers, so the using the built-in function _external.eval(String).
3270 IEEE TRANSACTIONS ON INDUSTRIAL ELECTRONICS, VOL. 57, NO. 10, OCTOBER 2010

Listing 2. Read and Write the channels from EJS


public double [] getData (){
double [] data;
//Read input channels
_external.eval (“s = [toc, peekdata(AI, 1)];”);
data = _external.getDoubleArray (“s”);
return (_data);
}
public double sendOut (double cmd){
Fig. 8. Scheme of the implemented remote lab.
//Saturation of command signal
cmd = commandLimits (cmd); mented lab is presented. Notice that the continuous-time system
//Write output channels is controlled by a discrete-time controller with a sampling
_external.eval(“putdata (AO, [“+cmd+,” 1])”); period of 50 ms. The networked control lab is divided in three
_external.eval (“start(AO)”); sections: the client side, the network, and the server side.
return (cmd); The implemented lab uses two Matlab sessions, one located
} at client side to compute the control signal and another one
located at the server side to interface the servo motor through
C. Control Loop of the Lab the DAQ card 6024E. At each sampling time, the Jim server
collects data from the plant by using the Matlab engine at the
The main loop of the networked control lab is displayed in server side. Then, the Jim server sends data to the EJS appli-
code listing 3. The code presented is part of the EJS application cation by using standard TCP/IP Java methods. The application
and has to be located in an Evolution page of the Model in order uses the data and the local Matlab engine to compute the control
to execute the code continuously. The code has three main parts: signal by means of executing a Matlab script (which can be
open loop, closed loop, and getting data. In the open-loop mode, modified online by the student). Then, the application retrieves
the input, given by the user (commandUser), is directly sent out the value of the control signal from the local Matlab engine and
to the real plant. In the closed-loop mode, the control signal sends it via TCP/IP to the Jim server. Finally, the Jim server
is computed using the function controller, and then, the signal sends out the computed control action to the servo motor by
is sent out to the motor. Finally, after the open- or closed-loop means of the server Matlab engine.
stages have been executed, the data are read from the sensors
of the plant. Notice that the functions for reading and writing
A. Computing the Control Signal
the channels (getData and sendOut) have been defined earlier
in listing 2. As it was said before, the lab uses a local connection with
Matlab to evaluate the control action. This means that students
Listing 3. Main loop of the remote lab in the EJS application can write on line the Matlab code to control the plant. The code
//Open Loop used by default (a PID controller) is shown in listing 4. Here,
if (isOpenLoop) { a Matlab function named computeControl will be called from
commandUser = sendOut (commandUser); the controller function of listing 3.
inputApplied = commandUser; The function computeControl has five input variables and
//Closed Loop one output variable. The input variables are r (set point or ref-
} else { erence), y (controlled variable for position or speed of motor),
if (speedControl) cs = controller (reference,speed); and three optional variables a, b, and c (in this case, these free
else cs = controller (reference,position); variables are used as gain, integral time, and derivative time of
controlSignal = sendOut (cs); the PID controller). The output variable cs is returned to the
inputApplied = controlSignal; controller function in order to send out the control action to
} the real plant (see listing 3).
//Getting data
data = getData (); Listing 4. Default code to calculate a PID controller
position = data [2]; function cs = computeControl (r, y, a, b, c)
speed = data [1]; %r = ref erence y = output [a b c] = EJSparameters
time = data [0]; %cs = controlsignal
%Initialization
persistent Iold Dold yold
IV. N ETWORKED C ONTROL L AB I MPLEMENTED
if isempty (Iold)
The lab created is a Java application designed to control a Iold = 0; Dold = 0; yold = 0;
simple servo motor through the Internet. This lab uses a real end
servo motor of FEEDBACK located at Ghent University in %Calculate Control Signal
Belgium. The selected DAQ card was the 6024E card manufac- beta = 1; N = 10; h = 0.1;
tured by National Instruments. In Fig. 8, a scheme of the imple- P = a ∗ (beta ∗ r − y);
FARIAS et al.: DEVELOPING NETWORKED CONTROL LABS: A MATLAB AND EASY JAVA SIMULATIONS APPROACH 3271

in this work, only the position control will be analyzed further,


since it is more difficult than speed control. In a feedback
control of the remote servo, the model of the motor can be
considered as a second-order system with a dead time, a dead
zone, and a saturation. The effect of each part of the model will
be discussed next.
1) Dead Zone: Consider a second-order system composed
only by the FOS model plus a gain (kp ) and a pure integrator.
Fig. 9. Model of the networked control lab. The remote servo motor is divided If a P controller (kc ) is also considered, then the open-loop
into three parts: the network model, the speed model, and the position model. transfer function of this simple model is given by the following
equation, where K = kc · κ · kp :
I = Iold;
D = c/(N ∗ h + c) ∗ Dold + N ∗ a ∗ c/(N ∗ h + c) ∗ K
(yold − y); GH = . (1)
s(τ s + 1)
cs = P + I + D;
Iold = Iold + a ∗ h/b ∗ (r − y); From control point of view, this second-order system can be
Dold = D; controlled using only the P controller. However, if the dead zone
yold = y; is taken into account [see Fig. 10(a)], then the control requires
an integral action to eliminate the steady-state error. This fact
B. Model of the Remote Servo Motor is demonstrated analyzing the obtained error when the control
signal (cs = kc · e) is inside the dead zone (−δ1 ≤ cs ≤ δ1 ). In
From the control point of view, the model of the networked this situation, the output of the dead-zone block is zero, so the
control lab can be divided in three main parts: a model for the control loop is broken, and therefore, the position signal is just
network delay, and models for the speed and position of the a constant. It can be demonstrated that, in this case, the steady-
servo motor (see Fig. 9). state error (ess ) is different from zero, and it is located in a band
We can assume that all delays from the network can be [see (2)]. The extremes of this band depend on the dead-zone
represented by a single variable dead time, which can have dif- limits and the gain of the proportional controller
ferent values depending mainly on the distance between server
and client and the traffic overhead in the network. The speed −δ1 δ1
≤ ess ≤ . (2)
model is a first-order system (FOS) plus two nonlinearities: a kc kc
saturation (limiter) and a dead zone. The FOS system represents
the dynamics of the amplifier, the motor, the brake, and the 2) Dead Zone and Saturation: Consider the previous case
tachometer of the servo motor plant. Regarding the dead zone, plus the saturation. Here, if the saturation is also taken into
the range detected in the real plant is located in [−δ1 , δ1 ], where account, then the integral action required to eliminate the
δ1 = 0.1 V. In the case of the saturation of the amplifier, it steady-state error has to consider the limits of the saturation
allows input values into the range [−δ2 , δ2 ], where δ2 = 0.2 V. block. Thus, if a PI controller is selected, then an antiwindup
To get the position of the servo motor, a potentiometer was scheme should be applied to avoid a slow control action [17].
used. The potentiometer is fed by the DAQ card with 1 V. 3) Dead Time: If only the linear parts of the motor and the
Thus, the voltage obtained indicates the position of the motor. dead time are considered [see Fig. 10(b)], then we get a second-
This position model can be represented by a gain plus a pure order system plus dead time. A detailed description about
integrator. However, in order to have a better model of the real dead-time processes can be found in [18]. In this situation,
plant behavior, an automatic reset can be added to the pure the network delay can affect strongly the control performance.
integrator to limit and handle the discontinuity of the servo Here, different solutions can be applied; one of them could be
position sensor, which produces a signal between 0 and 1 V the use of a Smith predictor if the delay remains approximately
to represent the angular position from 0◦ to 360◦ . constant during the remote control session. However, if the
The motor dynamics can be modified by means of the posi- delay connection is highly variable, then more elaborated al-
tion of the magnetic brake. Normally, two positions are used: gorithms should be required. To simplify the problem, here, we
partial brake and full brake. For instance, when full brake is will focus on fixed time-delay systems; further analysis about
selected, then the gain κ and the time constant τ are smaller varying time delay can be found in [18]–[20].
than that when the partial brake is used. In the full brake case, If the network delay is approximately constant and we use a
typical values for κ and τ are about 10 and 1 s, respectively. On P controller, it is possible to calculate how much delay that the
the other hand, in the partial brake case, normally, the values system can tolerate before becoming unstable [21]. To calculate
for κ and τ are about 14 and 2.5 s, respectively. this margin delay first, we compute the open-loop transfer
function of the model, which, in this case, is given by (1).
Second, computing the magnitude and the phase margin
C. Control Aspects of the Remote Servo Motor
of √the transfer function given by (1) and assuming that
There are two control objectives regarding the implemented (1/ τ K) ≈ 0 (which is a common situation when partial or
lab configuration: speed control and position control. However, full brake is selected), we can get useful approximations for
3272 IEEE TRANSACTIONS ON INDUSTRIAL ELECTRONICS, VOL. 57, NO. 10, OCTOBER 2010

Fig. 10. Remote servo (a) as a second-order system plus dead zone and (b) as a second-order system plus dead time. Note that the block “Controller” represents
a PID controller, which can be computed in the remote lab by the Matlab function computeControl described in listing 4.

ωgc (gain cross over frequency) and φm (phase margin). These saturation, respectively. The function f (γ) is called saturation
approximations are given by function, and its values are given by (8)
    
K K δ2 δ1
20 log  = 0 → ωgc ≈ (3) N (A) = f −f (7)
ω ω2 τ 2 + 1 τ A A
gc gc ⎧
⎨ −1,
for γ < −1
φm = π −
π
− arctan ωgc τ → φm ≈ √
1 f (γ) = 2
arcsin γ + γ 1 − γ , for |γ| ≤ 1 (8)
2
. (4) ⎩π
2 Kτ 1, for γ > 1.
Finally, by using ωgc and φm , the delay margin (T ) can be √
Solving (6) and assuming that (1/ τ KN ) ≈ 0, we can find
calculated using (5). Therefore, this last equation tells us that
useful approximations for the frequency of the limit cycle (ω)
the delay margin is inversely proportional to the product of
and also for the delay margin (T ). These approximations, given
kc · κ · kp
by the following equations, can be used for control design
1 purposes:
φm = ωgc T → T ≈ . (5)
kc κkp 
KN 1
ω≈ T ≈ . (9)
Notice that even small delays could lead to an unstable closed τ KN
loop. For example, when the full brake is selected (κ = 10 and
τ = 1) and assuming that kp = kc = 1, the delay margin is Interesting analysis can also be done observing the polar plot
approximately 0.1 s, which is a usual value for Internet delays. (see Fig. 11) of (6). In this figure, we can see that the limit
This result implies that if the system has less brake, then it cycles appear when there is an intersection of GH(jω) and
is less stable. Obviously, this delay margin can be modified −(1/N (A)). Notice that the curve of −(1/N (A)) has been
changing the value of kc in the P controller. distorted to see both limit cycles. Hence, it is clear that there
4) Dead Time, Saturation, and Dead Zone: Consider the are no limit cycles if there is no dead time (curve GH(jω)).
linear model of the motor plus the dead time, saturation, and However, if there is enough delay (curve GHT (jω)), there will
the dead zone controlled by a P controller. In this situation, be one or two limit cycles. In the case of two limit cycles, one
the system could produce limit cycles if there is enough dead is unstable, and the other one is stable. However, the effect
time. To effect an approximate limit cycle study of this non- of the unstable cycle limit is constrained by the stable cycle
linear system, the nonlinear elements can be characterized by limit.
their describing functions (N (A, ω)) and the linear part by Observing the polar plot in Fig. 11, it is possible to conclude
its frequency response function (GH(jω)). Then, the solu- that at least one limit cycle will occur in the maximum value of
tion of (6) yields the amplitudes and frequencies of the limit −(1/N (A)) (i.e., when A = δ2 ). The minimum value of the
cycle [22] delay required for this situation can be calculated using (9).
For example, if kp = kc = 1, δ1 = 0.1, δ2 = 0.2, and the full
1 + N (A, ω)GH(jω) = 0. (6) brake is selected as the previous case, then the minimum delay
is about T ≈ (1/10N (0.2)) ≈ 0.26 s.
In our case, the linear part is given by (1), and the dead 5) Complete Model: In this case, we are considering the
zone, combined with the saturation, has the describing function model shown in Fig. 9 controlled by a P controller. The
shown in (7), where A is the amplitude of the limit cycle after analysis is quite similar to the previous case; the only one
the P controller and δ1 and δ2 are the limits of the dead zone and difference is the automatic reset mechanism of the integrator.
FARIAS et al.: DEVELOPING NETWORKED CONTROL LABS: A MATLAB AND EASY JAVA SIMULATIONS APPROACH 3273

Fig. 11. Polar plot representation to determine the limit cycle conditions.

This mechanism allows us to emulate the nonlinearity of the


position sensor (potentiometer), which keeps the position signal
between zero and one. For this reason, the behavior of this
Fig. 12. GUI of the implemented remote lab.
model is similar to the previous case when the position signal is
ranged from zero to one. Otherwise, if the signal crosses these
limits, then the model could become unstable. Hence, the limit depends on the speed of the connection to the Internet, the
cycles analysis is useful to determine the delay (T ) with which view of the actual equipment brings students a sense of reality.
the system would have a limit cycle with an amplitude before The view includes information of the speed and position of the
the P controller greater than the position range. To do this, servo. In addition, on this right panel, a series of buttons allows
we have to use the approximation for time delay given by (9) students to apply ready-made step up, step down, or square
when A = 0.5kc . Thus, for instance, if the full brake is selected, signal as input to the system. The text box allows entering a
kp = kc = 1, δ1 = 0.1, and δ2 = 0.2, then the maximum delay constant value as input to the plant. In open-loop mode, this
is about T = 0.41 s. input represents a command to the plant, while in closed loop,
the input represents a reference to the controller.
The two lower panels are devoted to the control of the motor.
D. GUI of the Networked Control Lab
The left bottom panel allows the student to select an open-
The many control aspects described earlier demand a graph- or closed-loop mode of operation, as well as modification of
ical user interface (GUI) for the application which offers a the parameters of the controller in the closed-loop mode. An
high degree of flexibility. However, at the same time, the information bar at the bottom of this panel shows the total
intended pedagogical use recommends keeping the interaction delay in each operation cycle. This delay includes the sampling
with the students relatively simple and intuitive. For this reason, period, the controller computing time, and the round trip com-
we spent a considerable part of our implementation time to munication time between the server and the controller. Finally,
discuss and test the possible designs of the interface. The a time bar indicates the time elapsed by the current session.
fast-prototyping facilities of EJS were very useful, because The right bottom panel is used by the student to select if the
they allowed faculty with not much programming expertise to signal to control is the speed or the position of the motor and to
interact directly with the computer at the application design enter the Matlab code that will be used to compute the control
phase, testing the many different possibilities. The result is a signal. This code accepts three free parameters (a, b, and c)
modern-looking intuitive GUI that offers a clear view of the that can be used by the student in the control algorithm (see
process and allows flexible user interaction without frightening listing 4) and whose values can be modified using three text
the student with too many options. fields provided by the interface.
The interface of the application, shown in Fig. 12, has four The interface is completed with a top task bar that provides
main panels, a menu bar, and a small task bar. buttons to start, pause, step, and stop the application and select
The two upper panels of the interface provide a quick view whether we want to control the real equipment (if available) or
of the motor and a time plot of the signals from and to it. the virtual simulation of the motor.
The time plots on the left panel display the speed and position The components of the interface described earlier provide the
signals of the motor, which are read from the Jim connection basic functionality required to operate the application. A menu
to the equipment, as well as the reference and the input to the bar provides some additional features such as the possibility
plant (which is the command or the control signal depending on to specify the range of the axes of the plot, indicate if the
whether the mode is open or closed loop, respectively). values of the signals are displayed in volts or as percentages,
The top part of the right panel shows a real view of the actual send to the Windows clipboard the values of the signals for
motor at Ghent University, obtained by EJS from an IP camera further analysis, and calibrate the location of the video of the IP
pointing to it. Although the quality of the video thus obtained camera.
3274 IEEE TRANSACTIONS ON INDUSTRIAL ELECTRONICS, VOL. 57, NO. 10, OCTOBER 2010

E. Using and Evaluating the Networked Control Lab add interesting and challenging features from the control point
of view.
From a wide set of tasks to do with the networked control
Two main software tools have been used, Matlab and EJS.
lab, we asked our students to do the following activities.
Matlab was selected because it is a very well known tool
1) Control the plant indicating suitable values for the con- in the control engineering community, whereas EJS allows
troller (by default, a PID controller). teachers to build complex Java applications with high levels
2) Apply a step to the motor input voltage. of interactivity and visualization, but with minimum skills on
3) Identify the main time constant and the gain from the computer programming.
“speed” response. Future work will mainly consist in adding new function-
4) On the basis of this identification exercise, derive a model ality and improvements to this approach. In this sense, in
for the “position” response. order to provide a better experience for users, large delays
5) On the basis of the position model, design a controller on far Internet connections should be mitigated until suitable
transfer function for position control. values.
6) Apply the position controller to the motor, and evaluate
the result. R EFERENCES
This exercise was done in a basic course on control engineer- [1] B. S. Heck, “Special report: Future directions in control education,” IEEE
Control Syst. Mag., vol. 19, no. 5, pp. 35–58, Oct. 1999.
ing in Ghent University, taken by some 130 students. At the [2] S. Dormido, “Control learning: Present and future,” Annu. Control Rev.,
end of the use of the networked control lab, the students were vol. 28, no. 1, pp. 115–136, 2004.
invited to evaluate it using an online poll (which allows students [3] L. Gomes and S. Bogosyan, “Current trends in remote laborato-
ries,” IEEE Trans. Ind. Electron., vol. 56, no. 12, pp. 4744–4756,
to vote in a confidential way). The results, from teacher and Dec. 2009.
students point of views, were very good specially considering [4] L. Gomes, F. Coito, A. Costa, L. Palma, and P. Almeida, “Remote labora-
that it was our first experience. The online questionnaire (based tories support within teaching and learning activities,” in Proc. Int. Conf.
REV, Jun. 25–27, 2007, pp. 1–6.
on [8]) was rated for students as strongly agree, agree, neutral, [5] J. Sánchez, S. Dormido, and F. Esquembre, “The learning of control
disagree, and strongly disagree. The questions were divided concepts using interactive tools,” Comput. Appl. Eng. Educ., vol. 13, no. 1,
into the following categories. pp. 84–98, 2005.
[6] C. Lazar and S. Carari, “A remote-control engineering laboratory,” IEEE
1) Learning value: The lab helps to learn the relevant Trans. Ind. Electron., vol. 55, no. 6, pp. 2368–2375, Jun. 2008.
[7] W. Zhang, M. S. Branicky, and S. M. Phillips, “Stability of networked
contents. control systems,” IEEE Control Syst. Mag., vol. 21, no. 1, pp. 84–99,
2) Value added: The lab has advantages over traditional Feb. 2001.
learning methods. [8] R. Dormido, H. Vargas, N. Duro, J. Sánchez, S. Dormido-Canto, G. Farias,
F. Esquembre, and S. Dormido, “Development of a web-based control lab-
3) Usability: The lab was easy to use. oratory for automation technicians: The three-tank system,” IEEE Trans.
4) Technical functionality: The lab works well from soft- Educ., vol. 51, no. 1, pp. 35–44, Feb. 2008.
ware and hardware points of view. [9] Mathworks’ Home Page. [Online]. Available: http://www.mathworks.com
[10] F. Esquembre, “Easy Java simulations: A software tool to create scientific
The results indicate that Technical Functionality was not a simulations in Java,” Comput. Phys. Commun., vol. 156, no. 2, pp. 199–
204, Jan. 2004.
problem for most of the students because only 11% of them
[11] Easy Java Simulations’ Home Page. [Online]. Available: http://fem.
evaluated this category as disagree. Regarding the Usability, um.es/Ejs
about 84% of the students did not find some difficulty to use [12] S. Dormido, F. Esquembre, G. Farias, and J. Sanchez, “Adding interac-
the lab. About 55% of the students think that the lab helps to tivity to existing Simulink models using Easy Java Simulations,” in Proc.
44th IEEE Conf. Decision Control, Seville, Spain, 2005, pp. 4163–4168.
understand the matters (Learning Value), while only 13% of [13] S. Müller, JMatlink’s Home Page. [Online]. Available: http://jmatlink.
them disagree. Regarding the Value Added, 30% of the students sourceforge.net/
think that the lab has advantages over other learning meth- [14] G. Farias, F. Esquembre, J. Sanchez, S. Dormido, H. Vargas,
S. Dormido-Canto, R. Dormido, N. Duro, and M. Canto, “Desarrollo
ods; however, about 25% of the students think the opposite. de Laboratorios Virtuales, Interactivos y Remotos Utilizando Easy Java
Probably, this item indicates the value that students give to the Simulations y Modelos Simulink,” in Proc. 12th Latin-Amer. Congr.
traditional practice in the labs, which means that the remote or Autom. Control, Salvador de Bahı´a, Brazil, 2006.
[15] JIM Server’s Home Page. [Online]. Available: http://lab.dia.uned.es/
virtual labs have to be considered as a complement (and not a rmatlab/
replacement) of the industrial electrical teaching. [16] The MathWorks, Inc., Data Acquisition Toolbox, User’s Guide, v.2.5.
[17] K. J. Åström and T. Hägglund, Advanced PID Control. Research
Triangle Park, NC: ISA, 2005.
[18] J. Normey-Rico and E. Camacho, Control of Dead-Time Processes.
V. C ONCLUSION AND F URTHER W ORK Berlin, Germany: Springer-Verlag, 2007.
[19] S. Cristea, C. de Prada, and R. De Keyser, “Predictive control of a process
In this paper, a new approach to build interactive networked with variable dead-time,” in Proc. IFAC 16th World Congr., Prague, Czech
control labs has been presented. The work allows nonpro- Republic, 2005.
gramming instructors to create innovative pedagogical tools, [20] G. Liu, Y. Xia, J. Chen, D. Rees, and W. Hu, “Networked predictive con-
trol of systems with random network delays in both forward and feedback
which can be used to motivate students to apply the theory of channels,” IEEE Trans. Ind. Electron., vol. 54, no. 3, pp. 1282–1297,
automatic control to new challenges, like the remote control Jun. 2007.
of plants. This kind of labs can be used as part of a basic [21] R. Dorf and R. Bishop, Modern Control Systems, 10th ed. Englewood
Cliffs, NJ: Prentice-Hall, 2004.
industrial electronic control course or even a benchmark for [22] A. Gelb and W. Vander Velde, Multiple-Input Describing Functions and
advanced students since the network delays and nonlinearities Nonlinear System Design. New York: McGraw-Hill, 1968.
FARIAS et al.: DEVELOPING NETWORKED CONTROL LABS: A MATLAB AND EASY JAVA SIMULATIONS APPROACH 3275

Gonzalo Farias received the M.S. degree in com- Sebastián Dormido received the B.S. degree in
puter science from the University de la Frontera, physics from Complutense University, Madrid,
Temuco, Chile, in 2001. Spain, in 1968 and the Ph.D. degree in science from
Since 2005, he has been with the Department of the University of the Basque Country, Bilbao, Spain,
Computer Science and Automatic Control, Univer- in 1971.
sidad Nacional de Educación a Distancia, Madrid, Since 1981, he has been a Professor of con-
Spain. His current research interests include control trol engineering with the Universidad Nacional de
of dynamic system and virtual and remote labs. Educación a Distancia, Madrid, Spain. His scien-
tific activities include computer control of industrial
processes, model-based predictive control, robust
control, and model and simulations of continuous
processes. He has authored or coauthored more than 150 technical papers in
international journals and conferences. Since 2002, he has promoted academic
Robin De Keyser received the M.Sc. degree in and industrial relations as President of the Spanish Association of Automatic
electromechanical engineering and the Ph.D. degree Control CEA–IFAC (Comité Español de Automática–International Federation
in control engineering from Ghent University, Ghent, on Automatic Control).
Belgium, in 1974 and 1980, respectively.
He is currently a Full Professor of control en-
gineering with the Faculty of Engineering, Ghent
University. He was an External Review expert in sev- Francisco Esquembre received the Ph.D. degree in
eral European Commission research programs and mathematics from the University of Murcia, Murcia,
is one of the pioneers who produced the original Spain, in 1991.
concepts of “predictive control” during the 1980s. Since 1986, he has been with the University of
He is the author/coauthor of about 250 publications Murcia, where he has been holding the position of
in journals, books, and conference proceedings. His current research interests Associate Professor since 1994. His academic exper-
include model predictive control, autotuning and adaptive control, modeling tise includes differential equations, dynamical sys-
and simulation, system identification, and pilot implementations in technical tem, and numerical analysis. His research includes
and nontechnical systems, such as chemical, steel, marine, mechatronic, semi- computer-assisted teaching and learning.
nconductor, power electronics, and biomedical.

You might also like