diff options
| author | Willem Jan Palenstijn <Willem.Jan.Palenstijn@cwi.nl> | 2016-01-14 11:07:01 +0100 | 
|---|---|---|
| committer | Willem Jan Palenstijn <Willem.Jan.Palenstijn@cwi.nl> | 2016-01-14 11:07:01 +0100 | 
| commit | a7ce7a296545a9361c496e906997c9b7b5d70875 (patch) | |
| tree | 18075b5cef0df3c4ed6833df8890d41cdfc3acef | |
| parent | feedff76504d15c08ef46905410bbdbdc5bfe13d (diff) | |
| parent | 13d945c0b2812a5a4958876a80378f4015b173bf (diff) | |
| download | astra-a7ce7a296545a9361c496e906997c9b7b5d70875.tar.gz astra-a7ce7a296545a9361c496e906997c9b7b5d70875.tar.bz2 astra-a7ce7a296545a9361c496e906997c9b7b5d70875.tar.xz astra-a7ce7a296545a9361c496e906997c9b7b5d70875.zip | |
Merge branch 'master'
| -rw-r--r-- | matlab/mex/astra_mex.cpp | 124 | ||||
| -rw-r--r-- | src/CompositeGeometryManager.cpp | 12 | 
2 files changed, 12 insertions, 124 deletions
| diff --git a/matlab/mex/astra_mex.cpp b/matlab/mex/astra_mex.cpp deleted file mode 100644 index 4bf42dd..0000000 --- a/matlab/mex/astra_mex.cpp +++ /dev/null @@ -1,124 +0,0 @@ -/* ------------------------------------------------------------------------ -Copyright: 2010-2015, iMinds-Vision Lab, University of Antwerp -           2014-2015, CWI, Amsterdam - -Contact: astra@uantwerpen.be -Website: http://sf.net/projects/astra-toolbox - -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/>. - ------------------------------------------------------------------------ -$Id$ -*/ - -#include <mex.h> -#include "mexHelpFunctions.h" -#include "mexInitFunctions.h" - -#include "astra/Globals.h" - -using namespace std; -using namespace astra; - - -//----------------------------------------------------------------------------------------- -/** astra_mex('credits'); - *  - * Print Credits - */ -void astra_mex_credits(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) -{  -	cout << "All Scale Tomographic Reconstruction Antwerp Toolbox (ASTRA-Toolbox) was developed at the University of Antwerp by" << endl; -	cout << " * Joost Batenburg, PhD" << endl; -	cout << " * Gert Merckx" << endl; -	cout << " * Willem Jan Palenstijn" << endl; -	cout << " * Tom Roelandts" << endl; -	cout << " * Prof. Dr. Jan Sijbers" << endl; -	cout << " * Wim van Aarle" << endl; -	cout << " * Sander van der Maar" << endl; -	cout << " * Gert Van Gompel, PhD" << endl; -} - -//----------------------------------------------------------------------------------------- -/** use_cuda = astra_mex('use_cuda'); - *  - * Is CUDA enabled? - */ -void astra_mex_use_cuda(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) -{  -	if (1 <= nlhs) { -		plhs[0] = mxCreateDoubleScalar(astra::cudaEnabled() ? 1 : 0); -	} -} - -//----------------------------------------------------------------------------------------- -/** version_number = astra_mex('version'); - *  - * Fetch the version number of the toolbox. - */ -void astra_mex_version(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) -{  -	if (1 <= nlhs) { -		plhs[0] = mxCreateDoubleScalar(astra::getVersion()); -	} else { -		cout << "astra toolbox version " << astra::getVersionString() << endl; -	} -} - -//----------------------------------------------------------------------------------------- - -static void printHelp() -{ -	mexPrintf("Please specify a mode of operation.\n"); -	mexPrintf("   Valid modes: version, use_cuda, credits\n"); -} - -//----------------------------------------------------------------------------------------- -/** - * ... = astra_mex(type,...); - */ -void mexFunction(int nlhs, mxArray* plhs[], -				 int nrhs, const mxArray* prhs[]) -{ - -	// INPUT0: Mode -	string sMode = ""; -	if (1 <= nrhs) { -		sMode = mex_util_get_string(prhs[0]);	 -	} else { -		printHelp(); -		return; -	} - -	initASTRAMex(); - -	// SWITCH (MODE) -	if (sMode ==  std::string("version")) {  -		astra_mex_version(nlhs, plhs, nrhs, prhs);  -	} else if (sMode ==  std::string("use_cuda")) {	 -		astra_mex_use_cuda(nlhs, plhs, nrhs, prhs);  -	} else if (sMode ==  std::string("credits")) {	 -		astra_mex_credits(nlhs, plhs, nrhs, prhs);  -	} else { -		printHelp(); -	} - -	return; -} - - diff --git a/src/CompositeGeometryManager.cpp b/src/CompositeGeometryManager.cpp index 9be4797..41f6319 100644 --- a/src/CompositeGeometryManager.cpp +++ b/src/CompositeGeometryManager.cpp @@ -247,6 +247,18 @@ CCompositeGeometryManager::CPart* CCompositeGeometryManager::CVolumePart::reduce  	//ASTRA_DEBUG("coord extent: %f - %f", zmin, zmax); +	// Clip both zmin and zmax to get rid of extreme (or infinite) values +	// NB: When individual pz values are +/-Inf, the sign is determined +	// by ray direction and on which side of the face the ray passes. +	if (zmin < pGeom->getWindowMinZ() - 2*pixz) +		zmin = pGeom->getWindowMinZ() - 2*pixz; +	if (zmin > pGeom->getWindowMaxZ() + 2*pixz) +		zmin = pGeom->getWindowMaxZ() + 2*pixz; +	if (zmax < pGeom->getWindowMinZ() - 2*pixz) +		zmax = pGeom->getWindowMinZ() - 2*pixz; +	if (zmax > pGeom->getWindowMaxZ() + 2*pixz) +		zmax = pGeom->getWindowMaxZ() + 2*pixz; +  	zmin = (zmin - pixz - pGeom->getWindowMinZ()) / pixz;  	zmax = (zmax + pixz - pGeom->getWindowMinZ()) / pixz; | 
