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 a few classes 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, data compression and encryption support libraries, used by the PixInsight modules included in this distribution. The CFITSIO, LibTIFF 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.
62 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.
65On subdirectories under the [PCL]/src branch, we provide makefiles and project files that can be used to build and test the supplied libraries and modules. These files have been automatically generated by the standard MakefileGenerator script in the current version of PixInsight. All of these makefiles and project files can be regenerated with the same script to adapt the build process to the user requirements.
67For each [module_name] module and third-party or PCL [library_name], makefiles and projects are available on the following subdirectories:
75 Makefiles for FreeBSD 12 with the system Clang C++ compiler
84 Makefiles for Linux with GCC >= 7 (GCC 9 or higher recommended)
93 Makefiles for macOS >= 10.14 with Clang C++ compiler/Xcode version >= 11.0
102 Project files (.vcxproj) for Microsoft Visual C++ 2017
111 Project files (.vcxproj) for Microsoft Visual C++ 2019
117## Supported Compilers
119The current version of PCL has been built with:
121 * Ubuntu 18.04 LTS: GCC C/C++ compiler 9.3.0.
122 * FreeBSD 12.0: Clang C/C++ compiler, default system compiler version.
123 * macOS 10.15.6: Clang C/C++ compiler with Xcode 11.0, as provided by Apple.
124 * Windows 10: Microsoft Visual C++ 2019 Community Edition.
126This version of PCL requires a compiler with C++17 language support.
128The 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.
130On Linux and UNIX platforms we support GNU make exclusively, so you must use 'gmake' on FreeBSD instead of the default make utility.
132On Windows, we provide project files for the Microsoft Visual Studio integrated development environment (.vcxproj files). As of PCL version 2.4.0 we support Visual C++ 2017 and 2019 exclusively.
135## Environment Variables
137In 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.
139With 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.
144 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):
152 and on Windows, something like:
160 or maybe something more practical such as:
167**PCLBINDIR32** (* Obsolete *)
170 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.
176 Binary files subdirectory for 64-bit executables and shared objects. Normally this variable should be equal to $PCLDIR/bin.
182 PCL binaries directory. This variable should be equal to PCLBINDIR64.
185**PCLLIBDIR32** (* Obsolete *)
188 32-bit libraries subdirectory. This variable has been deprecated and is no longer necessary. PCL development on 32-bit platforms is no longer supported.
194 64-bit libraries subdirectory. This variable should normally be equal to $PCLDIR/lib/[platform]/x64 on each platform.
200 PCL library files directory. This variable should normally be equal to PCLLIBDIR64.
206 PCL include files directory. Should normally be equal to $PCLDIR/include.
212 PCL source files directory. Should normally be equal to $PCLDIR/src.
218###### Copyright (C) 2003-2020 Pleiades Astrophoto