1PCL - PixInsight Class Library
4[PixInsight](https://pixinsight.com/) is an advanced image processing software platform designed specifically for astronomy and other technical imaging applications. PixInsight is a modular, open-architecture system where the entire processing and file handling capabilities are implemented as external installable modules.
6The PixInsight core application provides the infrastructure on top of which external modules can implement processes, image file formats, and their associated user interfaces. The [PixInsight Class Library](https://pixinsight.com/developer/pcl/) (PCL) is a C++ development framework to build PixInsight modules.
8PixInsight modules are special shared libraries (.so files on FreeBSD and Linux; .dylib under macOS; .dll files on Windows) that communicate with the PixInsight core application through a high-level API provided by PCL. Along with a core communication API, PCL includes a comprehensive set of image processing algorithms, ranging from geometrical transformations to multiscale analysis algorithms, most of them available as multithreaded parallel implementations. PCL provides also rigorous and efficient implementations of essential astronomical algorithms, including state-of-the-art solar system ephemerides, vector astrometry, and reduction of positions of solar system and stellar objects.
10PCL is highly portable code. As of writing this document, it is available on the same platforms supported by the PixInsight core application: 64-bit FreeBSD, Linux, macOS, and Windows. PixInsight modules written around PCL are directly portable to all supported platforms *without changing a single line of source code*. This is possible because PCL is a high-level framework. PCL isolates your module from platform-specific implementation details: all platform-dependent complexities are handled behind the scenes by the PixInsight core application and internal PCL routines.
12Starting from version 2.0, which was published in December of 2012, PCL is an open-source library released under the [PixInsight Class Library License](https://pixinsight.com/license/PCL_PJSR_1.0.html) (PCLL). In essence, PCLL is a liberal BSD-like license that allows you to develop open-source and closed-source, free and commercial PixInsight modules without restrictions. As long as you observe all PCLL terms, you can modify PCL and use your modified version with or without releasing your source code.
14A good starting point for developing PixInsight modules is the src/modules directory, where you'll find all open-source modules that form part of the official PixInsight distribution. You may also want to take a look at the PCL Reference Documentation mentioned below. PixInsight and PCL are supported by a vibrant community on [PixInsight Forum](https://pixinsight.com/forum/), which also contains a developers section. Join us there!
16## PCL Reference Documentation
18The official reference documentation for PCL has been generated automatically from PCL source code files with the [Doxygen](http://www.doxygen.nl/) documentation tool.
20[PCL Reference Documentation - HTML Format](https://pixinsight.com/developer/pcl/doc/html/index.html)
22Currently the PCL documentation is fairly complete, although there are still some classes and functions lacking detailed descriptions. If you find errors or inaccuracies in our documentation, we'd like to hear you to get them fixed. If you want to collaborate with us to enhance the existing PCL documentation, you are also welcome.
24## PCL Repository
26This PCL repository includes all standard PCL headers and source code, along with all third-party libraries required to build PCL on the user's machine. The repository also contains the complete source code of all standard PixInsight modules that have been released as open-source products, most of them under PCLL license.
28Here is a list of subdirectories, along with descriptions of the files therein. We assume that the PCL distribution has been installed on a <PCL> directory on your local filesystem; for example:
31 UNIX and Linux : [PCL] = $HOME/PCL<br/>
32 Windows : [PCL] = C:\PCL
38 Standard PCL C++ header files. These files are necessary for development of PixInsight modules.
44 Some third-party libraries, mainly file format support libraries, used by the PixInsight modules included in this distribution. The CFITSIO, LibRAW and JasPer libraries may include custom modifications, which are conveniently identified in the source code (search for the 'CUSTOM CODE' string).
50 Open-source PixInsight file format modules with complete source code.
56 Open-source PixInsight process modules, with complete source code. These source codes are ready for compilation and form an excellent body of development reference material.
58 On module subdirectories under the [PCL]/src/modules branch, we provide makefiles and project files that can be used to build and test the supplied modules; these files have been automatically generated by the standard Makefile Generator script in PixInsight. They can be regenerated with the same script to adapt the build process to the user requirements.
60 For each [module_name] module, makefiles and projects are available on the following subdirectories:
67 Makefiles for FreeBSD 12 with the system Clang C++ compiler
74 Makefiles for Linux with GCC >= 7 (GCC 9 or higher recommended)
81 Makefiles for macOS >= 10.14 with Clang C++ compiler/Xcode version >= 11.0
88 Project files (.vcxproj) for Microsoft Visual C++ 2017
94 The complete source code of PixInsight Class Library (PCL). Along with the PCL headers distributed on the [PCL]/include/pcl directory, you can use these source files with the provided makefiles and project files to rebuild PCL on your system.
98## Supported Compilers
100The current version of PCL has been built with:
102 * Ubuntu 18.04 LTS: GCC C/C++ compiler 9.2.1.
103 * FreeBSD 12.0: Clang C/C++ compiler, default system compiler version.
104 * macOS 10.14.6: Clang C/C++ compiler with Xcode 11.0, as provided by Apple.
105 * Windows 10: Microsoft Visual C++ 2017 Community Edition.
107This version of PCL requires a compiler with C++17 language support.
109The GCC and Clang C++ compilers provide higher conformance to ISO C++ standards and are high quality development tools. On FreeBSD and macOS we rely on the Clang/LLVM compiler included with the latest versions of Xcode and FreeBSD.
111On Windows, we provide project files for the Microsoft Visual Studio integrated development environment (.vcxproj files). Since PCL version 2.1.10, we support Visual C++ 2017 exclusively.
114## Environment Variables
116In order to use the PCL build system to compile and link PCL-based code, a number of environment variables must be defined on all platforms.
118With the following environment variables correctly defined, you can generate makefiles and project files for your modules on all platforms automatically with the Makefile Generator script, which we have included as a standard tool on all PixInsight core distributions.
123 PCL root directory. The value of this variable must be the full directory path where the PCL distribution has been installed on your computer. On FreeBSD, Linux and macOS, this variable should normally be (assuming that you have installed PCL on a 'PCL' subdirectory of your home directory):
131 and on Windows, something like:
139 or maybe something more practical such as:
146**PCLBINDIR32** (* Obsolete *)
149 Binary files subdirectory for 32-bit executables and shared objects. This variable has been deprecated and is no longer necessary. PCL development on 32-bit platforms is no longer supported.
155 Binary files subdirectory for 64-bit executables and shared objects. Normally this variable should be equal to $PCLDIR/bin.
161 PCL binaries directory. This variable should be equal to PCLBINDIR64.
164**PCLLIBDIR32** (* Obsolete *)
167 32-bit libraries subdirectory. This variable has been deprecated and is no longer necessary. PCL development on 32-bit platforms is no longer supported.
173 64-bit libraries subdirectory. This variable should normally be equal to $PCLDIR/lib/[platform]/x64 on each platform.
179 PCL library files directory. This variable should normally be equal to PCLLIBDIR64.
185 PCL include files directory. Should normally be equal to $PCLDIR/include.
191 PCL source files directory. Should normally be equal to $PCLDIR/src.
197###### Copyright (C) 2003-2019 Pleiades Astrophoto