Instrument Neutral Distributed Interface

Instrument Neutral Distributed Interface (INDI) is a distributed control system (DCS) protocol to enable control, data acquisition and exchange among hardware devices and software front ends, emphasizing astronomical instrumentation.

INDI
Original author(s)Elwood Downey, Jasem Mutlaq
Developer(s)The INDI Development Team
Initial release15 April 2003 (2003-04-15)
Stable release
1.8.0 / 27 July 2019 (2019-07-27)
Written inC, C++
Operating systemLinux, OS X, macOS, FreeBSD, OpenBSD
LicenseGNU LGPL v2.1+
Websitewww.indilib.org

Introduction

Elwood Downey started the INDI Protocol initiative in 2003 to develop a platform and client independent control protocol. INDI is a simple protocol modeled on Extensible Markup Language (XML), described for interactive and automated remote control of diverse instruments. It is small, easy to parse, and stateless. In the INDI paradigm, each Device poses all command and status functions in terms of setting and getting Properties. Each Property is a vector of one or more named members, and has a current value vector; a target value vector; provides information about how it should be sequenced with respect to other Properties to accomplish one coordinated unit of observation; and provides hints as to how it might be displayed for interactive manipulation in a graphical user interface (GUI). Clients learn the Properties of a particular Device at runtime using introspection.

This decouples Client and Device implementation histories. Devices have full authority over whether to accept commands from Clients. INDI accommodates intermediate servers, broadcasting, and connection topologies ranging from one-to-one on one type of system, to many-to-many between systems of different genre. The INDI protocol can be nested within other XML elements such as Remote Telescope Markup Language (RTML) to add constraints for automatic scheduling and execution.

Architecture

The main key concept in INDI is that devices have the ability to describe themselves. This is accomplished by using XML to describe a generic hierarchy that can represent both canonical and non-canonical devices. In INDI, all devices may contain one or more properties. Any property may contain one or more elements. A property in the INDI paradigm describes a specific function of the device. There are five types of INDI properties:

  • Text property
  • Number property
  • Switch property – represented in GUI by buttons or check boxes
  • Light property – represented in GUI by colored LEDs
  • Blob property – binary data

INDI provides powerful scripting facilities that enable full device automation.

INDI Library

INDI Library is an implementation of the INDI wire protocol for Unix-like systems. It supports a wide variety of astronomical instruments including telescopes, charge-coupled devices (CCDs), focusers, filters, and video capture devices. The INDI Library is licensed under the GNU Lesser General Public License (LGPL).

INDI Driver

INDI driver is the program that communicates directly to the device. It is responsible for controlling the device parameters and for defining them to clients. Drivers send a list of supported device properties to clients where they are parsed and presented to the end users.

INDI Clients

Clients are the software frontends that communicate with the hardware drivers. They usually communicate with INDI hardware drivers via INDI server, though they can communicate with the drivers directly. There are many types of clients, most notably:

INDI Control Panel in KStars
  • Generic GUI clients like KStars, XEphem, AstroImager,[1] or AstroTelescope.[2] Such clients generate a dynamic GUI to offer users a control panel to control the device.
  • Logger clients to record messages, alarms, and data exchanged between devices and clients.
  • Watch dog clients to ensure safe and proper operation of devices.
  • Automated scripts to carry on complex and coordinated operations on devices.

INDI Server

INDI server is the hub that sits between drivers and clients. It reroutes traffic for control and data across distributed networks. Each device or client in the network is a node and may communicate with other nodes whenever desired. The server supports broadcasting, chaining, and marshaling of data.

INDI Server Network Topology

IANA port

Internet Assigned Numbers Authority (IANA) has assigned INDI to Transmission Control Protocol (TCP) and User Datagram Protocol (UDP), or TCP/UDP port 7624. See List of TCP and UDP port numbers.

gollark: The hashes are there so that a potatonode™ can check its own files against a manifest's and see which need updating.
gollark: hæsh
gollark: As you can see, it's two lines of JSON.
gollark: ```json{"build":23,"files":{"autorun.lua":"bb7b2b900d6990b98514e21321c2669c84f03452017c47cdb6b94a80b811207c","startup":"d18769bbc601f80dab15e5dce8d2966bcf24b3d78f9dd6ce396d237011831899"},"timestamp":1596141744}{"hash":"44f71fab1fba58949da6551f8e9b9018e0c93b739bb051abb10684071ab1d683"}```Here is a Potatomanifest™ file.
gollark: With the eventual™ cryptographic signing thing, you could even have potatOS updates hosted off even untrusted servers securely.

References

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.