CPL - The Common Pipeline Library

CPL Title Graphic

Latest News

PyCPL version 1.0.1 has been released - (13-Jan-2025)

This is the first maintenance release of the PyCPL 1.0 release series. Read more...

PyCPL version 1.0 is now available - (06-Nov-2023)

PyCPL provides Python Language bindings for the Common Pipeline Library (CPL).

CPL version 7.3.2 has been released - (10-May-2023)

PyCPL version 0.9 (early release version) is now available - (17-Aug-2022)

CPL version 7.2.3 has been released - (21-Dec-2022)



Overview

The Common Pipeline Library (CPL) comprises a set of ISO-C libraries that provide a comprehensive, efficient and robust software toolkit to develop astronomical data-reduction tasks (known as "recipes"). These data-reduction tasks can then be executed manually by a user, or can be triggered in an automated data-reduction framework (known as "pipelines") which are used at ESO to monitor the health status of VLT instruments, for quick-look data processing at the observatory, and the creation of data products available from the ESO archive facility.

The Common Pipeline Library was developed to standardise the way VLT instrument pipelines are built, to shorten their development cycle and to ease their maintenance. However, it may be more generally applied to any similar application, and the details of the CPL code have been engineered in away to make the library portable and flexible, as well as minimising external dependencies.

The CPL provides a host of functionality, presented in a clear, generic and uniform manner. Among its many features, the CPL offers:

  • many useful low-level data types (images, tables, matrices, strings, property lists, ...),
  • many fundamental statistic, arithmetic and conversion operations for these data types.
  • medium-level data access methods (e.g. a data abstraction layer for FITS files),
  • data table organisation and manipulation,
  • keyword/value handling and management,
  • a standardised application interface for pipeline recipes, and,
  • support for dynamic loading of recipe modules.

Despite the current bias towards instrument pipeline development, the library also provides a variety of general-purpose image- and signal-processing functions, making it an excellent framework for the creation of more generic data-handling packages.

For more information about the CPL project, please see the web pages whose links appear at the top of this page.