Name Date Size #Lines LOC

..21-Feb-2019-

include/pcl/H21-Feb-2019-

src/H21-Feb-2019-

CODING_STYLE.mdH A D21-Feb-201918.6 KiB643455

COPYING.mdH A D09-Nov-20192.2 KiB4231

LICENSE.txtH A D09-Nov-20192.3 KiB4433

README.mdH A D09-Nov-20199.6 KiB198128

README.md

1PCL - PixInsight Class Library
2------------------------------
3
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.
5
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.
7
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.
9
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.
11
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.
13
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!
15
16## PCL Reference Documentation
17
18The official reference documentation for PCL has been generated automatically from PCL source code files with the [Doxygen](http://www.doxygen.nl/) documentation tool.
19
20[PCL Reference Documentation - HTML Format](https://pixinsight.com/developer/pcl/doc/html/index.html)
21
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.
23
24## PCL Repository
25
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.
27
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:
29
30<dl><dd>
31   UNIX and Linux : [PCL] = $HOME/PCL<br/>
32   Windows        : [PCL] = C:\PCL
33</dd></dl>
34
35**[PCL]/include/pcl**
36
37<dl><dd>
38   Standard PCL C++ header files. These files are necessary for development of PixInsight modules.
39</dd></dl>
40
41**[PCL]/src/3rdparty**
42
43<dl><dd>
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).
45</dd></dl>
46
47**[PCL]/src/modules/file-formats**
48
49<dl><dd>
50   Open-source PixInsight file format modules with complete source code.
51</dd></dl>
52
53**[PCL]/src/modules/processes**
54
55<dl><dd>
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.
57</dd><dd>
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.
59</dd><dd>
60   For each [module_name] module, makefiles and projects are available on the following subdirectories:
61</dd></dl>
62
63**[PCL]/src/modules/file-formats/[module_name]/freebsd/g++**<br/>
64**[PCL]/src/modules/processes/[module_name]/freebsd/g++**
65
66<dl><dd>
67   Makefiles for FreeBSD 12 with the system Clang C++ compiler
68</dd></dl>
69
70**[PCL]/src/modules/file-formats/[module_name]/linux/g++**<br/>
71**[PCL]/src/modules/processes/[module_name]/linux/g++**
72
73<dl><dd>
74   Makefiles for Linux with GCC >= 7 (GCC 9 or higher recommended)
75</dd></dl>
76
77**[PCL]/src/modules/file-formats/[module_name]/macosx/g++**<br/>
78**[PCL]/src/modules/processes/[module_name]/macosx/g++**
79
80<dl><dd>
81   Makefiles for macOS >= 10.14 with Clang C++ compiler/Xcode version >= 11.0
82</dd></dl>
83
84**[PCL]/src/modules/file-formats/[module_name]/windows/vc15**<br/>
85**[PCL]/src/modules/processes/[module_name]/windows/vc15**
86
87<dl><dd>
88   Project files (.vcxproj) for Microsoft Visual C++ 2017
89</dd></dl>
90
91**[PCL]/src/pcl**
92
93<dl><dd>
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.
95</dd></dl>
96
97
98## Supported Compilers
99
100The current version of PCL has been built with:
101
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.
106
107This version of PCL requires a compiler with C++17 language support.
108
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.
110
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.
112
113
114## Environment Variables
115
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.
117
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.
119
120**PCLDIR**
121
122<dl><dd>
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):
124</dd></dl>
125
126<dl><dd><dl><dd>
127   $HOME/PCL
128</dd></dl></dd></dl>
129
130<dl><dd>
131   and on Windows, something like:
132</dd></dl>
133
134<dl><dd><dl><dd>
135   C:\Users\[your-user-name]\PCL
136</dd></dl></dd></dl>
137
138<dl><dd>
139   or maybe something more practical such as:
140</dd></dl>
141
142<dl><dd><dl><dd>
143   C:\PCL
144</dd></dl></dd></dl>
145
146**PCLBINDIR32** (* Obsolete *)
147
148<dl><dd>
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.
150</dd></dl>
151
152**PCLBINDIR64**
153
154<dl><dd>
155   Binary files subdirectory for 64-bit executables and shared objects. Normally this variable should be equal to $PCLDIR/bin.
156</dd></dl>
157
158**PCLBINDIR**
159
160<dl><dd>
161   PCL binaries directory. This variable should be equal to PCLBINDIR64.
162</dd></dl>
163
164**PCLLIBDIR32** (* Obsolete *)
165
166<dl><dd>
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.
168</dd></dl>
169
170**PCLLIBDIR64**
171
172<dl><dd>
173   64-bit libraries subdirectory. This variable should normally be equal to $PCLDIR/lib/[platform]/x64 on each platform.
174</dd></dl>
175
176**PCLLIBDIR**
177
178<dl><dd>
179   PCL library files directory. This variable should normally be equal to PCLLIBDIR64.
180</dd></dl>
181
182**PCLINCDIR**
183
184<dl><dd>
185   PCL include files directory. Should normally be equal to $PCLDIR/include.
186</dd></dl>
187
188**PCLSRCDIR**
189
190<dl><dd>
191   PCL source files directory. Should normally be equal to $PCLDIR/src.
192</dd></dl>
193
194
195
196******
197###### Copyright (C) 2003-2019 Pleiades Astrophoto
198