/* ----------------------------------------------------------------------- Copyright: 2010-2021, imec Vision Lab, University of Antwerp 2014-2021, CWI, Amsterdam Contact: astra@astra-toolbox.com Website: http://www.astra-toolbox.com/ This file is part of the ASTRA Toolbox. The ASTRA Toolbox is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. The ASTRA Toolbox is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. ----------------------------------------------------------------------- */ #ifndef _INC_ASTRA_FEATURES #define _INC_ASTRA_FEATURES #include "astra/Globals.h" namespace astra { _AstraExport bool hasFeature(const std::string &feature); } /* FEATURES: cuda is cuda support compiled in? NB: To check if there is also actually a usable GPU, use cudaAvailable() mex_link is there support for the matlab command astra_mex_data3d('link')? projectors_scaled_as_line_integrals This is set since all 2D and 3D, CPU and GPU projectors scale their outputs to approximate line integrals. (Previously, some 2D projectors were scaled as area integrals.) fan_cone_BP_density_weighting_by_default This is set since fan beam and cone beam BP operations perform ray density weighting by default to more closely approximate the true mathematical adjoint. The DensityWeighting cuda3d projector option is removed. unpadded_GPULink This is set since FP3D no longer silently fails with GPULink memory that is not padded to a multiple of 32 pixels For future backward-incompatible changes, extra features will be added here */ #endif