PSI sics-cvs-psi_pre-ansto
This commit is contained in:
346
doc/programmer/pub.tex
Normal file
346
doc/programmer/pub.tex
Normal file
@@ -0,0 +1,346 @@
|
||||
% Copyleft (c) 1997 by Mark Koennecke at PSI, Switzerland.
|
||||
%
|
||||
%
|
||||
%
|
||||
|
||||
\documentclass[12pt]{article}
|
||||
\usepackage{epsf}
|
||||
\setlength{\oddsidemargin}{-.1in}
|
||||
\setlength{\evensidemargin}{0in}
|
||||
\setlength{\topmargin}{0in}
|
||||
\addtolength{\topmargin}{-\headheight}
|
||||
\addtolength{\topmargin}{-\headsep}
|
||||
\setlength{\textheight}{8.9in}
|
||||
\setlength{\textwidth}{6.2in}
|
||||
\setlength{\marginparwidth}{0.5in}
|
||||
\parindent=0pt
|
||||
\parskip=0.3cm
|
||||
|
||||
\begin{document}
|
||||
\title{SICS: SINQ Instrument Control Software}
|
||||
|
||||
\author{Mark K\"onnecke\\
|
||||
Heinz Heer\\
|
||||
Labor f\"ur Neutronenstreuung\\
|
||||
Paul Scherrer Institut\\
|
||||
CH-5232 Villigen PSI\\
|
||||
Switzerland\\
|
||||
Mark.Koennecke@psi.ch \\
|
||||
Heinz.Heer@psi.ch \\
|
||||
}
|
||||
|
||||
|
||||
\maketitle
|
||||
|
||||
\section{Introduction}
|
||||
At the new spallation source SINQ at PSI a whole set of new neutron
|
||||
scattering instruments are being installed. All these new instruments need a
|
||||
instrument control control system. After a review of similar systems
|
||||
out in the market it was found that none fully met the requirements defined
|
||||
for SINQ or could easily be extended to do so. Therefore it was decided to
|
||||
design a new system. This new system SICS, the SINQ Instrument Control
|
||||
System, had to meet the following specifications:
|
||||
\begin{itemize}
|
||||
\item Control the instrument reliably.
|
||||
\item Good remote access to the instrument via the internet.
|
||||
\item Portability across operating system platforms.
|
||||
\item Enhanced portability across instrument hardware. This means that it
|
||||
should be easy to add other types of motors, counters or other hardware to
|
||||
the system.
|
||||
\item Support authorization on the command and variable level. This means
|
||||
that certain instrument settings can be protected against harmful changes by
|
||||
less knowledgable users.
|
||||
\item Good maintainability and extendability.
|
||||
\item Be capable to acomodate graphical user interfaces (GUI).
|
||||
\item Single code base for all instruments.
|
||||
\item Powerful macro language.
|
||||
\end{itemize}
|
||||
A suitable new system was implemented using an object oriented design which
|
||||
matches the above criteria.
|
||||
|
||||
\section{The SINQ Hardware Setup}
|
||||
SICS had to take in account the SINQ hardware setup which had been decided
|
||||
upon earlier on. Most hardware such as motors and counters is controlled via
|
||||
RS--232 interfaces. These devices connect to a Macintosh PC which has a
|
||||
terminal server program running on it. This terminal server program collects
|
||||
request to the hardware from a TCP/IP port and forwards them to the serial
|
||||
device. The instrument control program runs on a workstation running
|
||||
DigitalUnix. Communication with the hardware happens via TCP/IP through the
|
||||
terminal server. Some hardware devices, such as the histogram memory, can handle
|
||||
TCP/IP themselves. With such devices the instrument control program
|
||||
communicates directly through TCP/IP, without a terminal server. All
|
||||
hardware devices take care of their real time needs themselves. Thus the
|
||||
only task of the instrument control program is to orchestrate the hardware
|
||||
devices. SICS is designed with this setup up in mind, but is not restricted
|
||||
to it. A schematic view of the SINQ hardware setup is given in picture
|
||||
\ref{hard}.
|
||||
\begin{figure}
|
||||
\epsfxsize=0.65\textwidth
|
||||
%% \epsfxsize=160mm
|
||||
\epsffile{hart.eps}
|
||||
\caption{Instrument control hardware setup at SINQ}\label{hard}
|
||||
\end{figure}
|
||||
|
||||
|
||||
\section{SICS Overall Design}
|
||||
In order to achieve the design goals stated above it was decided to divide
|
||||
the system into a client server system. This means that there are at least
|
||||
two programs necessary to run an instrument: a client program and a server
|
||||
program. The server program, the SICS server, does all the work and
|
||||
implements the actual instrument control. The SICS server usually runs on
|
||||
the DAQ computer. The client program may run on any computer on the world
|
||||
and implements the user interface to the instrument. Any numbers of clients
|
||||
can communicate with one SICS server. The SICS server and the clients
|
||||
communicate via a simple ASCII command protocol through TCP/IP sockets.
|
||||
With this design good remote control through the network is easily achieved.
|
||||
SICS clients can be implemented in any language or system capable of handling
|
||||
TCP/IP. Thus the user interface and the functional aspect are well separated. This
|
||||
allows for easy exchange of user interfaces by writing new clients.
|
||||
|
||||
|
||||
\section{SICS Clients}
|
||||
SICS Clients implement the SICS user interface. Current client programs have
|
||||
been written in Tcl/TK$^{1}$, but work is under way to recode clients in Java for
|
||||
maximum platform portability. This is a real concern at SINQ where VMS,
|
||||
Intel-PC, Macintosh and Unix users have to be satisfied. As many instrument scientists still prefer
|
||||
the command line for interacting with instruments, the most used client is a
|
||||
visual command line client. Status displays are another sort of specialized
|
||||
client programs. Graphical user interfaces are under consideration for some
|
||||
instruments. As an example for a client a screen shot of the command line
|
||||
client is given in picture \ref{dmc}.
|
||||
\begin{figure}[h]
|
||||
\epsfxsize=0.9\textwidth
|
||||
%% \epsfxsize=160mm
|
||||
\epsffile{dmccom.eps}
|
||||
\caption{Example for a SICS client: The Command line client}\label{dmc}
|
||||
\end{figure}
|
||||
|
||||
|
||||
|
||||
\section{The SICS Server}
|
||||
The SICS server is the core component of the SICS system. The SICS server is
|
||||
responsible for doing all the work in instrument control. Additionally the
|
||||
server has to answer the requests of possibly multiple clients.
|
||||
The SICS server can be subdivided into three subsystems: The kernel, a database
|
||||
of SICS objects and an interpreter. The SICS server kernel takes care of
|
||||
client multitasking and the preservation of the proper I/O and error context
|
||||
for each client command executing.
|
||||
|
||||
SICS objects are software modules which represent all aspects
|
||||
of an instrument: hardware devices, commands, measurement strategies
|
||||
and data storage. The SICS server's database of objects is initialized at server startup
|
||||
time from an initialization script. The third SICS server component is an
|
||||
interpreter which allows to issue commands to the objects in the objects database.
|
||||
A schematic drawing of the SICS server's structure is given in picture
|
||||
\ref{sicsnew}.
|
||||
\begin{figure}
|
||||
\epsfxsize=0.9\textwidth
|
||||
\epsfysize=100mm
|
||||
%% \epsfxsize=160mm
|
||||
\epsffile{newsics.eps}
|
||||
\caption{Schematic Representation of the SICS server's structure}\label{sicsnew}
|
||||
\end{figure}
|
||||
|
||||
|
||||
\subsection{The SICS Server Kernel}
|
||||
Any server-program has the problem how to organize multiple
|
||||
clients accessing the same server and how to stop one client reading data,
|
||||
which another client is just writing. The approach used for the SICS server
|
||||
is a combination of polling and cooperative multitasking. This scheme is
|
||||
simple and can be implemented in an operating system independent manner. One
|
||||
way to look at the SICS server is as a series of tasks in a circular queue
|
||||
executing one after another. There are several system tasks and one
|
||||
task for each living client connection. The servers main loop does nothing but
|
||||
executing the tasks in this circular buffer in an endless loop.
|
||||
Thus only one task executes at any
|
||||
given time and data access is efficiently serialized.
|
||||
|
||||
One of the main system
|
||||
tasks (and the one which will be always there) is the network reader. The
|
||||
network reader has a list of open network connections and checks each of
|
||||
them for pending requests. What happens when data is pending on an open
|
||||
network port depends on the type of port: If it is the servers main
|
||||
connection port, the network reader will try to accept and verify a new
|
||||
client connection and create the associated data structures. If the port
|
||||
belongs to an open client connection the network reader will read the
|
||||
command pending and put it onto a command stack existing for each client
|
||||
connection. When it is time for a client task to execute, it will fetch a
|
||||
command from its very own command stack and execute it. When the net reader
|
||||
finds an user interrupt pending, the interrupt is executed.
|
||||
This is how the SICS server deals with client requests.
|
||||
|
||||
The scheme described above relies on the fact that most SICS command need
|
||||
only very little time to execute. A command needing time extensive
|
||||
calculations may effectively block the server. Implementations of such
|
||||
commands have to take care that control passes back to the task switching
|
||||
loop at regular intervalls in order to prevent the server from blocking.
|
||||
|
||||
Another problem in a server handling multiple client requests is how to
|
||||
maintain the proper execution context for each client. This includes the
|
||||
clients I/O-context (socket), the authorisation of the client and possible
|
||||
error conditions pending for a
|
||||
client connection. SICS does this via a connection object, a special
|
||||
data structure holding all the above information plus a set of functions
|
||||
operating on this data structure. This connection object is passed along
|
||||
with many calls throughout the whole system.
|
||||
|
||||
Multiple clients issuing commands to the SICS server may mean that multiple
|
||||
clients might try to move motors or access other hardware in conflicting
|
||||
ways. As there is only one set of instrument hardware this needs to be
|
||||
prevented. This is achieved by a convention. No SICS object drives hardware
|
||||
directly but registers it's request with a special object, the device
|
||||
executor. This device executor starts the requested operation and reserves
|
||||
the hardware to the client for the length of the operation. During the execution of such
|
||||
an hardware request all other clients requests to drive the hardware will
|
||||
return an error. The device executor is also responsible for monitoring the
|
||||
progress of an hardware operation. It does so by adding a special task into
|
||||
the system which checks the status of the operation each time this tasks
|
||||
executes. When the hardware operation is finished this
|
||||
device executor task will end. A special system facility allows a client
|
||||
task to wait for the device executor task to end while the rest of the task
|
||||
queue is still executing. In this way time intensive hardware operations can
|
||||
be performed by drive, count or scan commands without blocking the whole
|
||||
system for other clients. \label{devexec}
|
||||
|
||||
|
||||
Most experiments do not happen at ambient room conditions but
|
||||
require some special environment for the sample. Mostly this is temperature
|
||||
but it can also be magnetic of electric fields etc. Most of such devices
|
||||
can regulate themselves but the data acquisition program needs to monitor
|
||||
such devices. Within SICS this is done via a special system object, the
|
||||
environment monitor. A environment device, for example a temperature
|
||||
controller, registers it's presence with this object. Then an special system
|
||||
task will control this device when it is executing, check for possible out
|
||||
of range errors and initiates the proper error handling if such a problem is
|
||||
encountered.
|
||||
|
||||
\subsection{The SICS Interpreter}
|
||||
When a task belonging to a client connection executes a command it will pass
|
||||
the command along with the connection object to the SICS interpreter. The
|
||||
SICS interpreter will then analyze the command and forward it to the
|
||||
appropriate SICS object in the object database for further action. The SICS
|
||||
interpreter is very much modeled after the Tcl interpreter as devised by
|
||||
John Ousterhout$^{1}$. For each SICS object visible from the interpreter there is
|
||||
a wrapper function. Using the first word of the command as a key, the
|
||||
interpreter will locate the objects wrapper function. If such a function is
|
||||
found it is passed the command parameters, the interpreter object and the
|
||||
connection object for further processing. An interface exists to add and
|
||||
remove commands to this interpreter very easily. Thus the actual command
|
||||
list can be configured easily to match the instrument in question, sometimes
|
||||
even at run time. Given the closeness of the design of the SICS interpreter
|
||||
to the Tcl interpreter, the reader may not be surprised to learn that the
|
||||
SICS server incorporates Tcl as its internal macro language. The internal
|
||||
macro language may use Tcl commands as well as SICS commands.
|
||||
|
||||
\subsection{SICS Objects}
|
||||
As already said, SICS objects implement the true functionality of SICS
|
||||
instrument control. All hardware, all commands and procedures, all data
|
||||
handling strategies are implemented as SICS objects. Hardware objects, for
|
||||
instance motors deserve some special attention. Such objects are divided
|
||||
into two objects in the SICS system: A logical hardware object and a driver
|
||||
object. The logical object is responsible for implementing all the nuts and
|
||||
bolts of the hardware device, whereas the driver defines a set of primitive
|
||||
operations on the device. The benefit of this scheme is twofold:
|
||||
switching to new hardware, for instance a new type of motor, just requires
|
||||
to incorporate a new driver into the system. Internally, independent from
|
||||
the actual hardware, all hardware object of the same type (for example
|
||||
motors) look the same and can be treated the same by higher level objects.
|
||||
No need to rewrite a scan command because a motor changed.
|
||||
|
||||
In order to live happily within the SICS system SICS object have to adhere
|
||||
to a system of protocols. There are protocols for:
|
||||
\begin{itemize}
|
||||
\item Input/Output to the client.
|
||||
\item Error handling.
|
||||
\item Interaction with the interpreter.
|
||||
\item For identification of the object to the system at run time.
|
||||
\item For interacting with hardware (see device executor above).
|
||||
\item For checking the authorisation of the client who wants to execute the
|
||||
command.
|
||||
\end{itemize}
|
||||
|
||||
SICS uses NeXus$^{2}$, the upcoming standard for data exchange for neutron
|
||||
and X\_ray scattering as its raw data format.
|
||||
|
||||
SICS objects have the ability to notify clients and other objects of
|
||||
internal state changes. For example when a motor is driven, the motor object
|
||||
can be configured to tell SICS clients or other SICS objects about his new
|
||||
position.
|
||||
|
||||
The SICS server has been implemented in ANSI--C for maximum portability.
|
||||
ANSI--C proved powerful enough to support SICS's object oriented programming
|
||||
concepts.
|
||||
|
||||
\section{SICS Working Example}
|
||||
In order to illustrate the inner working of the SICS server a command to
|
||||
drive a motor will be traced through the system.
|
||||
\begin{itemize}
|
||||
\item The network reader finds data pending at one of the client ports.
|
||||
\item The network reader reads the command, splits it into single lines and
|
||||
put those on the top of the client connections command stack. The network
|
||||
reader passes control to the task switcher.
|
||||
\item In due time the client connection task executes, inspects its command
|
||||
stack, pops the command pending and forwards it together with a pointer to
|
||||
itself to the SICS interpreter.
|
||||
\item The SICS interpreter inspects the first word of the command. Using
|
||||
this key the interpreter finds the drive command wrapper function and passes
|
||||
control to that function.
|
||||
\item The drive command wrapper function will check further arguments,
|
||||
checks the
|
||||
clients authorisation if appropriate for the action requested. Depending on
|
||||
the checks, the wrapper function will create an error message or do its
|
||||
work.
|
||||
\item Assuming everything is OK, the motor is located in the system.
|
||||
\item The drive command wrapper function asks the device executor to run the
|
||||
motor.
|
||||
\item The device executor verifies that nobody else is driving, then starts
|
||||
the motor and grabs hardware control. The device executor also starts a task
|
||||
monitoring the activity of the motor.
|
||||
\item The drive command wrapper function now enters a wait state. This means
|
||||
the task switcher will execute other tasks, except the connection task
|
||||
requesting the wait state. The client connection and task executing the drive command
|
||||
will not be able to process further commands.
|
||||
\item The device executor task will keep on monitoring the progress of the motor
|
||||
driving whenever the task switcher allows it to execute.
|
||||
\item In due time the device executor task will find that the motor finished
|
||||
driving. The task will then die. The clients grab of the hardware driving
|
||||
permission will be released.
|
||||
\item At this stage the drive command wrapper function will awake and
|
||||
continue execution. This means inspecting errors and reporting to the client
|
||||
how things worked out.
|
||||
\item This done, control passes back through the interpreter and the connection
|
||||
task to the task switcher. The client connection is free to execute
|
||||
other commands.
|
||||
\item The next task executes.
|
||||
\end{itemize}
|
||||
|
||||
|
||||
\section{Current Status}
|
||||
Currently, SICS is in operation on the powder diffractometer DMC, the two circle
|
||||
diffractometer TOPSI and the small angle scattering diffractometer SANS.
|
||||
First clients have been
|
||||
implemented in Tcl/TK$^{1}$ and ANSI--C for a command line interface and status
|
||||
displays. First experiences with the system were positive. SICS currently
|
||||
supports the following hardware:
|
||||
\begin{itemize}
|
||||
\item SINQ EL734 motor controller.
|
||||
\item SINQ EL737 counter box.
|
||||
\item SINQ Histogram Memory.
|
||||
\item Dornier Velocity Selector.
|
||||
\item Oxford Instruments ITC4 temperature controller.
|
||||
\end{itemize}
|
||||
|
||||
SICS is in
|
||||
ongoing development. Support for the reactor time--of--flight instrument
|
||||
FOCUS, the
|
||||
reflectometer AMOR and the four circle diffractometer TRICS will be added in near
|
||||
future. Support for chopper control and more sample environment devices
|
||||
is on the way. More clients will be written in the Java programming language for
|
||||
optimal portability. Parties interested in using SICS or wishing to
|
||||
collaborate in its development are kindly asked to contact the authors.
|
||||
|
||||
\section{References}
|
||||
\begin{enumerate}
|
||||
\item John K Ousterhout: Tcl and the Tk toolkit, Addison--Wesley, 1994.
|
||||
\end{enumerate}
|
||||
\end{document}
|
||||
Reference in New Issue
Block a user