TANGO

Summary

The TANGO control system is a free open source device-oriented controls toolkit for controlling any kind of hardware or software and building SCADA systems. It is used for controlling synchrotrons, lasers, physics experiments in over 20 sites. It is being actively developed by a consortium of research institutes.

TANGO
Developer(s)TANGO Consortium
Initial releaseApril 19, 2001 (2001-04-19)
Stable release
9.3.4 / Sep 15, 2020
Repository
  • gitlab.com/tango-controls/cppTango Edit this at Wikidata
Operating systemCross-platform
LicenseLGPLv3, GPLv3
WebsiteTANGO website

TANGO is a distributed control system. It runs on a single machine as well as hundreds of machines. TANGO uses two network protocols - the omniorb implementation of CORBA and Zeromq. The basic communication model is the client-server model. Communication between clients and servers can be synchronous, asynchronous or event driven. CORBA is used for synchronous and asynchronous communication and Zeromq is used for event-driven communication (since version 8 of TANGO).

TANGO is based on the concept of Devices. Devices implement object oriented and service oriented approaches to software architecture. The Device model in TANGO implements commands/methods, attributes / data fields and properties for configuring Devices. In TANGO all control objects are Devices.

Device Servers edit

 
All solutions in TANGO can be reduced to 3 processes
 
TANGO uses hierarchies of devices to manage complexity simply

TANGO is a software for building control systems which need to provide network access to hardware. Hardware can range from single bits of digital input/output up to sophisticated detector systems or entire plant control systems (SCADAs). Hardware access is managed in a process called a Device Server. The Device Server contains Devices belonging to different Device Classes which implement the hardware access. At Device Server startup time Devices (instances of Device Classes) are created which then represent logical instances of hardware in the control system. Clients "import" the Devices via a database and send requests to the devices using TANGO. Devices can store configuration and setup values in a Mysql database permanently.

Hundreds of Device Classes have been written by the community.

TANGO manages complexity using hierarchies.

Bindings edit

TANGO supports bindings to the following languages :

C, C++, Java, Python, MATLAB, LabVIEW, IGOR Pro

Licensing edit

TANGO is distributed under 2 licenses. The libraries are licensed under the GNU Lesser General Public License (LGPLv3). Tools and device servers are (unless otherwise stated) under the GNU General Public License (GPLv3). The LGPL licence allows the TANGO libraries in products which are not GNU GPL.

Projects using TANGO edit

Some of the projects using TANGO (in addition to the consortium) :

  1. the diagnostics of the Laser Mégajoule

Consortium edit

The consortium is a group of institutes who are actively developing TANGO. To join the consortium an institute has to sign the Memorandum of Understanding[dead link] and actively commit resources to the development of TANGO. The consortium currently consists of the following institutes :

  1. ESRF - European Synchrotron Radiation Facility, Grenoble, France
  2. SOLEIL - Soleil Synchrotron, Paris, France
  3. ELETTRA - Elettra Synchrotron, Trieste, Italy
  4. ALBA - Alba Synchrotron, Barcelona, Spain
  5. DESY - PETRA III Synchrotron, Hamburg, Germany
  6. MAXIV - MAXIV Synchrotron, Lund, Sweden
  7. FRMII - FRMII neutron source, Munich, Germany
  8. SOLARIS - National Synchrotron Radiation Centre SOLARIS, Kraków, Poland
  9. ANKA - ANKA Synchrotron, Karlsruhe, Germany
  10. INAF - Istituto Nazionale di Astrofisica, IT

The goal of the consortium is to guarantee the development of TANGO.

See also edit

  • EPICS—Experimental Physics and Industrial Control System
  • SCADA—Supervisory Control And Data Acquisition

References edit

Refer to the following publications on TANGO for more information :

  1. TANGO - an object oriented control system based on CORBA, ICALEPCS 1999, Trieste (Italy)
  2. TANGO a CORBA based Control System, ICALEPCS 2003, Gyeongju (Korea)
  3. Ubiquitous TANGO[dead link], ICALEPCS 2007[dead link], Knoxville (USA)
  4. Future of TANGO, ICALEPCS 2007[dead link], Knoxville (USA)
  5. TANGO papers presented at ICALEPCS 2009, Kobe (Japan)
  6. TANGO papers presented at ICALEPCS 2011. Grenoble (France)