diff options
157 files changed, 12187 insertions, 6543 deletions
@@ -27,6 +27,7 @@ Requirements: g++, boost, CUDA (driver+toolkit), matlab  ```  cd build/linux +./autogen.sh   # when building a git version  ./configure --with-cuda=/usr/local/cuda \              --with-matlab=/usr/local/MATLAB/R2012a \              --prefix=/usr/local/astra @@ -64,9 +65,14 @@ Install by copying AstraCuda32.dll or AstraCuda64.dll from bin/ and  ## References -If you use parallel beam GPU code for your research, we would appreciate it if you would refer to the following paper: +If you use the ASTRA Toolbox for your research, we would appreciate it if you would refer to the following paper: + +W. van Aarle, W. J. Palenstijn, J. De Beenhouwer, T. Altantzis, S. Bals,  K J. Batenburg, and J. Sijbers, "The ASTRA Toolbox: A platform for advanced algorithm development in electron tomography", Ultramicroscopy (2015), http://dx.doi.org/10.1016/j.ultramic.2015.05.002 + +Additionally, if you use parallel beam GPU code, we would appreciate it if you would refer to the following paper: + +W. J. Palenstijn, K J. Batenburg, and J. Sijbers, "Performance improvements for iterative electron tomography reconstruction using graphics processing units (GPUs)", Journal of Structural Biology, vol. 176, issue 2, pp. 250-253, 2011, http://dx.doi.org/10.1016/j.jsb.2011.07.017 -W. J. Palenstijn, K J. Batenburg, and J. Sijbers, "Performance improvements for iterative electron tomography reconstruction using graphics processing units (GPUs)", Journal of Structural Biology, vol. 176, issue 2, pp. 250-253, 2011.  ## License @@ -79,4 +85,4 @@ website: http://sf.net/projects/astra-toolbox  Copyright: 2010-2015, iMinds-Vision Lab, University of Antwerp             2014-2015, CWI, Amsterdam -           http://visielab.uantwerpen.be/ and http://www.cwi.nl/
\ No newline at end of file +           http://visielab.uantwerpen.be/ and http://www.cwi.nl/ @@ -52,6 +52,7 @@ Linux, from source:  Requirements: g++, boost, CUDA (driver+toolkit), matlab  cd build/linux +./autogen.sh   # when building a git version  ./configure --with-cuda=/usr/local/cuda \              --with-matlab=/usr/local/MATLAB/R2012a \              --prefix=/usr/local/astra @@ -90,11 +91,14 @@ Install by copying AstraCuda32.dll or AstraCuda64.dll from bin/ and  References:  ------------ -If you use parallel beam GPU code for your research, we would appreciate it if -you would refer to the following paper: +If you use the ASTRA Toolbox for your research, we would appreciate it if you would refer to the following paper: + +W. van Aarle, W. J. Palenstijn, J. De Beenhouwer, T. Altantzis, S. Bals,  K J. Batenburg, and J. Sijbers, "The ASTRA Toolbox: A platform for advanced algorithm development in electron tomography", Ultramicroscopy (2015), http://dx.doi.org/10.1016/j.ultramic.2015.05.002 + +Additionally, if you use parallel beam GPU code, we would appreciate it if you would refer to the following paper:  W. J. Palenstijn, K J. Batenburg, and J. Sijbers, "Performance improvements  for iterative electron tomography reconstruction using graphics processing  units (GPUs)", Journal of Structural Biology, vol. 176, issue 2, pp. 250-253, -2011 +2011, http://dx.doi.org/10.1016/j.jsb.2011.07.017 diff --git a/astra_vc08.sln b/astra_vc09.sln index 60f2e25..9b93a0f 100644 --- a/astra_vc08.sln +++ b/astra_vc09.sln @@ -1,215 +1,221 @@ -
 -Microsoft Visual Studio Solution File, Format Version 10.00
 -# Visual Studio 2008
 -Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "astra_mex", "astra_mex", "{33EF0AC5-B475-40BF-BAE5-67075B204D10}"
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_matrix", "matlab\mex\astra_mex_matrix_vc08.vcproj", "{9D041710-2119-4230-BCF2-5FBE753FDE49}"
 -	ProjectSection(ProjectDependencies) = postProject
 -		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA}
 -	EndProjectSection
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra", "astra_vc08.vcproj", "{12926444-6723-46A8-B388-12E65E0577FA}"
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "tests", "tests\tests_vc08.vcproj", "{32C1BDD3-38C2-4C80-A03C-2129782F59B5}"
 -	ProjectSection(ProjectDependencies) = postProject
 -		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA}
 -	EndProjectSection
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_projector", "matlab\mex\astra_mex_projector_vc08.vcproj", "{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}"
 -	ProjectSection(ProjectDependencies) = postProject
 -		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA}
 -	EndProjectSection
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_projector3d", "matlab\mex\astra_mex_projector3d_vc08.vcproj", "{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}"
 -	ProjectSection(ProjectDependencies) = postProject
 -		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA}
 -	EndProjectSection
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_data3d", "matlab\mex\astra_mex_data3d_vc08.vcproj", "{0BEC029B-0929-4BF9-BD8B-9C9806A52065}"
 -	ProjectSection(ProjectDependencies) = postProject
 -		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA}
 -	EndProjectSection
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_data2d", "matlab\mex\astra_mex_data2d_vc08.vcproj", "{E4092269-B19C-46F7-A84E-4F146CC70E44}"
 -	ProjectSection(ProjectDependencies) = postProject
 -		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA}
 -	EndProjectSection
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_algorithm", "matlab\mex\astra_mex_algorithm_vc08.vcproj", "{056BF7A9-294D-487C-8CC3-BE629077CA94}"
 -	ProjectSection(ProjectDependencies) = postProject
 -		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA}
 -	EndProjectSection
 -EndProject
 -Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex", "matlab\mex\astra_mex_vc08.vcproj", "{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}"
 -	ProjectSection(ProjectDependencies) = postProject
 -		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA}
 -	EndProjectSection
 -EndProject
 -Global
 -	GlobalSection(SolutionConfigurationPlatforms) = preSolution
 -		Debug_CUDA|Win32 = Debug_CUDA|Win32
 -		Debug_CUDA|x64 = Debug_CUDA|x64
 -		Debug|Win32 = Debug|Win32
 -		Debug|x64 = Debug|x64
 -		Release_CUDA|Win32 = Release_CUDA|Win32
 -		Release_CUDA|x64 = Release_CUDA|x64
 -		Release|Win32 = Release|Win32
 -		Release|x64 = Release|x64
 -	EndGlobalSection
 -	GlobalSection(ProjectConfigurationPlatforms) = postSolution
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug|Win32.Build.0 = Debug|Win32
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug|x64.ActiveCfg = Debug|x64
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug|x64.Build.0 = Debug|x64
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release_CUDA|x64.Build.0 = Release_CUDA|x64
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release|Win32.ActiveCfg = Release|Win32
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release|Win32.Build.0 = Release|Win32
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release|x64.ActiveCfg = Release|x64
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release|x64.Build.0 = Release|x64
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Debug|Win32.Build.0 = Debug|Win32
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Debug|x64.ActiveCfg = Debug|x64
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Debug|x64.Build.0 = Debug|x64
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Release_CUDA|x64.Build.0 = Release_CUDA|x64
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Release|Win32.ActiveCfg = Release|Win32
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Release|Win32.Build.0 = Release|Win32
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Release|x64.ActiveCfg = Release|x64
 -		{12926444-6723-46A8-B388-12E65E0577FA}.Release|x64.Build.0 = Release|x64
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Debug|Win32.Build.0 = Debug|Win32
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Debug|x64.ActiveCfg = Debug|x64
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Debug|x64.Build.0 = Debug|x64
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Release|Win32.ActiveCfg = Release|Win32
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Release|Win32.Build.0 = Release|Win32
 -		{32C1BDD3-38C2-4C80-A03C-2129782F59B5}.Release|x64.ActiveCfg = Release|x64
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug|Win32.Build.0 = Debug|Win32
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug|x64.ActiveCfg = Debug|x64
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug|x64.Build.0 = Debug|x64
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release_CUDA|x64.Build.0 = Release_CUDA|x64
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release|Win32.ActiveCfg = Release|Win32
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release|Win32.Build.0 = Release|Win32
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release|x64.ActiveCfg = Release|x64
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release|x64.Build.0 = Release|x64
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug|Win32.Build.0 = Debug|Win32
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug|x64.ActiveCfg = Debug|x64
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug|x64.Build.0 = Debug|x64
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release_CUDA|x64.Build.0 = Release_CUDA|x64
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|Win32.ActiveCfg = Release|Win32
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|Win32.Build.0 = Release|Win32
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|x64.ActiveCfg = Release|x64
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|x64.Build.0 = Release|x64
 -
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug|Win32.Build.0 = Debug|Win32
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug|x64.ActiveCfg = Debug|x64
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug|x64.Build.0 = Debug|x64
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release_CUDA|x64.Build.0 = Release_CUDA|x64
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release|Win32.ActiveCfg = Release|Win32
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release|Win32.Build.0 = Release|Win32
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release|x64.ActiveCfg = Release|x64
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release|x64.Build.0 = Release|x64
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug|Win32.Build.0 = Debug|Win32
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug|x64.ActiveCfg = Debug|x64
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug|x64.Build.0 = Debug|x64
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release_CUDA|x64.Build.0 = Release_CUDA|x64
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release|Win32.ActiveCfg = Release|Win32
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release|Win32.Build.0 = Release|Win32
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release|x64.ActiveCfg = Release|x64
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release|x64.Build.0 = Release|x64
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug|Win32.Build.0 = Debug|Win32
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug|x64.ActiveCfg = Debug|x64
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug|x64.Build.0 = Debug|x64
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release_CUDA|x64.Build.0 = Release_CUDA|x64
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release|Win32.ActiveCfg = Release|Win32
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release|Win32.Build.0 = Release|Win32
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release|x64.ActiveCfg = Release|x64
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release|x64.Build.0 = Release|x64
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug|Win32.ActiveCfg = Debug|Win32
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug|Win32.Build.0 = Debug|Win32
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug|x64.ActiveCfg = Debug|x64
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug|x64.Build.0 = Debug|x64
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release_CUDA|x64.Build.0 = Release_CUDA|x64
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release|Win32.ActiveCfg = Release|Win32
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release|Win32.Build.0 = Release|Win32
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release|x64.ActiveCfg = Release|x64
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release|x64.Build.0 = Release|x64
 -	EndGlobalSection
 -	GlobalSection(SolutionProperties) = preSolution
 -		HideSolutionNode = FALSE
 -	EndGlobalSection
 -	GlobalSection(NestedProjects) = preSolution
 -		{9D041710-2119-4230-BCF2-5FBE753FDE49} = {33EF0AC5-B475-40BF-BAE5-67075B204D10}
 -		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97} = {33EF0AC5-B475-40BF-BAE5-67075B204D10}
 -		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883} = {33EF0AC5-B475-40BF-BAE5-67075B204D10}
 -		{0BEC029B-0929-4BF9-BD8B-9C9806A52065} = {33EF0AC5-B475-40BF-BAE5-67075B204D10}
 -		{E4092269-B19C-46F7-A84E-4F146CC70E44} = {33EF0AC5-B475-40BF-BAE5-67075B204D10}
 -		{056BF7A9-294D-487C-8CC3-BE629077CA94} = {33EF0AC5-B475-40BF-BAE5-67075B204D10}
 -		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221} = {33EF0AC5-B475-40BF-BAE5-67075B204D10}
 -	EndGlobalSection
 -EndGlobal
 + +Microsoft Visual Studio Solution File, Format Version 10.00 +# Visual Studio 2008 +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra", "astra_vc09.vcproj", "{12926444-6723-46A8-B388-12E65E0577FA}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "astra_mex", "astra_mex", "{33EF0AC5-B475-40BF-BAE5-67075B204D10}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex", "matlab\mex\astra_mex_vc09.vcproj", "{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_algorithm", "matlab\mex\astra_mex_algorithm_vc09.vcproj", "{056BF7A9-294D-487C-8CC3-BE629077CA94}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_data2d", "matlab\mex\astra_mex_data2d_vc09.vcproj", "{E4092269-B19C-46F7-A84E-4F146CC70E44}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_data3d", "matlab\mex\astra_mex_data3d_vc09.vcproj", "{0BEC029B-0929-4BF9-BD8B-9C9806A52065}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_matrix", "matlab\mex\astra_mex_matrix_vc09.vcproj", "{9D041710-2119-4230-BCF2-5FBE753FDE49}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_projector", "matlab\mex\astra_mex_projector_vc09.vcproj", "{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_projector3d", "matlab\mex\astra_mex_projector3d_vc09.vcproj", "{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_log", "matlab\mex\astra_mex_log_vc09.vcproj", "{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}" +	ProjectSection(ProjectDependencies) = postProject +		{12926444-6723-46A8-B388-12E65E0577FA} = {12926444-6723-46A8-B388-12E65E0577FA} +	EndProjectSection +EndProject +Global +	GlobalSection(SolutionConfigurationPlatforms) = preSolution +		Debug_CUDA|Win32 = Debug_CUDA|Win32 +		Debug_CUDA|x64 = Debug_CUDA|x64 +		Debug|Win32 = Debug|Win32 +		Debug|x64 = Debug|x64 +		Release_CUDA|Win32 = Release_CUDA|Win32 +		Release_CUDA|x64 = Release_CUDA|x64 +		Release|Win32 = Release|Win32 +		Release|x64 = Release|x64 +	EndGlobalSection +	GlobalSection(ProjectConfigurationPlatforms) = postSolution +		{12926444-6723-46A8-B388-12E65E0577FA}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{12926444-6723-46A8-B388-12E65E0577FA}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{12926444-6723-46A8-B388-12E65E0577FA}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{12926444-6723-46A8-B388-12E65E0577FA}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{12926444-6723-46A8-B388-12E65E0577FA}.Debug|Win32.ActiveCfg = Debug|Win32 +		{12926444-6723-46A8-B388-12E65E0577FA}.Debug|Win32.Build.0 = Debug|Win32 +		{12926444-6723-46A8-B388-12E65E0577FA}.Debug|x64.ActiveCfg = Debug|x64 +		{12926444-6723-46A8-B388-12E65E0577FA}.Debug|x64.Build.0 = Debug|x64 +		{12926444-6723-46A8-B388-12E65E0577FA}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{12926444-6723-46A8-B388-12E65E0577FA}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{12926444-6723-46A8-B388-12E65E0577FA}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{12926444-6723-46A8-B388-12E65E0577FA}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{12926444-6723-46A8-B388-12E65E0577FA}.Release|Win32.ActiveCfg = Release|Win32 +		{12926444-6723-46A8-B388-12E65E0577FA}.Release|Win32.Build.0 = Release|Win32 +		{12926444-6723-46A8-B388-12E65E0577FA}.Release|x64.ActiveCfg = Release|x64 +		{12926444-6723-46A8-B388-12E65E0577FA}.Release|x64.Build.0 = Release|x64 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug|Win32.ActiveCfg = Debug|Win32 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug|Win32.Build.0 = Debug|Win32 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug|x64.ActiveCfg = Debug|x64 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Debug|x64.Build.0 = Debug|x64 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release|Win32.ActiveCfg = Release|Win32 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release|Win32.Build.0 = Release|Win32 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release|x64.ActiveCfg = Release|x64 +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}.Release|x64.Build.0 = Release|x64 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug|Win32.ActiveCfg = Debug|Win32 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug|Win32.Build.0 = Debug|Win32 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug|x64.ActiveCfg = Debug|x64 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Debug|x64.Build.0 = Debug|x64 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release|Win32.ActiveCfg = Release|Win32 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release|Win32.Build.0 = Release|Win32 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release|x64.ActiveCfg = Release|x64 +		{056BF7A9-294D-487C-8CC3-BE629077CA94}.Release|x64.Build.0 = Release|x64 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug|Win32.ActiveCfg = Debug|Win32 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug|Win32.Build.0 = Debug|Win32 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug|x64.ActiveCfg = Debug|x64 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Debug|x64.Build.0 = Debug|x64 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release|Win32.ActiveCfg = Release|Win32 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release|Win32.Build.0 = Release|Win32 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release|x64.ActiveCfg = Release|x64 +		{E4092269-B19C-46F7-A84E-4F146CC70E44}.Release|x64.Build.0 = Release|x64 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug|Win32.ActiveCfg = Debug|Win32 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug|Win32.Build.0 = Debug|Win32 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug|x64.ActiveCfg = Debug|x64 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Debug|x64.Build.0 = Debug|x64 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release|Win32.ActiveCfg = Release|Win32 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release|Win32.Build.0 = Release|Win32 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release|x64.ActiveCfg = Release|x64 +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065}.Release|x64.Build.0 = Release|x64 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug|Win32.ActiveCfg = Debug|Win32 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug|Win32.Build.0 = Debug|Win32 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug|x64.ActiveCfg = Debug|x64 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Debug|x64.Build.0 = Debug|x64 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release|Win32.ActiveCfg = Release|Win32 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release|Win32.Build.0 = Release|Win32 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release|x64.ActiveCfg = Release|x64 +		{9D041710-2119-4230-BCF2-5FBE753FDE49}.Release|x64.Build.0 = Release|x64 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug|Win32.ActiveCfg = Debug|Win32 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug|Win32.Build.0 = Debug|Win32 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug|x64.ActiveCfg = Debug|x64 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Debug|x64.Build.0 = Debug|x64 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release|Win32.ActiveCfg = Release|Win32 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release|Win32.Build.0 = Release|Win32 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release|x64.ActiveCfg = Release|x64 +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}.Release|x64.Build.0 = Release|x64 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug|Win32.ActiveCfg = Debug|Win32 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug|Win32.Build.0 = Debug|Win32 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug|x64.ActiveCfg = Debug|x64 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Debug|x64.Build.0 = Debug|x64 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|Win32.ActiveCfg = Release|Win32 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|Win32.Build.0 = Release|Win32 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|x64.ActiveCfg = Release|x64 +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|x64.Build.0 = Release|x64 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Debug|Win32.ActiveCfg = Debug|Win32 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Debug|Win32.Build.0 = Debug|Win32 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Debug|x64.ActiveCfg = Debug|x64 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Debug|x64.Build.0 = Debug|x64 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Release|Win32.ActiveCfg = Release|Win32 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Release|Win32.Build.0 = Release|Win32 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Release|x64.ActiveCfg = Release|x64 +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}.Release|x64.Build.0 = Release|x64 +	EndGlobalSection +	GlobalSection(SolutionProperties) = preSolution +		HideSolutionNode = FALSE +	EndGlobalSection +	GlobalSection(NestedProjects) = preSolution +		{3FDA35E0-0D54-4663-A3E6-5ABA96F32221} = {33EF0AC5-B475-40BF-BAE5-67075B204D10} +		{056BF7A9-294D-487C-8CC3-BE629077CA94} = {33EF0AC5-B475-40BF-BAE5-67075B204D10} +		{E4092269-B19C-46F7-A84E-4F146CC70E44} = {33EF0AC5-B475-40BF-BAE5-67075B204D10} +		{0BEC029B-0929-4BF9-BD8B-9C9806A52065} = {33EF0AC5-B475-40BF-BAE5-67075B204D10} +		{9D041710-2119-4230-BCF2-5FBE753FDE49} = {33EF0AC5-B475-40BF-BAE5-67075B204D10} +		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97} = {33EF0AC5-B475-40BF-BAE5-67075B204D10} +		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883} = {33EF0AC5-B475-40BF-BAE5-67075B204D10} +		{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8} = {33EF0AC5-B475-40BF-BAE5-67075B204D10} +	EndGlobalSection +EndGlobal diff --git a/astra_vc08.vcproj b/astra_vc09.vcproj index 957586a..a56e4bc 100644 --- a/astra_vc08.vcproj +++ b/astra_vc09.vcproj @@ -1,3158 +1,3184 @@ -<?xml version="1.0" encoding="Windows-1252"?>
 -<VisualStudioProject
 -	ProjectType="Visual C++"
 -	Version="9,00"
 -	Name="astra"
 -	ProjectGUID="{12926444-6723-46A8-B388-12E65E0577FA}"
 -	RootNamespace="astra"
 -	TargetFrameworkVersion="131072"
 -	>
 -	<Platforms>
 -		<Platform
 -			Name="Win32"
 -		/>
 -		<Platform
 -			Name="x64"
 -		/>
 -	</Platforms>
 -	<ToolFiles>
 -		<ToolFile
 -			RelativePath=".\build\Cuda.rules"
 -		/>
 -	</ToolFiles>
 -	<Configurations>
 -		<Configuration
 -			Name="Release|Win32"
 -			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Release"
 -			IntermediateDirectory="$(OutDir)/obj"
 -			ConfigurationType="2"
 -			>
 -			<Tool
 -				Name="VCPreBuildEventTool"
 -			/>
 -			<Tool
 -				Name="VCCustomBuildTool"
 -			/>
 -			<Tool
 -				Name="CUDA Build Rule"
 -				Include="lib\include\cuda"
 -				Defines="-DDLL_EXPORTS"
 -				Platform="1"
 -			/>
 -			<Tool
 -				Name="VCXMLDataGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCWebServiceProxyGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCMIDLTool"
 -			/>
 -			<Tool
 -				Name="VCCLCompilerTool"
 -				Optimization="3"
 -				InlineFunctionExpansion="0"
 -				EnableIntrinsicFunctions="false"
 -				FavorSizeOrSpeed="1"
 -				OmitFramePointers="false"
 -				EnableFiberSafeOptimizations="false"
 -				WholeProgramOptimization="false"
 -				AdditionalIncludeDirectories="lib\include;include"
 -				PreprocessorDefinitions="DLL_EXPORTS"
 -				ExceptionHandling="1"
 -				RuntimeLibrary="2"
 -			/>
 -			<Tool
 -				Name="VCManagedResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCPreLinkEventTool"
 -			/>
 -			<Tool
 -				Name="VCLinkerTool"
 -				AdditionalDependencies=""
 -				OutputFile="bin\win32\Astra32.dll"
 -				AdditionalLibraryDirectories="".\lib\win32""
 -				GenerateManifest="true"
 -				ModuleDefinitionFile=""
 -				RandomizedBaseAddress="1"
 -				DataExecutionPrevention="0"
 -				Profile="false"
 -			/>
 -			<Tool
 -				Name="VCALinkTool"
 -			/>
 -			<Tool
 -				Name="VCManifestTool"
 -			/>
 -			<Tool
 -				Name="VCXDCMakeTool"
 -			/>
 -			<Tool
 -				Name="VCBscMakeTool"
 -			/>
 -			<Tool
 -				Name="VCFxCopTool"
 -			/>
 -			<Tool
 -				Name="VCAppVerifierTool"
 -			/>
 -			<Tool
 -				Name="VCPostBuildEventTool"
 -			/>
 -		</Configuration>
 -		<Configuration
 -			Name="Release|x64"
 -			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Release"
 -			IntermediateDirectory="$(OutDir)/obj"
 -			ConfigurationType="2"
 -			>
 -			<Tool
 -				Name="VCPreBuildEventTool"
 -			/>
 -			<Tool
 -				Name="VCCustomBuildTool"
 -			/>
 -			<Tool
 -				Name="CUDA Build Rule"
 -				Include="lib\include\cuda"
 -				Defines="-DDLL_EXPORTS"
 -				Platform="2"
 -			/>
 -			<Tool
 -				Name="VCXMLDataGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCWebServiceProxyGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCMIDLTool"
 -			/>
 -			<Tool
 -				Name="VCCLCompilerTool"
 -				AdditionalIncludeDirectories="lib\include;include"
 -				PreprocessorDefinitions="DLL_EXPORTS"
 -				RuntimeLibrary="2"
 -			/>
 -			<Tool
 -				Name="VCManagedResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCPreLinkEventTool"
 -			/>
 -			<Tool
 -				Name="VCLinkerTool"
 -				AdditionalDependencies=""
 -				OutputFile="bin\x64\Astra64.dll"
 -				AdditionalLibraryDirectories="".\lib\x64""
 -				GenerateManifest="true"
 -				ModuleDefinitionFile=""
 -				RandomizedBaseAddress="1"
 -				DataExecutionPrevention="0"
 -			/>
 -			<Tool
 -				Name="VCALinkTool"
 -			/>
 -			<Tool
 -				Name="VCManifestTool"
 -			/>
 -			<Tool
 -				Name="VCXDCMakeTool"
 -			/>
 -			<Tool
 -				Name="VCBscMakeTool"
 -			/>
 -			<Tool
 -				Name="VCFxCopTool"
 -			/>
 -			<Tool
 -				Name="VCAppVerifierTool"
 -			/>
 -			<Tool
 -				Name="VCPostBuildEventTool"
 -			/>
 -		</Configuration>
 -		<Configuration
 -			Name="Release_CUDA|Win32"
 -			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Release_CUDA"
 -			IntermediateDirectory="$(OutDir)/obj"
 -			ConfigurationType="2"
 -			>
 -			<Tool
 -				Name="VCPreBuildEventTool"
 -			/>
 -			<Tool
 -				Name="VCCustomBuildTool"
 -			/>
 -			<Tool
 -				Name="CUDA Build Rule"
 -				Include="lib\include\cuda"
 -				Defines="-DDLL_EXPORTS"
 -				Runtime="2"
 -				Platform="1"
 -			/>
 -			<Tool
 -				Name="VCXMLDataGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCWebServiceProxyGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCMIDLTool"
 -			/>
 -			<Tool
 -				Name="VCCLCompilerTool"
 -				Optimization="3"
 -				InlineFunctionExpansion="0"
 -				EnableIntrinsicFunctions="false"
 -				FavorSizeOrSpeed="1"
 -				OmitFramePointers="false"
 -				EnableFiberSafeOptimizations="false"
 -				WholeProgramOptimization="false"
 -				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\include;lib\include\cuda;include\"
 -				PreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS"
 -				ExceptionHandling="1"
 -				RuntimeLibrary="2"
 -				CallingConvention="0"
 -			/>
 -			<Tool
 -				Name="VCManagedResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCPreLinkEventTool"
 -			/>
 -			<Tool
 -				Name="VCLinkerTool"
 -				AdditionalDependencies="cudart.lib cufft.lib"
 -				OutputFile="bin\win32\AstraCuda32.dll"
 -				AdditionalLibraryDirectories="".\lib\win32";"$(CUDA_LIB_PATH)";"$(NVSDKCOMPUTE_ROOT)"/C/common/lib"
 -				GenerateManifest="true"
 -				ModuleDefinitionFile=""
 -				RandomizedBaseAddress="1"
 -				DataExecutionPrevention="0"
 -				Profile="false"
 -			/>
 -			<Tool
 -				Name="VCALinkTool"
 -			/>
 -			<Tool
 -				Name="VCManifestTool"
 -			/>
 -			<Tool
 -				Name="VCXDCMakeTool"
 -			/>
 -			<Tool
 -				Name="VCBscMakeTool"
 -			/>
 -			<Tool
 -				Name="VCFxCopTool"
 -			/>
 -			<Tool
 -				Name="VCAppVerifierTool"
 -			/>
 -			<Tool
 -				Name="VCPostBuildEventTool"
 -			/>
 -		</Configuration>
 -		<Configuration
 -			Name="Release_CUDA|x64"
 -			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Release_CUDA"
 -			IntermediateDirectory="$(OutDir)/obj"
 -			ConfigurationType="2"
 -			>
 -			<Tool
 -				Name="VCPreBuildEventTool"
 -			/>
 -			<Tool
 -				Name="VCCustomBuildTool"
 -			/>
 -			<Tool
 -				Name="CUDA Build Rule"
 -				Include="lib\include\cuda"
 -				Defines="DLL_EXPORTS"
 -				Runtime="2"
 -				Platform="2"
 -			/>
 -			<Tool
 -				Name="VCXMLDataGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCWebServiceProxyGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCMIDLTool"
 -			/>
 -			<Tool
 -				Name="VCCLCompilerTool"
 -				AdditionalOptions="/MP"
 -				Optimization="3"
 -				InlineFunctionExpansion="2"
 -				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\include;lib\include\cuda;include\"
 -				PreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS"
 -				RuntimeLibrary="2"
 -			/>
 -			<Tool
 -				Name="VCManagedResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCPreLinkEventTool"
 -			/>
 -			<Tool
 -				Name="VCLinkerTool"
 -				AdditionalDependencies="cudart.lib cufft.lib"
 -				OutputFile="bin\x64\AstraCuda64.dll"
 -				AdditionalLibraryDirectories="".\lib\x64";"$(CUDA_LIB_PATH)";"$(NVSDKCOMPUTE_ROOT)"/C/common/lib"
 -				GenerateManifest="true"
 -				IgnoreAllDefaultLibraries="false"
 -				ModuleDefinitionFile=""
 -				RandomizedBaseAddress="1"
 -				DataExecutionPrevention="0"
 -			/>
 -			<Tool
 -				Name="VCALinkTool"
 -			/>
 -			<Tool
 -				Name="VCManifestTool"
 -			/>
 -			<Tool
 -				Name="VCXDCMakeTool"
 -			/>
 -			<Tool
 -				Name="VCBscMakeTool"
 -			/>
 -			<Tool
 -				Name="VCFxCopTool"
 -			/>
 -			<Tool
 -				Name="VCAppVerifierTool"
 -			/>
 -			<Tool
 -				Name="VCPostBuildEventTool"
 -			/>
 -		</Configuration>
 -		<Configuration
 -			Name="Debug_CUDA|Win32"
 -			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Debug_CUDA"
 -			IntermediateDirectory="$(OutDir)/obj"
 -			ConfigurationType="2"
 -			>
 -			<Tool
 -				Name="VCPreBuildEventTool"
 -			/>
 -			<Tool
 -				Name="VCCustomBuildTool"
 -			/>
 -			<Tool
 -				Name="CUDA Build Rule"
 -				Include="lib\include\cuda"
 -				Debug="true"
 -				Defines="-DDLL_EXPORTS"
 -				Optimization="0"
 -				Runtime="3"
 -				Platform="1"
 -			/>
 -			<Tool
 -				Name="VCXMLDataGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCWebServiceProxyGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCMIDLTool"
 -			/>
 -			<Tool
 -				Name="VCCLCompilerTool"
 -				Optimization="0"
 -				InlineFunctionExpansion="0"
 -				EnableIntrinsicFunctions="false"
 -				FavorSizeOrSpeed="0"
 -				OmitFramePointers="false"
 -				EnableFiberSafeOptimizations="false"
 -				WholeProgramOptimization="false"
 -				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\include;lib\include\cuda;include\"
 -				PreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS;_DEBUG"
 -				ExceptionHandling="1"
 -				RuntimeLibrary="3"
 -				DebugInformationFormat="3"
 -				CallingConvention="0"
 -			/>
 -			<Tool
 -				Name="VCManagedResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCPreLinkEventTool"
 -			/>
 -			<Tool
 -				Name="VCLinkerTool"
 -				AdditionalDependencies="cufft.lib cudart.lib"
 -				OutputFile="bin\win32\AstraCuda32D.dll"
 -				AdditionalLibraryDirectories="".\lib\win32";"$(CUDA_LIB_PATH)";"$(NVSDKCOMPUTE_ROOT)"/C/common/lib"
 -				GenerateManifest="true"
 -				IgnoreAllDefaultLibraries="false"
 -				IgnoreDefaultLibraryNames=""
 -				ModuleDefinitionFile=""
 -				GenerateDebugInformation="true"
 -				AssemblyDebug="1"
 -				RandomizedBaseAddress="1"
 -				DataExecutionPrevention="0"
 -				Profile="false"
 -			/>
 -			<Tool
 -				Name="VCALinkTool"
 -			/>
 -			<Tool
 -				Name="VCManifestTool"
 -			/>
 -			<Tool
 -				Name="VCXDCMakeTool"
 -			/>
 -			<Tool
 -				Name="VCBscMakeTool"
 -			/>
 -			<Tool
 -				Name="VCFxCopTool"
 -			/>
 -			<Tool
 -				Name="VCAppVerifierTool"
 -			/>
 -			<Tool
 -				Name="VCPostBuildEventTool"
 -			/>
 -		</Configuration>
 -		<Configuration
 -			Name="Debug_CUDA|x64"
 -			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Debug_CUDA"
 -			IntermediateDirectory="$(OutDir)/obj"
 -			ConfigurationType="2"
 -			>
 -			<Tool
 -				Name="VCPreBuildEventTool"
 -			/>
 -			<Tool
 -				Name="VCCustomBuildTool"
 -			/>
 -			<Tool
 -				Name="CUDA Build Rule"
 -				Include="lib\include\cuda;include;lib\include"
 -				Debug="true"
 -				Defines="-DDLL_EXPORTS"
 -				Optimization="0"
 -				Runtime="3"
 -				Platform="2"
 -			/>
 -			<Tool
 -				Name="VCXMLDataGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCWebServiceProxyGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCMIDLTool"
 -				TargetEnvironment="3"
 -			/>
 -			<Tool
 -				Name="VCCLCompilerTool"
 -				Optimization="0"
 -				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\include;lib\include\cuda;include\"
 -				PreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS;_DEBUG"
 -				RuntimeLibrary="3"
 -				DebugInformationFormat="3"
 -			/>
 -			<Tool
 -				Name="VCManagedResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCPreLinkEventTool"
 -			/>
 -			<Tool
 -				Name="VCLinkerTool"
 -				AdditionalDependencies="cudart.lib cufft.lib"
 -				OutputFile="bin\x64\AstraCuda64D.dll"
 -				AdditionalLibraryDirectories="".\lib\x64";"$(CUDA_LIB_PATH)";"$(NVSDKCOMPUTE_ROOT)"/C/common/lib"
 -				GenerateManifest="true"
 -				IgnoreAllDefaultLibraries="false"
 -				IgnoreDefaultLibraryNames=""
 -				ModuleDefinitionFile=""
 -				GenerateDebugInformation="true"
 -				RandomizedBaseAddress="1"
 -				DataExecutionPrevention="0"
 -				TargetMachine="17"
 -			/>
 -			<Tool
 -				Name="VCALinkTool"
 -			/>
 -			<Tool
 -				Name="VCManifestTool"
 -			/>
 -			<Tool
 -				Name="VCXDCMakeTool"
 -			/>
 -			<Tool
 -				Name="VCBscMakeTool"
 -			/>
 -			<Tool
 -				Name="VCFxCopTool"
 -			/>
 -			<Tool
 -				Name="VCAppVerifierTool"
 -			/>
 -			<Tool
 -				Name="VCPostBuildEventTool"
 -			/>
 -		</Configuration>
 -		<Configuration
 -			Name="Debug|Win32"
 -			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Debug"
 -			IntermediateDirectory="$(OutDir)/obj"
 -			ConfigurationType="2"
 -			>
 -			<Tool
 -				Name="VCPreBuildEventTool"
 -			/>
 -			<Tool
 -				Name="VCCustomBuildTool"
 -			/>
 -			<Tool
 -				Name="CUDA Build Rule"
 -				Include="lib\include\cuda"
 -				Defines="-DDLL_EXPORTS"
 -				Platform="1"
 -			/>
 -			<Tool
 -				Name="VCXMLDataGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCWebServiceProxyGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCMIDLTool"
 -			/>
 -			<Tool
 -				Name="VCCLCompilerTool"
 -				Optimization="0"
 -				FavorSizeOrSpeed="0"
 -				AdditionalIncludeDirectories="lib\include;include"
 -				PreprocessorDefinitions="_DEBUG;DLL_EXPORTS"
 -				RuntimeLibrary="3"
 -				DebugInformationFormat="3"
 -				EnablePREfast="false"
 -			/>
 -			<Tool
 -				Name="VCManagedResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCPreLinkEventTool"
 -			/>
 -			<Tool
 -				Name="VCLinkerTool"
 -				AdditionalDependencies=""
 -				OutputFile="bin\win32\Astra32D.dll"
 -				AdditionalLibraryDirectories="".\lib\win32""
 -				GenerateManifest="true"
 -				DelayLoadDLLs=""
 -				GenerateDebugInformation="true"
 -				GenerateMapFile="false"
 -				RandomizedBaseAddress="1"
 -				DataExecutionPrevention="0"
 -				Profile="false"
 -			/>
 -			<Tool
 -				Name="VCALinkTool"
 -			/>
 -			<Tool
 -				Name="VCManifestTool"
 -			/>
 -			<Tool
 -				Name="VCXDCMakeTool"
 -			/>
 -			<Tool
 -				Name="VCBscMakeTool"
 -			/>
 -			<Tool
 -				Name="VCFxCopTool"
 -			/>
 -			<Tool
 -				Name="VCAppVerifierTool"
 -			/>
 -			<Tool
 -				Name="VCPostBuildEventTool"
 -			/>
 -		</Configuration>
 -		<Configuration
 -			Name="Debug|x64"
 -			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Debug"
 -			IntermediateDirectory="$(OutDir)/obj"
 -			ConfigurationType="2"
 -			>
 -			<Tool
 -				Name="VCPreBuildEventTool"
 -			/>
 -			<Tool
 -				Name="VCCustomBuildTool"
 -			/>
 -			<Tool
 -				Name="CUDA Build Rule"
 -				Include="lib\include\cuda"
 -				Defines="-DDLL_EXPORTS"
 -				Platform="2"
 -			/>
 -			<Tool
 -				Name="VCXMLDataGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCWebServiceProxyGeneratorTool"
 -			/>
 -			<Tool
 -				Name="VCMIDLTool"
 -				TargetEnvironment="3"
 -			/>
 -			<Tool
 -				Name="VCCLCompilerTool"
 -				Optimization="0"
 -				AdditionalIncludeDirectories="lib\include;include"
 -				PreprocessorDefinitions="_DEBUG;DLL_EXPORTS"
 -				RuntimeLibrary="3"
 -				DebugInformationFormat="3"
 -			/>
 -			<Tool
 -				Name="VCManagedResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCResourceCompilerTool"
 -			/>
 -			<Tool
 -				Name="VCPreLinkEventTool"
 -			/>
 -			<Tool
 -				Name="VCLinkerTool"
 -				AdditionalDependencies=""
 -				OutputFile="bin\x64\Astra64D.dll"
 -				AdditionalLibraryDirectories="".\lib\x64""
 -				GenerateManifest="true"
 -				ModuleDefinitionFile=""
 -				GenerateDebugInformation="true"
 -				RandomizedBaseAddress="1"
 -				DataExecutionPrevention="0"
 -				TargetMachine="17"
 -			/>
 -			<Tool
 -				Name="VCALinkTool"
 -			/>
 -			<Tool
 -				Name="VCManifestTool"
 -			/>
 -			<Tool
 -				Name="VCXDCMakeTool"
 -			/>
 -			<Tool
 -				Name="VCBscMakeTool"
 -			/>
 -			<Tool
 -				Name="VCFxCopTool"
 -			/>
 -			<Tool
 -				Name="VCAppVerifierTool"
 -			/>
 -			<Tool
 -				Name="VCPostBuildEventTool"
 -			/>
 -		</Configuration>
 -	</Configurations>
 -	<References>
 -	</References>
 -	<Files>
 -		<Filter
 -			Name="Resource Files"
 -			Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav"
 -			UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}"
 -			>
 -			<File
 -				RelativePath=".\src\astra.def"
 -				>
 -			</File>
 -		</Filter>
 -		<Filter
 -			Name="Algorithms"
 -			>
 -			<Filter
 -				Name="Header Files"
 -				>
 -				<File
 -					RelativePath=".\include\astra\Algorithm.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\AlgorithmTypelist.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ArtAlgorithm.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\AsyncAlgorithm.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\BackProjectionAlgorithm.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\CglsAlgorithm.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\FilteredBackProjectionAlgorithm.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ForwardProjectionAlgorithm.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Fourier.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ReconstructionAlgorithm2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ReconstructionAlgorithm3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\SartAlgorithm.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\SirtAlgorithm.h"
 -					>
 -				</File>
 -			</Filter>
 -			<Filter
 -				Name="Source Files"
 -				>
 -				<File
 -					RelativePath=".\src\Algorithm.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ArtAlgorithm.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\AsyncAlgorithm.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\BackProjectionAlgorithm.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\CglsAlgorithm.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\FilteredBackProjectionAlgorithm.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ForwardProjectionAlgorithm.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Fourier.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ReconstructionAlgorithm2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ReconstructionAlgorithm3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\SartAlgorithm.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\SirtAlgorithm.cpp"
 -					>
 -				</File>
 -			</Filter>
 -		</Filter>
 -		<Filter
 -			Name="Projectors"
 -			>
 -			<Filter
 -				Name="Header Files"
 -				>
 -				<File
 -					RelativePath=".\include\astra\DataProjector.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\DataProjectorPolicies.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\FanFlatBeamLineKernelProjector2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\FanFlatBeamStripKernelProjector2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelBeamBlobKernelProjector2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelBeamLinearKernelProjector2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelBeamLineKernelProjector2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelBeamStripKernelProjector2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Projector2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Projector3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ProjectorTypelist.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\SparseMatrixProjector2D.h"
 -					>
 -				</File>
 -			</Filter>
 -			<Filter
 -				Name="Source Files"
 -				>
 -				<File
 -					RelativePath=".\src\DataProjector.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\DataProjectorPolicies.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\FanFlatBeamLineKernelProjector2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\FanFlatBeamStripKernelProjector2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ParallelBeamBlobKernelProjector2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ParallelBeamLinearKernelProjector2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ParallelBeamLineKernelProjector2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ParallelBeamStripKernelProjector2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Projector2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Projector3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\SparseMatrixProjector2D.cpp"
 -					>
 -				</File>
 -			</Filter>
 -			<Filter
 -				Name="Inline Files"
 -				>
 -				<File
 -					RelativePath=".\include\astra\DataProjectorPolicies.inl"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\FanFlatBeamLineKernelProjector2D.inl"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\FanFlatBeamStripKernelProjector2D.inl"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelBeamLinearKernelProjector2D.inl"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelBeamLineKernelProjector2D.inl"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelBeamStripKernelProjector2D.inl"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Projector2DImpl.inl"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\SparseMatrixProjector2D.inl"
 -					>
 -				</File>
 -			</Filter>
 -		</Filter>
 -		<Filter
 -			Name="Global & Other"
 -			>
 -			<Filter
 -				Name="Source Files"
 -				>
 -				<File
 -					RelativePath=".\src\AstraObjectFactory.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\AstraObjectManager.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Config.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Globals.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\GeometryUtil3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Logger.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\PlatformDepSystemCode.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Utilities.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\XMLDocument.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\XMLNode.cpp"
 -					>
 -				</File>
 -			</Filter>
 -			<Filter
 -				Name="Header Files"
 -				>
 -				<File
 -					RelativePath=".\include\astra\AstraObjectFactory.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\AstraObjectManager.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Config.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Globals.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\GeometryUtil2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\GeometryUtil3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Logger.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\PlatformDepSystemCode.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Singleton.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\TypeList.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\XMLDocument.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\XMLNode.h"
 -					>
 -				</File>
 -			</Filter>
 -		</Filter>
 -		<Filter
 -			Name="CUDA"
 -			>
 -			<Filter
 -				Name="CUDA source"
 -				>
 -				<File
 -					RelativePath=".\cuda\2d\algo.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\algo3d.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\arith.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\arith3d.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\astra.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\astra3d.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\cgls.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\cgls3d.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\cone_bp.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\cone_fp.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\darthelper.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\darthelper3d.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\em.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\fan_bp.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\fan_fp.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\fdk.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\fft.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\par3d_bp.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\par3d_fp.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\par_bp.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\par_fp.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\sart.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\sirt.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\sirt3d.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\util.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\util3d.cu"
 -					>
 -					<FileConfiguration
 -						Name="Release|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Release|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|Win32"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -					<FileConfiguration
 -						Name="Debug|x64"
 -						ExcludedFromBuild="true"
 -						>
 -						<Tool
 -							Name="CUDA Build Rule"
 -						/>
 -					</FileConfiguration>
 -				</File>
 -			</Filter>
 -			<Filter
 -				Name="headers"
 -				>
 -				<File
 -					RelativePath=".\cuda\2d\algo.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\algo3d.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\arith.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\arith3d.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\astra.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\astra3d.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\cgls.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\cgls3d.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\cone_bp.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\cone_fp.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\darthelper.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\darthelper3d.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\dims.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\dims3d.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\em.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\fan_bp.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\fan_fp.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\fbp_filters.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\fft.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\par3d_bp.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\par3d_fp.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\par_bp.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\par_fp.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\sart.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\sirt.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\sirt3d.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\2d\util.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\cuda\3d\util3d.h"
 -					>
 -				</File>
 -			</Filter>
 -			<Filter
 -				Name="astra code"
 -				>
 -				<Filter
 -					Name="headers"
 -					>
 -					<File
 -						RelativePath=".\include\astra\CudaBackProjectionAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaBackProjectionAlgorithm3D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaCglsAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaCglsAlgorithm3D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaDartMaskAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaDartMaskAlgorithm3D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaDartSmoothingAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaDartSmoothingAlgorithm3D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaEMAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaFDKAlgorithm3D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaFilteredBackProjectionAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaForwardProjectionAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaForwardProjectionAlgorithm3D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaProjector2D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaProjector3D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaReconstructionAlgorithm2D.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaSartAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaSirtAlgorithm.h"
 -						>
 -					</File>
 -					<File
 -						RelativePath=".\include\astra\CudaSirtAlgorithm3D.h"
 -						>
 -					</File>
 -				</Filter>
 -				<Filter
 -					Name="source"
 -					>
 -					<File
 -						RelativePath=".\src\CudaBackProjectionAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaBackProjectionAlgorithm3D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaCglsAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaCglsAlgorithm3D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaDartMaskAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaDartMaskAlgorithm3D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaDartSmoothingAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaDartSmoothingAlgorithm3D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaDataOperationAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaEMAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaFDKAlgorithm3D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaFilteredBackProjectionAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaForwardProjectionAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaForwardProjectionAlgorithm3D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaProjector2D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaProjector3D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaReconstructionAlgorithm2D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaRoiSelectAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaSartAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaSirtAlgorithm.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -					<File
 -						RelativePath=".\src\CudaSirtAlgorithm3D.cpp"
 -						>
 -						<FileConfiguration
 -							Name="Release|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Release|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|Win32"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -						<FileConfiguration
 -							Name="Debug|x64"
 -							ExcludedFromBuild="true"
 -							>
 -							<Tool
 -								Name="VCCLCompilerTool"
 -							/>
 -						</FileConfiguration>
 -					</File>
 -				</Filter>
 -			</Filter>
 -		</Filter>
 -		<Filter
 -			Name="Data & Geometry Objects"
 -			>
 -			<Filter
 -				Name="Header Files"
 -				>
 -				<File
 -					RelativePath=".\include\astra\ConeProjectionGeometry3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ConeVecProjectionGeometry3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\FanFlatProjectionGeometry2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\FanFlatVecProjectionGeometry2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32Data.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32Data2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32Data3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32Data3DMemory.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32ProjectionData2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32ProjectionData3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32ProjectionData3DMemory.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32VolumeData2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32VolumeData3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Float32VolumeData3DMemory.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelProjectionGeometry2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelProjectionGeometry3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ParallelVecProjectionGeometry3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ProjectionGeometry2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\ProjectionGeometry3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\SparseMatrix.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\SparseMatrixProjectionGeometry2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\Vector3D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\VolumeGeometry2D.h"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\include\astra\VolumeGeometry3D.h"
 -					>
 -				</File>
 -			</Filter>
 -			<Filter
 -				Name="Source Files"
 -				>
 -				<File
 -					RelativePath=".\src\ConeProjectionGeometry3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ConeVecProjectionGeometry3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\FanFlatProjectionGeometry2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\FanFlatVecProjectionGeometry2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32Data.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32Data2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32Data3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32Data3DMemory.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32ProjectionData2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32ProjectionData3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32ProjectionData3DMemory.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32VolumeData2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32VolumeData3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Float32VolumeData3DMemory.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ParallelProjectionGeometry2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ParallelProjectionGeometry3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ParallelVecProjectionGeometry3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ProjectionGeometry2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\ProjectionGeometry3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\SparseMatrix.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\SparseMatrixProjectionGeometry2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\Vector3D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\VolumeGeometry2D.cpp"
 -					>
 -				</File>
 -				<File
 -					RelativePath=".\src\VolumeGeometry3D.cpp"
 -					>
 -				</File>
 -			</Filter>
 -		</Filter>
 -	</Files>
 -	<Globals>
 -	</Globals>
 -</VisualStudioProject>
 +<?xml version="1.0" encoding="Windows-1252"?> +<VisualStudioProject +	ProjectType="Visual C++" +	Version="9.00" +	ProjectGUID="{12926444-6723-46A8-B388-12E65E0577FA}" +	RootNamespace="astra" +	TargetFrameworkVersion="131072" +	> +	<Platforms> +		<Platform +			Name="Win32" +		/> +		<Platform +			Name="x64" +		/> +	</Platforms> +	<ToolFiles> +		<DefaultToolFile +			FileName="NvCudaRuntimeApi.v5.5.rules" +		/> +	</ToolFiles> +	<Configurations> +		<Configuration +			Name="Debug_CUDA|Win32" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Debug_CUDA" +			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\include;include" +				PreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS;__SSE2__" +				Optimization="0" +				InlineFunctionExpansion="0" +				FavorSizeOrSpeed="0" +				EnableFiberSafeOptimizations="false" +				WholeProgramOptimization="false" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="cudart.lib cufft.lib" +				OutputFile="bin\Win32\AstraCuda32D.dll" +				AdditionalLibraryDirectories="".\lib\Win32";"$(CUDA_LIB_PATH)"" +				GenerateManifest="true" +				ModuleDefinitionFile="" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/> +			<Tool +				Name="Cudart Build Rule" +				Arch1="20" +				Arch2="30" +				Arch3="35" +				TargetMachinePlatform="0" +				Runtime="3" +				Defines="-DASTRA_CUDA -DDLL_EXPORTS" +			/> +		</Configuration> +		<Configuration +			Name="Debug_CUDA|x64" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Debug_CUDA" +			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\include;include" +				PreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS;__SSE2__" +				Optimization="0" +				InlineFunctionExpansion="0" +				FavorSizeOrSpeed="0" +				EnableFiberSafeOptimizations="false" +				WholeProgramOptimization="false" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="cudart.lib cufft.lib" +				OutputFile="bin\x64\AstraCuda64D.dll" +				AdditionalLibraryDirectories="".\lib\x64";"$(CUDA_LIB_PATH)"" +				GenerateManifest="true" +				ModuleDefinitionFile="" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/> +			<Tool +				Name="Cudart Build Rule" +				Arch1="20" +				Arch2="30" +				Arch3="35" +				TargetMachinePlatform="1" +				Runtime="3" +				Defines="-DASTRA_CUDA -DDLL_EXPORTS" +			/> +		</Configuration> +		<Configuration +			Name="Debug|Win32" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Debug" +			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="lib\include;include" +				PreprocessorDefinitions="DLL_EXPORTS;__SSE2__" +				Optimization="0" +				InlineFunctionExpansion="0" +				FavorSizeOrSpeed="0" +				EnableFiberSafeOptimizations="false" +				WholeProgramOptimization="false" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				OutputFile="bin\Win32\Astra32D.dll" +				AdditionalLibraryDirectories="".\lib\Win32"" +				GenerateManifest="true" +				ModuleDefinitionFile="" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/> +			<Tool +				Name="Cudart Build Rule" +				Arch1="20" +				Arch2="30" +				Arch3="35" +				TargetMachinePlatform="0" +				Runtime="3" +				Defines="-DDLL_EXPORTS" +			/> +		</Configuration> +		<Configuration +			Name="Debug|x64" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Debug" +			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="lib\include;include" +				PreprocessorDefinitions="DLL_EXPORTS;__SSE2__" +				Optimization="0" +				InlineFunctionExpansion="0" +				FavorSizeOrSpeed="0" +				EnableFiberSafeOptimizations="false" +				WholeProgramOptimization="false" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				OutputFile="bin\x64\Astra64D.dll" +				AdditionalLibraryDirectories="".\lib\x64"" +				GenerateManifest="true" +				ModuleDefinitionFile="" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/> +			<Tool +				Name="Cudart Build Rule" +				Arch1="20" +				Arch2="30" +				Arch3="35" +				TargetMachinePlatform="1" +				Runtime="3" +				Defines="-DDLL_EXPORTS" +			/> +		</Configuration> +		<Configuration +			Name="Release_CUDA|Win32" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Release_CUDA" +			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\include;include" +				PreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS;__SSE2__" +				Optimization="3" +				InlineFunctionExpansion="2" +				FavorSizeOrSpeed="1" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="cudart.lib cufft.lib" +				OutputFile="bin\Win32\AstraCuda32.dll" +				AdditionalLibraryDirectories="".\lib\Win32";"$(CUDA_LIB_PATH)"" +				GenerateManifest="true" +				ModuleDefinitionFile="" +				TargetMachine="1" +			/> +			<Tool +				Name="Cudart Build Rule" +				Arch1="20" +				Arch2="30" +				Arch3="35" +				TargetMachinePlatform="0" +				Runtime="2" +				Defines="-DASTRA_CUDA -DDLL_EXPORTS" +			/> +		</Configuration> +		<Configuration +			Name="Release_CUDA|x64" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Release_CUDA" +			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\include;include" +				PreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS;__SSE2__" +				Optimization="3" +				InlineFunctionExpansion="2" +				FavorSizeOrSpeed="1" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="cudart.lib cufft.lib" +				OutputFile="bin\x64\AstraCuda64.dll" +				AdditionalLibraryDirectories="".\lib\x64";"$(CUDA_LIB_PATH)"" +				GenerateManifest="true" +				ModuleDefinitionFile="" +				TargetMachine="17" +			/> +			<Tool +				Name="Cudart Build Rule" +				Arch1="20" +				Arch2="30" +				Arch3="35" +				TargetMachinePlatform="1" +				Runtime="2" +				Defines="-DASTRA_CUDA -DDLL_EXPORTS" +			/> +		</Configuration> +		<Configuration +			Name="Release|Win32" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Release" +			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="lib\include;include" +				PreprocessorDefinitions="DLL_EXPORTS;__SSE2__" +				Optimization="3" +				InlineFunctionExpansion="2" +				FavorSizeOrSpeed="1" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				OutputFile="bin\Win32\Astra32.dll" +				AdditionalLibraryDirectories="".\lib\Win32"" +				GenerateManifest="true" +				ModuleDefinitionFile="" +				TargetMachine="1" +			/> +			<Tool +				Name="Cudart Build Rule" +				Arch1="20" +				Arch2="30" +				Arch3="35" +				TargetMachinePlatform="0" +				Runtime="2" +				Defines="-DDLL_EXPORTS" +			/> +		</Configuration> +		<Configuration +			Name="Release|x64" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\Release" +			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="lib\include;include" +				PreprocessorDefinitions="DLL_EXPORTS;__SSE2__" +				Optimization="3" +				InlineFunctionExpansion="2" +				FavorSizeOrSpeed="1" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				OutputFile="bin\x64\Astra64.dll" +				AdditionalLibraryDirectories="".\lib\x64"" +				GenerateManifest="true" +				ModuleDefinitionFile="" +				TargetMachine="17" +			/> +			<Tool +				Name="Cudart Build Rule" +				Arch1="20" +				Arch2="30" +				Arch3="35" +				TargetMachinePlatform="1" +				Runtime="2" +				Defines="-DDLL_EXPORTS" +			/> +		</Configuration> +	</Configurations> +	<References> +	</References> +	<Files> +		<Filter +			Name="Resource Files" +			Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav" +			UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" +			> +			<File +				RelativePath=".\src\astra.def" +				> +			</File> +		</Filter> +		<Filter +			Name="Algorithms" +			> +			<Filter +				Name="headers" +				> +				<File +					RelativePath=".\include\astra\Algorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\AlgorithmTypelist.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ArtAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\AsyncAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\BackProjectionAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CglsAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaBackProjectionAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaBackProjectionAlgorithm3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\FilteredBackProjectionAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ForwardProjectionAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ReconstructionAlgorithm2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ReconstructionAlgorithm3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\SartAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\SirtAlgorithm.h" +					> +				</File> +			</Filter> +			<Filter +				Name="source" +				> +				<File +					RelativePath=".\src\Algorithm.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ArtAlgorithm.cpp" +					> +				</File> +				<File +					RelativePath=".\src\AsyncAlgorithm.cpp" +					> +				</File> +				<File +					RelativePath=".\src\BackProjectionAlgorithm.cpp" +					> +				</File> +				<File +					RelativePath=".\src\CglsAlgorithm.cpp" +					> +				</File> +				<File +					RelativePath=".\src\FilteredBackProjectionAlgorithm.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ForwardProjectionAlgorithm.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ReconstructionAlgorithm2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ReconstructionAlgorithm3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\SartAlgorithm.cpp" +					> +				</File> +				<File +					RelativePath=".\src\SirtAlgorithm.cpp" +					> +				</File> +			</Filter> +		</Filter> +		<Filter +			Name="Data Structures" +			> +			<Filter +				Name="headers" +				> +				<File +					RelativePath=".\include\astra\Float32Data.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32Data2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32Data3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32Data3DMemory.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32ProjectionData2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32ProjectionData3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32ProjectionData3DMemory.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32VolumeData2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32VolumeData3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Float32VolumeData3DMemory.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\SparseMatrix.h" +					> +				</File> +			</Filter> +			<Filter +				Name="source" +				> +				<File +					RelativePath=".\src\Float32Data.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32Data2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32Data3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32Data3DMemory.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32ProjectionData2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32ProjectionData3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32ProjectionData3DMemory.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32VolumeData2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32VolumeData3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Float32VolumeData3DMemory.cpp" +					> +				</File> +				<File +					RelativePath=".\src\SparseMatrix.cpp" +					> +				</File> +			</Filter> +		</Filter> +		<Filter +			Name="Global & Other" +			> +			<Filter +				Name="headers" +				> +				<File +					RelativePath=".\include\astra\AstraObjectFactory.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\AstraObjectManager.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\clog.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Config.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Fourier.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Globals.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Logging.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\PlatformDepSystemCode.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Singleton.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\TypeList.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Utilities.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Vector3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\XMLDocument.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\XMLNode.h" +					> +				</File> +			</Filter> +			<Filter +				Name="source" +				> +				<File +					RelativePath=".\src\AstraObjectFactory.cpp" +					> +				</File> +				<File +					RelativePath=".\src\AstraObjectManager.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Config.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Fourier.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Globals.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Logging.cpp" +					> +				</File> +				<File +					RelativePath=".\src\PlatformDepSystemCode.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Utilities.cpp" +					> +				</File> +				<File +					RelativePath=".\src\XMLDocument.cpp" +					> +				</File> +				<File +					RelativePath=".\src\XMLNode.cpp" +					> +				</File> +			</Filter> +		</Filter> +		<Filter +			Name="Geometries" +			> +			<Filter +				Name="headers" +				> +				<File +					RelativePath=".\include\astra\ConeProjectionGeometry3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ConeVecProjectionGeometry3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\FanFlatProjectionGeometry2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\FanFlatVecProjectionGeometry2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\GeometryUtil2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\GeometryUtil3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelProjectionGeometry2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelProjectionGeometry3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelVecProjectionGeometry3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ProjectionGeometry2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ProjectionGeometry3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\SparseMatrixProjectionGeometry2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\VolumeGeometry2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\VolumeGeometry3D.h" +					> +				</File> +			</Filter> +			<Filter +				Name="source" +				> +				<File +					RelativePath=".\src\ConeProjectionGeometry3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ConeVecProjectionGeometry3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\FanFlatProjectionGeometry2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\FanFlatVecProjectionGeometry2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\GeometryUtil3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ParallelProjectionGeometry2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ParallelProjectionGeometry3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ParallelVecProjectionGeometry3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ProjectionGeometry2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ProjectionGeometry3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\SparseMatrixProjectionGeometry2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\VolumeGeometry2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\VolumeGeometry3D.cpp" +					> +				</File> +			</Filter> +		</Filter> +		<Filter +			Name="Projectors" +			> +			<Filter +				Name="headers" +				> +				<File +					RelativePath=".\include\astra\DataProjector.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\DataProjectorPolicies.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\FanFlatBeamLineKernelProjector2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\FanFlatBeamStripKernelProjector2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelBeamBlobKernelProjector2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelBeamLinearKernelProjector2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelBeamLineKernelProjector2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelBeamStripKernelProjector2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Projector2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\Projector3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\ProjectorTypelist.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\SparseMatrixProjector2D.h" +					> +				</File> +			</Filter> +			<Filter +				Name="inline" +				> +				<File +					RelativePath=".\include\astra\DataProjectorPolicies.inl" +					> +				</File> +				<File +					RelativePath=".\include\astra\FanFlatBeamLineKernelProjector2D.inl" +					> +				</File> +				<File +					RelativePath=".\include\astra\FanFlatBeamStripKernelProjector2D.inl" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelBeamBlobKernelProjector2D.inl" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelBeamLinearKernelProjector2D.inl" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelBeamLineKernelProjector2D.inl" +					> +				</File> +				<File +					RelativePath=".\include\astra\ParallelBeamStripKernelProjector2D.inl" +					> +				</File> +				<File +					RelativePath=".\include\astra\SparseMatrixProjector2D.inl" +					> +				</File> +			</Filter> +			<Filter +				Name="source" +				> +				<File +					RelativePath=".\src\DataProjector.cpp" +					> +				</File> +				<File +					RelativePath=".\src\DataProjectorPolicies.cpp" +					> +				</File> +				<File +					RelativePath=".\src\FanFlatBeamLineKernelProjector2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\FanFlatBeamStripKernelProjector2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ParallelBeamBlobKernelProjector2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ParallelBeamLinearKernelProjector2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ParallelBeamLineKernelProjector2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\ParallelBeamStripKernelProjector2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Projector2D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\Projector3D.cpp" +					> +				</File> +				<File +					RelativePath=".\src\SparseMatrixProjector2D.cpp" +					> +				</File> +			</Filter> +		</Filter> +		<Filter +			Name="CUDA" +			> +			<Filter +				Name="astra headers" +				> +				<File +					RelativePath=".\include\astra\CudaCglsAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaCglsAlgorithm3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaDartMaskAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaDartMaskAlgorithm3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaDartSmoothingAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaDartSmoothingAlgorithm3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaDataOperationAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaEMAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaFDKAlgorithm3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaFilteredBackProjectionAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaForwardProjectionAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaForwardProjectionAlgorithm3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaProjector2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaProjector3D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaReconstructionAlgorithm2D.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaRoiSelectAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaSartAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaSirtAlgorithm.h" +					> +				</File> +				<File +					RelativePath=".\include\astra\CudaSirtAlgorithm3D.h" +					> +				</File> +			</Filter> +			<Filter +				Name="astra source" +				> +				<File +					RelativePath=".\src\CudaBackProjectionAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaBackProjectionAlgorithm3D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaCglsAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaCglsAlgorithm3D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaDartMaskAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaDartMaskAlgorithm3D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaDartSmoothingAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaDartSmoothingAlgorithm3D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaDataOperationAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaEMAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaFDKAlgorithm3D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaFilteredBackProjectionAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaForwardProjectionAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaForwardProjectionAlgorithm3D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaProjector2D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaProjector3D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaReconstructionAlgorithm2D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaRoiSelectAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaSartAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaSirtAlgorithm.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\src\CudaSirtAlgorithm3D.cpp" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="VCCLCompilerTool" +						/> +					</FileConfiguration> +				</File> +			</Filter> +			<Filter +				Name="cuda headers" +				> +				<File +					RelativePath=".\cuda\2d\algo.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\arith.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\astra.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\cgls.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\darthelper.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\dims.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\em.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\fan_bp.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\fan_fp.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\fbp_filters.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\fft.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\par_bp.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\par_fp.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\sart.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\sirt.h" +					> +				</File> +				<File +					RelativePath=".\cuda\2d\util.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\algo3d.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\arith3d.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\astra3d.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\cgls3d.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\cone_bp.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\cone_fp.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\darthelper3d.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\dims3d.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\fdk.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\par3d_bp.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\par3d_fp.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\sirt3d.h" +					> +				</File> +				<File +					RelativePath=".\cuda\3d\util3d.h" +					> +				</File> +			</Filter> +			<Filter +				Name="cuda source" +				> +				<File +					RelativePath=".\cuda\2d\algo.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\arith.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\astra.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\cgls.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\darthelper.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\em.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\fan_bp.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\fan_fp.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\fft.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\par_bp.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\par_fp.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\sart.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\sirt.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\2d\util.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\algo3d.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\arith3d.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\astra3d.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\cgls3d.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\cone_bp.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\cone_fp.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\darthelper3d.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\fdk.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\par3d_bp.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\par3d_fp.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\sirt3d.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +				<File +					RelativePath=".\cuda\3d\util3d.cu" +					> +					<FileConfiguration +						Name="Debug|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Debug|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|Win32" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +					<FileConfiguration +						Name="Release|x64" +						ExcludedFromBuild="true" +						> +						<Tool +							Name="Cudart Build Rule" +						/> +					</FileConfiguration> +				</File> +			</Filter> +		</Filter> +	</Files> +	<Globals> +	</Globals> +</VisualStudioProject> diff --git a/astra_vc11.sln b/astra_vc11.sln index 784fe7a..2832eab 100644 --- a/astra_vc11.sln +++ b/astra_vc11.sln @@ -4,20 +4,49 @@ Microsoft Visual Studio Solution File, Format Version 12.00  Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_vc11", "astra_vc11.vcxproj", "{BE9F1326-527C-4284-AE2C-D1E25D539CEA}"  EndProject  Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "astra_mex", "astra_mex", "{5E99A109-374E-4102-BE9B-99BA1FA8AA30}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection  EndProject  Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex", "matlab\mex\astra_mex_vc11.vcxproj", "{3FDA35E0-0D54-4663-A3E6-5ABA96F32221}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection  EndProject  Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_algorithm", "matlab\mex\astra_mex_algorithm_vc11.vcxproj", "{056BF7A9-294D-487C-8CC3-BE629077CA94}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection  EndProject  Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_data2d", "matlab\mex\astra_mex_data2d_vc11.vcxproj", "{E4092269-B19C-46F7-A84E-4F146CC70E44}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection  EndProject  Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_data3d", "matlab\mex\astra_mex_data3d_vc11.vcxproj", "{0BEC029B-0929-4BF9-BD8B-9C9806A52065}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection  EndProject  Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_matrix", "matlab\mex\astra_mex_matrix_vc11.vcxproj", "{9D041710-2119-4230-BCF2-5FBE753FDE49}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection  EndProject  Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_projector", "matlab\mex\astra_mex_projector_vc11.vcxproj", "{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection  EndProject  Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_projector3d", "matlab\mex\astra_mex_projector3d_vc11.vcxproj", "{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "astra_mex_log", "matlab\mex\astra_mex_log_vc11.vcxproj", "{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}" +	ProjectSection(ProjectDependencies) = postProject +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA} = {BE9F1326-527C-4284-AE2C-D1E25D539CEA} +	EndProjectSection  EndProject  Global  	GlobalSection(SolutionConfigurationPlatforms) = preSolution @@ -31,10 +60,10 @@ Global  		Release|x64 = Release|x64  	EndGlobalSection  	GlobalSection(ProjectConfigurationPlatforms) = postSolution -		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug_CUDA|Win32.ActiveCfg = Debug|Win32 -		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug_CUDA|Win32.Build.0 = Debug|Win32 -		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug_CUDA|x64.ActiveCfg = Debug|x64 -		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug_CUDA|x64.Build.0 = Debug|x64 +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64  		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug|Win32.ActiveCfg = Debug|Win32  		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug|Win32.Build.0 = Debug|Win32  		{BE9F1326-527C-4284-AE2C-D1E25D539CEA}.Debug|x64.ActiveCfg = Debug|x64 @@ -159,6 +188,22 @@ Global  		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|Win32.Build.0 = Release|Win32  		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|x64.ActiveCfg = Release|x64  		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883}.Release|x64.Build.0 = Release|x64 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Debug_CUDA|Win32.ActiveCfg = Debug_CUDA|Win32 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Debug_CUDA|Win32.Build.0 = Debug_CUDA|Win32 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Debug_CUDA|x64.ActiveCfg = Debug_CUDA|x64 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Debug_CUDA|x64.Build.0 = Debug_CUDA|x64 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Debug|Win32.ActiveCfg = Debug|Win32 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Debug|Win32.Build.0 = Debug|Win32 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Debug|x64.ActiveCfg = Debug|x64 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Debug|x64.Build.0 = Debug|x64 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Release_CUDA|Win32.ActiveCfg = Release_CUDA|Win32 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Release_CUDA|Win32.Build.0 = Release_CUDA|Win32 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Release_CUDA|x64.ActiveCfg = Release_CUDA|x64 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Release_CUDA|x64.Build.0 = Release_CUDA|x64 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Release|Win32.ActiveCfg = Release|Win32 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Release|Win32.Build.0 = Release|Win32 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Release|x64.ActiveCfg = Release|x64 +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}.Release|x64.Build.0 = Release|x64  	EndGlobalSection  	GlobalSection(SolutionProperties) = preSolution  		HideSolutionNode = FALSE @@ -171,5 +216,6 @@ Global  		{9D041710-2119-4230-BCF2-5FBE753FDE49} = {5E99A109-374E-4102-BE9B-99BA1FA8AA30}  		{4DD6056F-8EEE-4C9A-B2A9-923F01A32E97} = {5E99A109-374E-4102-BE9B-99BA1FA8AA30}  		{F94CCD79-AA11-42DF-AC8A-6C9D2238A883} = {5E99A109-374E-4102-BE9B-99BA1FA8AA30} +		{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E} = {5E99A109-374E-4102-BE9B-99BA1FA8AA30}  	EndGlobalSection  EndGlobal diff --git a/astra_vc11.vcxproj b/astra_vc11.vcxproj index 91b216e..c8d0ec3 100644 --- a/astra_vc11.vcxproj +++ b/astra_vc11.vcxproj @@ -1,6 +1,14 @@  <?xml version="1.0" encoding="utf-8"?>  <Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">    <ItemGroup Label="ProjectConfigurations"> +    <ProjectConfiguration Include="Debug_CUDA|Win32"> +      <Configuration>Debug_CUDA</Configuration> +      <Platform>Win32</Platform> +    </ProjectConfiguration> +    <ProjectConfiguration Include="Debug_CUDA|x64"> +      <Configuration>Debug_CUDA</Configuration> +      <Platform>x64</Platform> +    </ProjectConfiguration>      <ProjectConfiguration Include="Debug|Win32">        <Configuration>Debug</Configuration>        <Platform>Win32</Platform> @@ -31,40 +39,52 @@      <RootNamespace>astra_vc11</RootNamespace>    </PropertyGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <UseDebugLibraries>true</UseDebugLibraries> +    <PlatformToolset>v110</PlatformToolset> +    <CharacterSet>MultiByte</CharacterSet> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <UseDebugLibraries>true</UseDebugLibraries> +    <PlatformToolset>v110</PlatformToolset> +    <CharacterSet>MultiByte</CharacterSet> +  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> -    <ConfigurationType>Application</ConfigurationType> +    <ConfigurationType>DynamicLibrary</ConfigurationType>      <UseDebugLibraries>true</UseDebugLibraries>      <PlatformToolset>v110</PlatformToolset>      <CharacterSet>MultiByte</CharacterSet>    </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration"> -    <ConfigurationType>Application</ConfigurationType> +    <ConfigurationType>DynamicLibrary</ConfigurationType>      <UseDebugLibraries>true</UseDebugLibraries>      <PlatformToolset>v110</PlatformToolset>      <CharacterSet>MultiByte</CharacterSet>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> -    <ConfigurationType>Application</ConfigurationType> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType>      <UseDebugLibraries>false</UseDebugLibraries>      <PlatformToolset>v110</PlatformToolset>      <WholeProgramOptimization>true</WholeProgramOptimization>      <CharacterSet>MultiByte</CharacterSet>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> -    <ConfigurationType>Application</ConfigurationType> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType>      <UseDebugLibraries>false</UseDebugLibraries>      <PlatformToolset>v110</PlatformToolset>      <WholeProgramOptimization>true</WholeProgramOptimization>      <CharacterSet>MultiByte</CharacterSet>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <UseDebugLibraries>false</UseDebugLibraries>      <PlatformToolset>v110</PlatformToolset>      <WholeProgramOptimization>true</WholeProgramOptimization>      <CharacterSet>MultiByte</CharacterSet>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <UseDebugLibraries>false</UseDebugLibraries>      <PlatformToolset>v110</PlatformToolset> @@ -75,133 +95,282 @@    <ImportGroup Label="ExtensionSettings">      <Import Project="$(VCTargetsPath)\BuildCustomizations\CUDA 5.5.props" />    </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup>    <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup>    <PropertyGroup Label="UserMacros" /> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +    <IncludePath>$(CUDA_INC_PATH);$(IncludePath)</IncludePath> +    <LibraryPath>$(CUDA_LIB_PATH);$(LibraryPath)</LibraryPath> +    <OutDir>$(SolutionDir)bin\$(Platform)\Debug_CUDA\</OutDir> +    <IntDir>$(OutDir)obj\</IntDir> +    <TargetExt>.dll</TargetExt> +    <TargetName>AstraCuda32D</TargetName> +    <GenerateManifest>true</GenerateManifest> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +    <IncludePath>$(CUDA_INC_PATH);$(IncludePath)</IncludePath> +    <LibraryPath>$(CUDA_LIB_PATH);$(LibraryPath)</LibraryPath> +    <OutDir>$(SolutionDir)bin\$(Platform)\Debug_CUDA\</OutDir> +    <IntDir>$(OutDir)obj\</IntDir> +    <TargetExt>.dll</TargetExt> +    <TargetName>AstraCuda64D</TargetName> +    <GenerateManifest>true</GenerateManifest> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\Debug\</OutDir> +    <IntDir>$(OutDir)obj\</IntDir> +    <TargetExt>.dll</TargetExt> +    <TargetName>Astra32D</TargetName> +    <GenerateManifest>true</GenerateManifest> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\Debug\</OutDir> +    <IntDir>$(OutDir)obj\</IntDir> +    <TargetExt>.dll</TargetExt> +    <TargetName>Astra64D</TargetName> +    <GenerateManifest>true</GenerateManifest> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <IncludePath>$(CUDA_INC_PATH);$(IncludePath)</IncludePath>      <LibraryPath>$(CUDA_LIB_PATH);$(LibraryPath)</LibraryPath>      <OutDir>$(SolutionDir)bin\$(Platform)\Release_CUDA\</OutDir>      <IntDir>$(OutDir)obj\</IntDir>      <TargetExt>.dll</TargetExt> +    <TargetName>AstraCuda32</TargetName> +    <GenerateManifest>true</GenerateManifest>    </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <IncludePath>$(CUDA_INC_PATH);$(IncludePath)</IncludePath>      <LibraryPath>$(CUDA_LIB_PATH);$(LibraryPath)</LibraryPath>      <OutDir>$(SolutionDir)bin\$(Platform)\Release_CUDA\</OutDir> -    <IntDir>$(OutDir)\obj\</IntDir> +    <IntDir>$(OutDir)obj\</IntDir>      <TargetExt>.dll</TargetExt> -    <GenerateManifest>false</GenerateManifest>      <TargetName>AstraCuda64</TargetName> +    <GenerateManifest>true</GenerateManifest> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\Release\</OutDir> +    <IntDir>$(OutDir)obj\</IntDir> +    <TargetExt>.dll</TargetExt> +    <TargetName>Astra32</TargetName> +    <GenerateManifest>true</GenerateManifest>    </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\Release\</OutDir> +    <IntDir>$(OutDir)obj\</IntDir> +    <TargetExt>.dll</TargetExt> +    <TargetName>Astra64</TargetName> +    <GenerateManifest>true</GenerateManifest> +  </PropertyGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <WarningLevel>Level3</WarningLevel> +      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +      <SDLCheck>true</SDLCheck> +    </ClCompile> +    <Link> +      <GenerateDebugInformation>true</GenerateDebugInformation> +      <OutputFile>bin\Win32\Debug_CUDA\AstraCuda32D.dll</OutputFile> +      <AdditionalDependencies>cudart.lib;cufft.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>lib\win32;%(AdditionalLibraryDirectories);$(CudaToolkitLibDir)</AdditionalLibraryDirectories> +    </Link> +    <CudaCompile> +      <TargetMachinePlatform>32</TargetMachinePlatform> +      <GenerateLineInfo>true</GenerateLineInfo> +      <CodeGeneration>compute_20,sm_20;compute_30,sm_30;compute_30,sm_35;compute_30,compute_30</CodeGeneration> +    </CudaCompile> +  </ItemDefinitionGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <WarningLevel>Level3</WarningLevel> +      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +      <SDLCheck>true</SDLCheck> +    </ClCompile> +    <Link> +      <GenerateDebugInformation>true</GenerateDebugInformation> +      <OutputFile>bin\x64\Debug_CUDA\AstraCuda64D.dll</OutputFile> +      <AdditionalDependencies>cudart.lib;cufft.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>lib\x64;%(AdditionalLibraryDirectories);$(CudaToolkitLibDir)</AdditionalLibraryDirectories> +    </Link> +    <CudaCompile> +      <TargetMachinePlatform>64</TargetMachinePlatform> +      <GenerateLineInfo>true</GenerateLineInfo> +      <CodeGeneration>compute_20,sm_20;compute_30,sm_30;compute_30,sm_35;compute_30,compute_30</CodeGeneration> +    </CudaCompile> +  </ItemDefinitionGroup>    <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <ClCompile> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>        <WarningLevel>Level3</WarningLevel> +      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet>        <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>        <SDLCheck>true</SDLCheck>      </ClCompile>      <Link>        <GenerateDebugInformation>true</GenerateDebugInformation> +      <OutputFile>bin\Win32\Debug\Astra32D.dll</OutputFile> +      <AdditionalLibraryDirectories>lib\win32;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>      </Link>    </ItemDefinitionGroup>    <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <ClCompile> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>        <WarningLevel>Level3</WarningLevel> +      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport>        <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>        <SDLCheck>true</SDLCheck>      </ClCompile>      <Link>        <GenerateDebugInformation>true</GenerateDebugInformation> +      <OutputFile>bin\x64\Debug\Astra64D.dll</OutputFile> +      <AdditionalLibraryDirectories>lib\x64;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <ClCompile> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>        <WarningLevel>Level3</WarningLevel> +      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet>        <Optimization>MaxSpeed</Optimization>        <FunctionLevelLinking>true</FunctionLevelLinking>        <IntrinsicFunctions>true</IntrinsicFunctions> +      <InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion> +      <FavorSizeOrSpeed>Speed</FavorSizeOrSpeed> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>        <SDLCheck>true</SDLCheck>      </ClCompile>      <Link>        <GenerateDebugInformation>true</GenerateDebugInformation>        <EnableCOMDATFolding>true</EnableCOMDATFolding>        <OptimizeReferences>true</OptimizeReferences> +      <OutputFile>bin\Win32\Release_CUDA\AstraCuda32.dll</OutputFile> +      <AdditionalDependencies>cudart.lib;cufft.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>lib\win32;%(AdditionalLibraryDirectories);$(CudaToolkitLibDir)</AdditionalLibraryDirectories>      </Link> +    <CudaCompile> +      <TargetMachinePlatform>32</TargetMachinePlatform> +      <GenerateLineInfo>true</GenerateLineInfo> +      <CodeGeneration>compute_20,sm_20;compute_30,sm_30;compute_30,sm_35;compute_30,compute_30</CodeGeneration> +    </CudaCompile>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <ClCompile> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>        <WarningLevel>Level3</WarningLevel> +      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport>        <Optimization>MaxSpeed</Optimization>        <FunctionLevelLinking>true</FunctionLevelLinking>        <IntrinsicFunctions>true</IntrinsicFunctions> +      <InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion> +      <FavorSizeOrSpeed>Speed</FavorSizeOrSpeed> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>        <SDLCheck>true</SDLCheck>      </ClCompile>      <Link>        <GenerateDebugInformation>true</GenerateDebugInformation>        <EnableCOMDATFolding>true</EnableCOMDATFolding>        <OptimizeReferences>true</OptimizeReferences> +      <OutputFile>bin\x64\Release_CUDA\AstraCuda64.dll</OutputFile> +      <AdditionalDependencies>cudart.lib;cufft.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>lib\x64;%(AdditionalLibraryDirectories);$(CudaToolkitLibDir)</AdditionalLibraryDirectories>      </Link> +    <CudaCompile> +      <TargetMachinePlatform>64</TargetMachinePlatform> +      <GenerateLineInfo>true</GenerateLineInfo> +      <CodeGeneration>compute_20,sm_20;compute_30,sm_30;compute_30,sm_35;compute_30,compute_30</CodeGeneration> +    </CudaCompile>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <ClCompile> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>        <WarningLevel>Level3</WarningLevel> +      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet>        <Optimization>MaxSpeed</Optimization>        <FunctionLevelLinking>true</FunctionLevelLinking>        <IntrinsicFunctions>true</IntrinsicFunctions> +      <InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion> +      <FavorSizeOrSpeed>Speed</FavorSizeOrSpeed> +      <PreprocessorDefinitions>__SSE2__;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>        <SDLCheck>true</SDLCheck>      </ClCompile>      <Link>        <GenerateDebugInformation>true</GenerateDebugInformation>        <EnableCOMDATFolding>true</EnableCOMDATFolding>        <OptimizeReferences>true</OptimizeReferences> +      <OutputFile>bin\Win32\Release\Astra32.dll</OutputFile> +      <AdditionalLibraryDirectories>lib\win32;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>      </Link> -    <CudaCompile> -      <TargetMachinePlatform>64</TargetMachinePlatform> -    </CudaCompile>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <ClCompile> -      <WarningLevel>Level1</WarningLevel> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <WarningLevel>Level3</WarningLevel> +      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport>        <Optimization>MaxSpeed</Optimization>        <FunctionLevelLinking>true</FunctionLevelLinking>        <IntrinsicFunctions>true</IntrinsicFunctions> -      <SDLCheck>true</SDLCheck> -      <AdditionalIncludeDirectories>lib\include;lib\include\cuda;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <MultiProcessorCompilation>true</MultiProcessorCompilation>        <InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion>        <FavorSizeOrSpeed>Speed</FavorSizeOrSpeed> -      <PreprocessorDefinitions>ASTRA_CUDA;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <PreprocessorDefinitions>__SSE2__;DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +      <SDLCheck>true</SDLCheck>      </ClCompile>      <Link>        <GenerateDebugInformation>true</GenerateDebugInformation>        <EnableCOMDATFolding>true</EnableCOMDATFolding>        <OptimizeReferences>true</OptimizeReferences> -      <OutputFile>bin\x64\Release_CUDA\AstraCuda64.dll</OutputFile> -      <AdditionalLibraryDirectories>lib\x64;$(CUDA_LIB_PATH);$(NVSDKCUDA_ROOT)\common\lib;$(NVSDKCOMPUTE_ROOT)/C/common/lib;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> -      <AdditionalDependencies>cudart.lib;cufft.lib;%(AdditionalDependencies)</AdditionalDependencies> -      <IgnoreAllDefaultLibraries>false</IgnoreAllDefaultLibraries> +      <OutputFile>bin\x64\Release\Astra64.dll</OutputFile> +      <AdditionalLibraryDirectories>lib\x64;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>      </Link> -    <CudaCompile> -      <TargetMachinePlatform>64</TargetMachinePlatform> -      <GenerateLineInfo>true</GenerateLineInfo> -      <CodeGeneration>compute_20,sm_20</CodeGeneration> -    </CudaCompile>    </ItemDefinitionGroup>    <ItemGroup>      <ClCompile Include="src\Algorithm.cpp" /> @@ -214,27 +383,132 @@      <ClCompile Include="src\ConeProjectionGeometry3D.cpp" />      <ClCompile Include="src\ConeVecProjectionGeometry3D.cpp" />      <ClCompile Include="src\Config.cpp" /> -    <ClCompile Include="src\CudaBackProjectionAlgorithm.cpp" /> -    <ClCompile Include="src\CudaBackProjectionAlgorithm3D.cpp" /> -    <ClCompile Include="src\CudaCglsAlgorithm.cpp" /> -    <ClCompile Include="src\CudaCglsAlgorithm3D.cpp" /> -    <ClCompile Include="src\CudaDartMaskAlgorithm.cpp" /> -    <ClCompile Include="src\CudaDartMaskAlgorithm3D.cpp" /> -    <ClCompile Include="src\CudaDartSmoothingAlgorithm.cpp" /> -    <ClCompile Include="src\CudaDartSmoothingAlgorithm3D.cpp" /> -    <ClCompile Include="src\CudaDataOperationAlgorithm.cpp" /> -    <ClCompile Include="src\CudaEMAlgorithm.cpp" /> -    <ClCompile Include="src\CudaFDKAlgorithm3D.cpp" /> -    <ClCompile Include="src\CudaFilteredBackProjectionAlgorithm.cpp" /> -    <ClCompile Include="src\CudaForwardProjectionAlgorithm.cpp" /> -    <ClCompile Include="src\CudaForwardProjectionAlgorithm3D.cpp" /> -    <ClCompile Include="src\CudaProjector2D.cpp" /> -    <ClCompile Include="src\CudaProjector3D.cpp" /> -    <ClCompile Include="src\CudaReconstructionAlgorithm2D.cpp" /> -    <ClCompile Include="src\CudaRoiSelectAlgorithm.cpp" /> -    <ClCompile Include="src\CudaSartAlgorithm.cpp" /> -    <ClCompile Include="src\CudaSirtAlgorithm.cpp" /> -    <ClCompile Include="src\CudaSirtAlgorithm3D.cpp" /> +    <ClCompile Include="src\CudaBackProjectionAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaBackProjectionAlgorithm3D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaCglsAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaCglsAlgorithm3D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaDartMaskAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaDartMaskAlgorithm3D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaDartSmoothingAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaDartSmoothingAlgorithm3D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaDataOperationAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaEMAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaFDKAlgorithm3D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaFilteredBackProjectionAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaForwardProjectionAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaForwardProjectionAlgorithm3D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaProjector2D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaProjector3D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaReconstructionAlgorithm2D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaRoiSelectAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaSartAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaSirtAlgorithm.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile> +    <ClCompile Include="src\CudaSirtAlgorithm3D.cpp"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </ClCompile>      <ClCompile Include="src\DataProjector.cpp" />      <ClCompile Include="src\DataProjectorPolicies.cpp" />      <ClCompile Include="src\FanFlatBeamLineKernelProjector2D.cpp" /> @@ -254,12 +528,12 @@      <ClCompile Include="src\Float32VolumeData3DMemory.cpp" />      <ClCompile Include="src\ForwardProjectionAlgorithm.cpp" />      <ClCompile Include="src\Fourier.cpp" /> -    <ClCompile Include="src\Globals.cpp" />      <ClCompile Include="src\GeometryUtil3D.cpp" /> -    <ClCompile Include="src\Logger.cpp" /> +    <ClCompile Include="src\Globals.cpp" /> +    <ClCompile Include="src\Logging.cpp" />      <ClCompile Include="src\ParallelBeamBlobKernelProjector2D.cpp" /> -    <ClCompile Include="src\ParallelBeamLinearKernelProjector2D.cpp" />      <ClCompile Include="src\ParallelBeamLineKernelProjector2D.cpp" /> +    <ClCompile Include="src\ParallelBeamLinearKernelProjector2D.cpp" />      <ClCompile Include="src\ParallelBeamStripKernelProjector2D.cpp" />      <ClCompile Include="src\ParallelProjectionGeometry2D.cpp" />      <ClCompile Include="src\ParallelProjectionGeometry3D.cpp" /> @@ -345,7 +619,6 @@      <ClInclude Include="include\astra\CudaSartAlgorithm.h" />      <ClInclude Include="include\astra\CudaSirtAlgorithm.h" />      <ClInclude Include="include\astra\CudaSirtAlgorithm3D.h" /> -    <ClInclude Include="include\astra\DartAlgorithm.h" />      <ClInclude Include="include\astra\DataProjector.h" />      <ClInclude Include="include\astra\DataProjectorPolicies.h" />      <ClInclude Include="include\astra\FanFlatBeamLineKernelProjector2D.h" /> @@ -365,13 +638,13 @@      <ClInclude Include="include\astra\Float32VolumeData3DMemory.h" />      <ClInclude Include="include\astra\ForwardProjectionAlgorithm.h" />      <ClInclude Include="include\astra\Fourier.h" /> -    <ClInclude Include="include\astra\Globals.h" />      <ClInclude Include="include\astra\GeometryUtil2D.h" />      <ClInclude Include="include\astra\GeometryUtil3D.h" /> -    <ClInclude Include="include\astra\Logger.h" /> +    <ClInclude Include="include\astra\Globals.h" /> +    <ClInclude Include="include\astra\Logging.h" />      <ClInclude Include="include\astra\ParallelBeamBlobKernelProjector2D.h" /> -    <ClInclude Include="include\astra\ParallelBeamLinearKernelProjector2D.h" />      <ClInclude Include="include\astra\ParallelBeamLineKernelProjector2D.h" /> +    <ClInclude Include="include\astra\ParallelBeamLinearKernelProjector2D.h" />      <ClInclude Include="include\astra\ParallelBeamStripKernelProjector2D.h" />      <ClInclude Include="include\astra\ParallelProjectionGeometry2D.h" />      <ClInclude Include="include\astra\ParallelProjectionGeometry3D.h" /> @@ -392,47 +665,179 @@      <ClInclude Include="include\astra\SparseMatrixProjectionGeometry2D.h" />      <ClInclude Include="include\astra\SparseMatrixProjector2D.h" />      <ClInclude Include="include\astra\TypeList.h" /> +    <ClInclude Include="include\astra\Utilities.h" />      <ClInclude Include="include\astra\Vector3D.h" />      <ClInclude Include="include\astra\VolumeGeometry2D.h" />      <ClInclude Include="include\astra\VolumeGeometry3D.h" />      <ClInclude Include="include\astra\XMLDocument.h" />      <ClInclude Include="include\astra\XMLNode.h" /> +    <ClInclude Include="include\astra\clog.h" />    </ItemGroup>    <ItemGroup> -    <CudaCompile Include="cuda\2d\algo.cu" /> -    <CudaCompile Include="cuda\2d\arith.cu" /> -    <CudaCompile Include="cuda\2d\astra.cu" /> -    <CudaCompile Include="cuda\2d\cgls.cu" /> -    <CudaCompile Include="cuda\2d\darthelper.cu" /> -    <CudaCompile Include="cuda\2d\em.cu" /> -    <CudaCompile Include="cuda\2d\fan_bp.cu" /> -    <CudaCompile Include="cuda\2d\fan_fp.cu" /> -    <CudaCompile Include="cuda\2d\fft.cu" /> -    <CudaCompile Include="cuda\2d\par_bp.cu" /> -    <CudaCompile Include="cuda\2d\par_fp.cu" /> -    <CudaCompile Include="cuda\2d\sart.cu" /> -    <CudaCompile Include="cuda\2d\sirt.cu" /> -    <CudaCompile Include="cuda\2d\util.cu" /> -    <CudaCompile Include="cuda\3d\algo3d.cu" /> -    <CudaCompile Include="cuda\3d\arith3d.cu" /> -    <CudaCompile Include="cuda\3d\astra3d.cu" /> -    <CudaCompile Include="cuda\3d\cgls3d.cu" /> -    <CudaCompile Include="cuda\3d\cone_bp.cu" /> -    <CudaCompile Include="cuda\3d\cone_fp.cu" /> -    <CudaCompile Include="cuda\3d\darthelper3d.cu" /> -    <CudaCompile Include="cuda\3d\fdk.cu" /> -    <CudaCompile Include="cuda\3d\par3d_bp.cu" /> -    <CudaCompile Include="cuda\3d\par3d_fp.cu" /> -    <CudaCompile Include="cuda\3d\sirt3d.cu" /> -    <CudaCompile Include="cuda\3d\util3d.cu" /> +    <CudaCompile Include="cuda\2d\algo.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\arith.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\astra.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\cgls.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\darthelper.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\em.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\fan_bp.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\fan_fp.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\fft.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\par_bp.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\par_fp.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\sart.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\sirt.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\2d\util.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\algo3d.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\arith3d.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\astra3d.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\cgls3d.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\cone_bp.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\cone_fp.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\darthelper3d.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\fdk.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\par3d_bp.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\par3d_fp.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\sirt3d.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile> +    <CudaCompile Include="cuda\3d\util3d.cu"> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</ExcludedFromBuild> +      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> +    </CudaCompile>    </ItemGroup>    <ItemGroup>      <None Include="include\astra\DataProjectorPolicies.inl" />      <None Include="include\astra\FanFlatBeamLineKernelProjector2D.inl" />      <None Include="include\astra\FanFlatBeamStripKernelProjector2D.inl" />      <None Include="include\astra\ParallelBeamBlobKernelProjector2D.inl" /> -    <None Include="include\astra\ParallelBeamLinearKernelProjector2D.inl" />      <None Include="include\astra\ParallelBeamLineKernelProjector2D.inl" /> +    <None Include="include\astra\ParallelBeamLinearKernelProjector2D.inl" />      <None Include="include\astra\ParallelBeamStripKernelProjector2D.inl" />      <None Include="include\astra\SparseMatrixProjector2D.inl" />    </ItemGroup> diff --git a/astra_vc11.vcxproj.filters b/astra_vc11.vcxproj.filters index 0453ec7..d0e7254 100644 --- a/astra_vc11.vcxproj.filters +++ b/astra_vc11.vcxproj.filters @@ -4,76 +4,76 @@      <CudaCompile Include="cuda\2d\algo.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\algo3d.cu"> +    <CudaCompile Include="cuda\2d\arith.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\arith.cu"> +    <CudaCompile Include="cuda\2d\astra.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\arith3d.cu"> +    <CudaCompile Include="cuda\2d\cgls.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\astra.cu"> +    <CudaCompile Include="cuda\2d\darthelper.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\astra3d.cu"> +    <CudaCompile Include="cuda\2d\em.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\cgls.cu"> +    <CudaCompile Include="cuda\2d\fan_bp.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\cgls3d.cu"> +    <CudaCompile Include="cuda\2d\fan_fp.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\cone_bp.cu"> +    <CudaCompile Include="cuda\2d\fft.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\cone_fp.cu"> +    <CudaCompile Include="cuda\2d\par_bp.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\darthelper.cu"> +    <CudaCompile Include="cuda\2d\par_fp.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\darthelper3d.cu"> +    <CudaCompile Include="cuda\2d\sart.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\em.cu"> +    <CudaCompile Include="cuda\2d\sirt.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\fan_bp.cu"> +    <CudaCompile Include="cuda\2d\util.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\fan_fp.cu"> +    <CudaCompile Include="cuda\3d\algo3d.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\fdk.cu"> +    <CudaCompile Include="cuda\3d\arith3d.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\fft.cu"> +    <CudaCompile Include="cuda\3d\astra3d.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\par3d_bp.cu"> +    <CudaCompile Include="cuda\3d\cgls3d.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\par3d_fp.cu"> +    <CudaCompile Include="cuda\3d\cone_bp.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\par_bp.cu"> +    <CudaCompile Include="cuda\3d\cone_fp.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\par_fp.cu"> +    <CudaCompile Include="cuda\3d\darthelper3d.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\sart.cu"> +    <CudaCompile Include="cuda\3d\fdk.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\sirt.cu"> +    <CudaCompile Include="cuda\3d\par3d_bp.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\3d\sirt3d.cu"> +    <CudaCompile Include="cuda\3d\par3d_fp.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile> -    <CudaCompile Include="cuda\2d\util.cu"> +    <CudaCompile Include="cuda\3d\sirt3d.cu">        <Filter>CUDA\cuda source</Filter>      </CudaCompile>      <CudaCompile Include="cuda\3d\util3d.cu"> @@ -162,7 +162,7 @@      <ClCompile Include="src\Globals.cpp">        <Filter>Global & Other\source</Filter>      </ClCompile> -    <ClCompile Include="src\Logger.cpp"> +    <ClCompile Include="src\Logging.cpp">        <Filter>Global & Other\source</Filter>      </ClCompile>      <ClCompile Include="src\PlatformDepSystemCode.cpp"> @@ -189,6 +189,9 @@      <ClCompile Include="src\FanFlatVecProjectionGeometry2D.cpp">        <Filter>Geometries\source</Filter>      </ClCompile> +    <ClCompile Include="src\GeometryUtil3D.cpp"> +      <Filter>Geometries\source</Filter> +    </ClCompile>      <ClCompile Include="src\ParallelProjectionGeometry2D.cpp">        <Filter>Geometries\source</Filter>      </ClCompile> @@ -333,7 +336,10 @@      <ClInclude Include="include\astra\CglsAlgorithm.h">        <Filter>Algorithms\headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\DartAlgorithm.h"> +    <ClInclude Include="include\astra\CudaBackProjectionAlgorithm.h"> +      <Filter>Algorithms\headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaBackProjectionAlgorithm3D.h">        <Filter>Algorithms\headers</Filter>      </ClInclude>      <ClInclude Include="include\astra\FilteredBackProjectionAlgorithm.h"> @@ -393,6 +399,9 @@      <ClInclude Include="include\astra\AstraObjectManager.h">        <Filter>Global & Other\headers</Filter>      </ClInclude> +    <ClInclude Include="include\astra\clog.h"> +      <Filter>Global & Other\headers</Filter> +    </ClInclude>      <ClInclude Include="include\astra\Config.h">        <Filter>Global & Other\headers</Filter>      </ClInclude> @@ -402,7 +411,7 @@      <ClInclude Include="include\astra\Globals.h">        <Filter>Global & Other\headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\Logger.h"> +    <ClInclude Include="include\astra\Logging.h">        <Filter>Global & Other\headers</Filter>      </ClInclude>      <ClInclude Include="include\astra\PlatformDepSystemCode.h"> @@ -414,6 +423,9 @@      <ClInclude Include="include\astra\TypeList.h">        <Filter>Global & Other\headers</Filter>      </ClInclude> +    <ClInclude Include="include\astra\Utilities.h"> +      <Filter>Global & Other\headers</Filter> +    </ClInclude>      <ClInclude Include="include\astra\Vector3D.h">        <Filter>Global & Other\headers</Filter>      </ClInclude> @@ -435,6 +447,12 @@      <ClInclude Include="include\astra\FanFlatVecProjectionGeometry2D.h">        <Filter>Geometries\headers</Filter>      </ClInclude> +    <ClInclude Include="include\astra\GeometryUtil2D.h"> +      <Filter>Geometries\headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\GeometryUtil3D.h"> +      <Filter>Geometries\headers</Filter> +    </ClInclude>      <ClInclude Include="include\astra\ParallelProjectionGeometry2D.h">        <Filter>Geometries\headers</Filter>      </ClInclude> @@ -495,46 +513,79 @@      <ClInclude Include="include\astra\SparseMatrixProjector2D.h">        <Filter>Projectors\headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\2d\algo.h"> -      <Filter>CUDA\cuda headers</Filter> +    <ClInclude Include="include\astra\CudaCglsAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\algo3d.h"> -      <Filter>CUDA\cuda headers</Filter> +    <ClInclude Include="include\astra\CudaCglsAlgorithm3D.h"> +      <Filter>CUDA\astra headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\2d\arith.h"> -      <Filter>CUDA\cuda headers</Filter> +    <ClInclude Include="include\astra\CudaDartMaskAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\arith3d.h"> -      <Filter>CUDA\cuda headers</Filter> +    <ClInclude Include="include\astra\CudaDartMaskAlgorithm3D.h"> +      <Filter>CUDA\astra headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\2d\astra.h"> -      <Filter>CUDA\cuda headers</Filter> +    <ClInclude Include="include\astra\CudaDartSmoothingAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\astra3d.h"> -      <Filter>CUDA\cuda headers</Filter> +    <ClInclude Include="include\astra\CudaDartSmoothingAlgorithm3D.h"> +      <Filter>CUDA\astra headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\2d\cgls.h"> -      <Filter>CUDA\cuda headers</Filter> +    <ClInclude Include="include\astra\CudaDataOperationAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\cgls3d.h"> -      <Filter>CUDA\cuda headers</Filter> +    <ClInclude Include="include\astra\CudaEMAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\cone_bp.h"> +    <ClInclude Include="include\astra\CudaFDKAlgorithm3D.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaFilteredBackProjectionAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaForwardProjectionAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaForwardProjectionAlgorithm3D.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaProjector2D.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaProjector3D.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaReconstructionAlgorithm2D.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaRoiSelectAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaSartAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaSirtAlgorithm.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="include\astra\CudaSirtAlgorithm3D.h"> +      <Filter>CUDA\astra headers</Filter> +    </ClInclude> +    <ClInclude Include="cuda\2d\algo.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\cone_fp.h"> +    <ClInclude Include="cuda\2d\arith.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\2d\darthelper.h"> +    <ClInclude Include="cuda\2d\astra.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\darthelper3d.h"> +    <ClInclude Include="cuda\2d\cgls.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\2d\dims.h"> +    <ClInclude Include="cuda\2d\darthelper.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\dims3d.h"> +    <ClInclude Include="cuda\2d\dims.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude>      <ClInclude Include="cuda\2d\em.h"> @@ -549,18 +600,9 @@      <ClInclude Include="cuda\2d\fbp_filters.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\fdk.h"> -      <Filter>CUDA\cuda headers</Filter> -    </ClInclude>      <ClInclude Include="cuda\2d\fft.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\par3d_bp.h"> -      <Filter>CUDA\cuda headers</Filter> -    </ClInclude> -    <ClInclude Include="cuda\3d\par3d_fp.h"> -      <Filter>CUDA\cuda headers</Filter> -    </ClInclude>      <ClInclude Include="cuda\2d\par_bp.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> @@ -573,74 +615,44 @@      <ClInclude Include="cuda\2d\sirt.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="cuda\3d\sirt3d.h"> -      <Filter>CUDA\cuda headers</Filter> -    </ClInclude>      <ClInclude Include="cuda\2d\util.h">        <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaBackProjectionAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaBackProjectionAlgorithm3D.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaCglsAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaCglsAlgorithm3D.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaDartMaskAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaDartMaskAlgorithm3D.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaDartSmoothingAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaDartSmoothingAlgorithm3D.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaDataOperationAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> -    </ClInclude> -    <ClInclude Include="include\astra\CudaEMAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\algo3d.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaFDKAlgorithm3D.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\arith3d.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaFilteredBackProjectionAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\astra3d.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaForwardProjectionAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\cgls3d.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaForwardProjectionAlgorithm3D.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\cone_bp.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaProjector2D.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\cone_fp.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaProjector3D.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\darthelper3d.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaReconstructionAlgorithm2D.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\dims3d.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaRoiSelectAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\fdk.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaSartAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\par3d_bp.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaSirtAlgorithm.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\par3d_fp.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude> -    <ClInclude Include="include\astra\CudaSirtAlgorithm3D.h"> -      <Filter>CUDA\astra headers</Filter> +    <ClInclude Include="cuda\3d\sirt3d.h"> +      <Filter>CUDA\cuda headers</Filter>      </ClInclude>      <ClInclude Include="cuda\3d\util3d.h">        <Filter>CUDA\cuda headers</Filter> diff --git a/build/linux/Makefile.in b/build/linux/Makefile.in index d391278..bc9821a 100644 --- a/build/linux/Makefile.in +++ b/build/linux/Makefile.in @@ -28,7 +28,7 @@ CXXFLAGS=@SAVED_CXXFLAGS@  LDFLAGS=@SAVED_LDFLAGS@  LIBS=@SAVED_LIBS@ -CPPFLAGS+=-I../.. -I../../include -I../../lib/include/rapidxml +CPPFLAGS+=-I../.. -I../../include -I../../lib/include  CXXFLAGS+=-g -O3 -Wall -Wshadow  LIBS+=-lpthread  LDFLAGS+=-g @@ -123,7 +123,7 @@ BASE_OBJECTS=\  	src/Fourier.lo \  	src/GeometryUtil3D.lo \  	src/Globals.lo \ -	src/Logger.lo \ +	src/Logging.lo \  	src/ParallelBeamBlobKernelProjector2D.lo \  	src/ParallelBeamLinearKernelProjector2D.lo \  	src/ParallelBeamLineKernelProjector2D.lo \ @@ -222,6 +222,7 @@ TEST_OBJECTS=\  MATLAB_CXX_OBJECTS=\  	matlab/mex/mexHelpFunctions.o \  	matlab/mex/mexCopyDataHelpFunctions.o \ +	matlab/mex/mexInitFunctions.o \  	matlab/mex/mexDataManagerHelpFunctions.o  MATLAB_MEX=\ @@ -231,6 +232,7 @@ MATLAB_MEX=\  	matlab/mex/astra_mex_matrix_c.$(MEXSUFFIX) \  	matlab/mex/astra_mex_projector_c.$(MEXSUFFIX) \  	matlab/mex/astra_mex_projector3d_c.$(MEXSUFFIX) \ +	matlab/mex/astra_mex_log_c.$(MEXSUFFIX) \  	matlab/mex/astra_mex_data3d_c.$(MEXSUFFIX) diff --git a/build/linux/configure.ac b/build/linux/configure.ac index d9e1f1a..58a3f4c 100644 --- a/build/linux/configure.ac +++ b/build/linux/configure.ac @@ -190,7 +190,7 @@ if test x"$with_python" != x -a x"$with_python" != xno; then    AC_MSG_CHECKING(for python)    ASTRA_RUN_LOGOUTPUT(echo 'import sys' | $PYTHON -)    if test $? -ne 0; then -    AC_MSG_ERROR(Python binary not found)] +    AC_MSG_ERROR(Python binary not found)    fi    AC_MSG_RESULT([$PYTHON])    HAVEPYTHON=yes diff --git a/build/msvc/gen.py b/build/msvc/gen.py new file mode 100644 index 0000000..9f5e367 --- /dev/null +++ b/build/msvc/gen.py @@ -0,0 +1,1127 @@ +from __future__ import print_function +import sys +import os + +vcppguid = "8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942" # C++ project +siguid = "2150E333-8FDC-42A3-9474-1A3956D46DE8" # project group  + +# to generate a new uuid: +# +# import uuid +# uuid.uuid4().__str__().upper() + +def create_mex_project(name, uuid11, uuid09): +  return { "type": vcppguid, "name": name, "file11": "matlab\\mex\\" + name + "_vc11.vcxproj", "file09": "matlab\\mex\\" + name + "_vc09.vcproj", "uuid11": uuid11, "uuid09": uuid09, "files": [] } + +P_astra = { "type": vcppguid, "name": "astra_vc11", "file11": "astra_vc11.vcxproj", "file09": "astra_vc09.vcproj", "uuid11": "BE9F1326-527C-4284-AE2C-D1E25D539CEA", "uuid09": "12926444-6723-46A8-B388-12E65E0577FA" } + +P0 = create_mex_project("astra_mex", "3FDA35E0-0D54-4663-A3E6-5ABA96F32221", "3FDA35E0-0D54-4663-A3E6-5ABA96F32221")  + +P1 = create_mex_project("astra_mex_algorithm", "056BF7A9-294D-487C-8CC3-BE629077CA94", "056BF7A9-294D-487C-8CC3-BE629077CA94") +P2 = create_mex_project("astra_mex_data2d", "E4092269-B19C-46F7-A84E-4F146CC70E44", "E4092269-B19C-46F7-A84E-4F146CC70E44") +P3 = create_mex_project("astra_mex_data3d", "0BEC029B-0929-4BF9-BD8B-9C9806A52065", "0BEC029B-0929-4BF9-BD8B-9C9806A52065") +P4 = create_mex_project("astra_mex_matrix", "9D041710-2119-4230-BCF2-5FBE753FDE49", "9D041710-2119-4230-BCF2-5FBE753FDE49") +P5 = create_mex_project("astra_mex_projector", "4DD6056F-8EEE-4C9A-B2A9-923F01A32E97", "4DD6056F-8EEE-4C9A-B2A9-923F01A32E97") +P6 = create_mex_project("astra_mex_projector3d", "F94CCD79-AA11-42DF-AC8A-6C9D2238A883", "F94CCD79-AA11-42DF-AC8A-6C9D2238A883") +P7 = create_mex_project("astra_mex_log", "03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E", "CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8") + +F_astra_mex = { "type": siguid, +                "name": "astra_mex", +                "file11": "astra_mex", +                "file09": "astra_mex", +                "uuid11": "5E99A109-374E-4102-BE9B-99BA1FA8AA30", +                "uuid09": "33EF0AC5-B475-40BF-BAE5-67075B204D10", +                "entries": [ P0, P1, P2, P3, P4, P5, P6, P7 ] } + + +P0["files"] = [ +"astra_mex_c.cpp", +"mexHelpFunctions.cpp", +"mexHelpFunctions.h", +"mexInitFunctions.cpp", +"mexInitFunctions.h", +] +P1["files"] = [ +"astra_mex_algorithm_c.cpp", +"mexHelpFunctions.cpp", +"mexHelpFunctions.h", +"mexInitFunctions.cpp", +"mexInitFunctions.h", +] +P2["files"] = [ +"astra_mex_data2d_c.cpp", +"mexHelpFunctions.cpp", +"mexHelpFunctions.h", +"mexCopyDataHelpFunctions.cpp", +"mexCopyDataHelpFunctions.h", +"mexDataManagerHelpFunctions.cpp", +"mexDataManagerHelpFunctions.h", +"mexInitFunctions.cpp", +"mexInitFunctions.h", +] +P3["files"] = [ +"astra_mex_data3d_c.cpp", +"mexHelpFunctions.cpp", +"mexHelpFunctions.h", +"mexCopyDataHelpFunctions.cpp", +"mexCopyDataHelpFunctions.h", +"mexDataManagerHelpFunctions.cpp", +"mexDataManagerHelpFunctions.h", +"mexInitFunctions.cpp", +"mexInitFunctions.h", +] +P4["files"] = [ +"astra_mex_matrix_c.cpp", +"mexHelpFunctions.cpp", +"mexHelpFunctions.h", +"mexInitFunctions.cpp", +"mexInitFunctions.h", +] +P5["files"] = [ +"astra_mex_projector_c.cpp", +"mexHelpFunctions.cpp", +"mexHelpFunctions.h", +"mexInitFunctions.cpp", +"mexInitFunctions.h", +] +P6["files"] = [ +"astra_mex_projector3d_c.cpp", +"mexHelpFunctions.cpp", +"mexHelpFunctions.h", +"mexInitFunctions.cpp", +"mexInitFunctions.h", +] +P7["files"] = [ +"astra_mex_log_c.cpp", +"mexHelpFunctions.cpp", +"mexHelpFunctions.h", +"mexInitFunctions.cpp", +"mexInitFunctions.h", +] + + + +P_astra["filter_names"] = [ +"Algorithms", +"Data Structures", +"Projectors", +"CUDA", +"Global & Other", +"Geometries", +"Algorithms\\headers", +"Algorithms\\source", +"Data Structures\\headers", +"Data Structures\\source", +"Global & Other\\headers", +"Global & Other\\source", +"Geometries\\headers", +"Geometries\\source", +"Projectors\\headers", +"Projectors\\inline", +"Projectors\\source", +"CUDA\\astra headers", +"CUDA\\astra source", +"CUDA\\cuda headers", +"CUDA\\cuda source", +] +P_astra["filters"] = {} +P_astra["filters"]["Algorithms"] = [ "262b0d17-774a-4cb1-b51a-b358d2d02791" ] +P_astra["filters"]["Data Structures"] = [ "76d6d672-670b-4454-b3ab-10dc8f9b8710" ] +P_astra["filters"]["Projectors"] = [ "77a581a9-60da-4265-97c0-80cdf97408c0" ] +P_astra["filters"]["CUDA"] = [ "c1af0e56-5fcc-4e75-b5db-88eeb4148185" ] +P_astra["filters"]["Global & Other"] = [ "72fbe846-10ef-4c52-88df-13bd66c4cbfc" ] +P_astra["filters"]["Geometries"] = [ "7ef37c12-c98c-4dd6-938d-12f49279eae0" ] +P_astra["filters"]["CUDA\\cuda source"] = [ +"04a878ed-77b4-4525-9bc2-38ccd65282c5", +"cuda\\2d\\algo.cu", +"cuda\\2d\\arith.cu", +"cuda\\2d\\astra.cu", +"cuda\\2d\\cgls.cu", +"cuda\\2d\\darthelper.cu", +"cuda\\2d\\em.cu", +"cuda\\2d\\fan_bp.cu", +"cuda\\2d\\fan_fp.cu", +"cuda\\2d\\fft.cu", +"cuda\\2d\\par_bp.cu", +"cuda\\2d\\par_fp.cu", +"cuda\\2d\\sart.cu", +"cuda\\2d\\sirt.cu", +"cuda\\2d\\util.cu", +"cuda\\3d\\algo3d.cu", +"cuda\\3d\\arith3d.cu", +"cuda\\3d\\astra3d.cu", +"cuda\\3d\\cgls3d.cu", +"cuda\\3d\\cone_bp.cu", +"cuda\\3d\\cone_fp.cu", +"cuda\\3d\\darthelper3d.cu", +"cuda\\3d\\fdk.cu", +"cuda\\3d\\par3d_bp.cu", +"cuda\\3d\\par3d_fp.cu", +"cuda\\3d\\sirt3d.cu", +"cuda\\3d\\util3d.cu", +] +P_astra["filters"]["Algorithms\\source"] = [ +"9df653ab-26c3-4bec-92a2-3dda22fda761", +"src\\Algorithm.cpp", +"src\\ArtAlgorithm.cpp", +"src\\AsyncAlgorithm.cpp", +"src\\BackProjectionAlgorithm.cpp", +"src\\CglsAlgorithm.cpp", +"src\\FilteredBackProjectionAlgorithm.cpp", +"src\\ForwardProjectionAlgorithm.cpp", +"src\\ReconstructionAlgorithm2D.cpp", +"src\\ReconstructionAlgorithm3D.cpp", +"src\\SartAlgorithm.cpp", +"src\\SirtAlgorithm.cpp", +] +P_astra["filters"]["Data Structures\\source"] = [ +"95346487-8185-487b-a794-3e7fb5fcbd4c", +"src\\Float32Data.cpp", +"src\\Float32Data2D.cpp", +"src\\Float32Data3D.cpp", +"src\\Float32Data3DMemory.cpp", +"src\\Float32ProjectionData2D.cpp", +"src\\Float32ProjectionData3D.cpp", +"src\\Float32ProjectionData3DMemory.cpp", +"src\\Float32VolumeData2D.cpp", +"src\\Float32VolumeData3D.cpp", +"src\\Float32VolumeData3DMemory.cpp", +"src\\SparseMatrix.cpp", +] +P_astra["filters"]["Global & Other\\source"] = [ +"1546cb47-7e5b-42c2-b695-ef172024c14b", +"src\\AstraObjectFactory.cpp", +"src\\AstraObjectManager.cpp", +"src\\Config.cpp", +"src\\Fourier.cpp", +"src\\Globals.cpp", +"src\\Logging.cpp", +"src\\PlatformDepSystemCode.cpp", +"src\\Utilities.cpp", +"src\\XMLDocument.cpp", +"src\\XMLNode.cpp", +] +P_astra["filters"]["Geometries\\source"] = [ +"dc27bff7-4256-4311-a131-47612a44af20", +"src\\ConeProjectionGeometry3D.cpp", +"src\\ConeVecProjectionGeometry3D.cpp", +"src\\FanFlatProjectionGeometry2D.cpp", +"src\\FanFlatVecProjectionGeometry2D.cpp", +"src\\GeometryUtil3D.cpp", +"src\\ParallelProjectionGeometry2D.cpp", +"src\\ParallelProjectionGeometry3D.cpp", +"src\\ParallelVecProjectionGeometry3D.cpp", +"src\\ProjectionGeometry2D.cpp", +"src\\ProjectionGeometry3D.cpp", +"src\\SparseMatrixProjectionGeometry2D.cpp", +"src\\VolumeGeometry2D.cpp", +"src\\VolumeGeometry3D.cpp", +] +P_astra["filters"]["Projectors\\source"] = [ +"2d60e3c8-7874-4cee-b139-991ac15e811d", +"src\\DataProjector.cpp", +"src\\DataProjectorPolicies.cpp", +"src\\FanFlatBeamLineKernelProjector2D.cpp", +"src\\FanFlatBeamStripKernelProjector2D.cpp", +"src\\ParallelBeamBlobKernelProjector2D.cpp", +"src\\ParallelBeamLinearKernelProjector2D.cpp", +"src\\ParallelBeamLineKernelProjector2D.cpp", +"src\\ParallelBeamStripKernelProjector2D.cpp", +"src\\Projector2D.cpp", +"src\\Projector3D.cpp", +"src\\SparseMatrixProjector2D.cpp", +] +P_astra["filters"]["CUDA\\astra source"] = [ +"bbef012e-598a-456f-90d8-416bdcb4221c", +"src\\CudaBackProjectionAlgorithm.cpp", +"src\\CudaBackProjectionAlgorithm3D.cpp", +"src\\CudaCglsAlgorithm.cpp", +"src\\CudaCglsAlgorithm3D.cpp", +"src\\CudaDartMaskAlgorithm.cpp", +"src\\CudaDartMaskAlgorithm3D.cpp", +"src\\CudaDartSmoothingAlgorithm.cpp", +"src\\CudaDartSmoothingAlgorithm3D.cpp", +"src\\CudaDataOperationAlgorithm.cpp", +"src\\CudaEMAlgorithm.cpp", +"src\\CudaFDKAlgorithm3D.cpp", +"src\\CudaFilteredBackProjectionAlgorithm.cpp", +"src\\CudaForwardProjectionAlgorithm.cpp", +"src\\CudaForwardProjectionAlgorithm3D.cpp", +"src\\CudaProjector2D.cpp", +"src\\CudaProjector3D.cpp", +"src\\CudaReconstructionAlgorithm2D.cpp", +"src\\CudaRoiSelectAlgorithm.cpp", +"src\\CudaSartAlgorithm.cpp", +"src\\CudaSirtAlgorithm.cpp", +"src\\CudaSirtAlgorithm3D.cpp", +] +P_astra["filters"]["CUDA\\cuda headers"] = [ +"4e17872e-db7d-41bc-9760-fad1c253b583", +"cuda\\2d\\algo.h", +"cuda\\2d\\arith.h", +"cuda\\2d\\astra.h", +"cuda\\2d\\cgls.h", +"cuda\\2d\\darthelper.h", +"cuda\\2d\\dims.h", +"cuda\\2d\\em.h", +"cuda\\2d\\fan_bp.h", +"cuda\\2d\\fan_fp.h", +"cuda\\2d\\fbp_filters.h", +"cuda\\2d\\fft.h", +"cuda\\2d\\par_bp.h", +"cuda\\2d\\par_fp.h", +"cuda\\2d\\sart.h", +"cuda\\2d\\sirt.h", +"cuda\\2d\\util.h", +"cuda\\3d\\algo3d.h", +"cuda\\3d\\arith3d.h", +"cuda\\3d\\astra3d.h", +"cuda\\3d\\cgls3d.h", +"cuda\\3d\\cone_bp.h", +"cuda\\3d\\cone_fp.h", +"cuda\\3d\\darthelper3d.h", +"cuda\\3d\\dims3d.h", +"cuda\\3d\\fdk.h", +"cuda\\3d\\par3d_bp.h", +"cuda\\3d\\par3d_fp.h", +"cuda\\3d\\sirt3d.h", +"cuda\\3d\\util3d.h", +] +P_astra["filters"]["Algorithms\\headers"] = [ +"a76ffd6d-3895-4365-b27e-fc9a72f2ed75", +"include\\astra\\Algorithm.h", +"include\\astra\\AlgorithmTypelist.h", +"include\\astra\\ArtAlgorithm.h", +"include\\astra\\AsyncAlgorithm.h", +"include\\astra\\BackProjectionAlgorithm.h", +"include\\astra\\CglsAlgorithm.h", +"include\\astra\\CudaBackProjectionAlgorithm.h", +"include\\astra\\CudaBackProjectionAlgorithm3D.h", +"include\\astra\\FilteredBackProjectionAlgorithm.h", +"include\\astra\\ForwardProjectionAlgorithm.h", +"include\\astra\\ReconstructionAlgorithm2D.h", +"include\\astra\\ReconstructionAlgorithm3D.h", +"include\\astra\\SartAlgorithm.h", +"include\\astra\\SirtAlgorithm.h", +] +P_astra["filters"]["Data Structures\\headers"] = [ +"444c44b0-6454-483a-be26-7cb9c8ab0b98", +"include\\astra\\Float32Data.h", +"include\\astra\\Float32Data2D.h", +"include\\astra\\Float32Data3D.h", +"include\\astra\\Float32Data3DMemory.h", +"include\\astra\\Float32ProjectionData2D.h", +"include\\astra\\Float32ProjectionData3D.h", +"include\\astra\\Float32ProjectionData3DMemory.h", +"include\\astra\\Float32VolumeData2D.h", +"include\\astra\\Float32VolumeData3D.h", +"include\\astra\\Float32VolumeData3DMemory.h", +"include\\astra\\SparseMatrix.h", +] +P_astra["filters"]["Global & Other\\headers"] = [ +"1c52efc8-a77e-4c72-b9be-f6429a87e6d7", +"include\\astra\\AstraObjectFactory.h", +"include\\astra\\AstraObjectManager.h", +"include\\astra\\clog.h", +"include\\astra\\Config.h", +"include\\astra\\Fourier.h", +"include\\astra\\Globals.h", +"include\\astra\\Logging.h", +"include\\astra\\PlatformDepSystemCode.h", +"include\\astra\\Singleton.h", +"include\\astra\\TypeList.h", +"include\\astra\\Utilities.h", +"include\\astra\\Vector3D.h", +"include\\astra\\XMLDocument.h", +"include\\astra\\XMLNode.h", +] +P_astra["filters"]["Geometries\\headers"] = [ +"eddb31ba-0db7-4ab1-a490-36623aaf8901", +"include\\astra\\ConeProjectionGeometry3D.h", +"include\\astra\\ConeVecProjectionGeometry3D.h", +"include\\astra\\FanFlatProjectionGeometry2D.h", +"include\\astra\\FanFlatVecProjectionGeometry2D.h", +"include\\astra\\GeometryUtil2D.h", +"include\\astra\\GeometryUtil3D.h", +"include\\astra\\ParallelProjectionGeometry2D.h", +"include\\astra\\ParallelProjectionGeometry3D.h", +"include\\astra\\ParallelVecProjectionGeometry3D.h", +"include\\astra\\ProjectionGeometry2D.h", +"include\\astra\\ProjectionGeometry3D.h", +"include\\astra\\SparseMatrixProjectionGeometry2D.h", +"include\\astra\\VolumeGeometry2D.h", +"include\\astra\\VolumeGeometry3D.h", +] +P_astra["filters"]["Projectors\\headers"] = [ +"91ae2cfd-6b45-46eb-ad99-2f16e5ce4b1e", +"include\\astra\\DataProjector.h", +"include\\astra\\DataProjectorPolicies.h", +"include\\astra\\FanFlatBeamLineKernelProjector2D.h", +"include\\astra\\FanFlatBeamStripKernelProjector2D.h", +"include\\astra\\ParallelBeamBlobKernelProjector2D.h", +"include\\astra\\ParallelBeamLinearKernelProjector2D.h", +"include\\astra\\ParallelBeamLineKernelProjector2D.h", +"include\\astra\\ParallelBeamStripKernelProjector2D.h", +"include\\astra\\Projector2D.h", +"include\\astra\\Projector3D.h", +"include\\astra\\ProjectorTypelist.h", +"include\\astra\\SparseMatrixProjector2D.h", +] +P_astra["filters"]["CUDA\\astra headers"] = [ +"bd4e1f94-2f56-4db6-b946-20c29d65a351", +"include\\astra\\CudaCglsAlgorithm.h", +"include\\astra\\CudaCglsAlgorithm3D.h", +"include\\astra\\CudaDartMaskAlgorithm.h", +"include\\astra\\CudaDartMaskAlgorithm3D.h", +"include\\astra\\CudaDartSmoothingAlgorithm.h", +"include\\astra\\CudaDartSmoothingAlgorithm3D.h", +"include\\astra\\CudaDataOperationAlgorithm.h", +"include\\astra\\CudaEMAlgorithm.h", +"include\\astra\\CudaFDKAlgorithm3D.h", +"include\\astra\\CudaFilteredBackProjectionAlgorithm.h", +"include\\astra\\CudaForwardProjectionAlgorithm.h", +"include\\astra\\CudaForwardProjectionAlgorithm3D.h", +"include\\astra\\CudaProjector2D.h", +"include\\astra\\CudaProjector3D.h", +"include\\astra\\CudaReconstructionAlgorithm2D.h", +"include\\astra\\CudaRoiSelectAlgorithm.h", +"include\\astra\\CudaSartAlgorithm.h", +"include\\astra\\CudaSirtAlgorithm.h", +"include\\astra\\CudaSirtAlgorithm3D.h", + +] +P_astra["filters"]["Projectors\\inline"] = [ +"0daffd63-ba49-4a5f-8d7a-5322e0e74f22", +"include\\astra\\DataProjectorPolicies.inl", +"include\\astra\\FanFlatBeamLineKernelProjector2D.inl", +"include\\astra\\FanFlatBeamStripKernelProjector2D.inl", +"include\\astra\\ParallelBeamBlobKernelProjector2D.inl", +"include\\astra\\ParallelBeamLinearKernelProjector2D.inl", +"include\\astra\\ParallelBeamLineKernelProjector2D.inl", +"include\\astra\\ParallelBeamStripKernelProjector2D.inl", +"include\\astra\\SparseMatrixProjector2D.inl", +] + +P_astra["files"] = [] +for f in P_astra["filters"]: +  P_astra["files"].extend(P_astra["filters"][f][1:]) +P_astra["files"].sort() + +projects = [ P_astra, F_astra_mex, P0, P1, P2, P3, P4, P5, P6, P7 ] + +bom = "\xef\xbb\xbf" + +class Configuration: +  def __init__(self, debug, cuda, x64): +    self.debug = debug +    self.cuda = cuda +    self.x64 = x64 +  def type(self): +    if self.debug: +      return "Debug" +    else: +      return "Release" +  def config(self): +    n = self.type() +    if self.cuda: +      n += "_CUDA" +    return n +  def platform(self): +    if self.x64: +      n = "x64" +    else: +      n = "Win32" +    return n  +  def name(self): +    n = self.config() +    n += "|" +    n += self.platform() +    return n +  def target(self): +    n = "Astra" +    if self.cuda: +      n += "Cuda" +    if self.x64: +      n += "64" +    else: +      n += "32" +    if self.debug: +      n += "D" +    return n +       + + +configs = [ Configuration(a,b,c) for a in [ True, False ] for b in [ True, False ] for c in [ False, True ] ] + +def write_sln(version): +  main_project = P_astra +  if version == 9: +    F = open("astra_vc09.sln", "w") +  elif version == 11: +    F = open("astra_vc11.sln", "w") +  else: +    assert(False) +  print(bom, file=F) +  if version == 9: +    print("Microsoft Visual Studio Solution File, Format Version 10.00", file=F) +    print("# Visual Studio 2008", file=F) +    uuid = "uuid09" +    file_ = "file09" +  elif version == 11: +    print("Microsoft Visual Studio Solution File, Format Version 12.00", file=F) +    print("# Visual Studio 2012", file=F) +    uuid = "uuid11" +    file_ = "file11" +  for p in projects: +    s = '''Project("{%s}") = "%s", "%s", "{%s}"''' % (p["type"], p["name"], p[file_], p[uuid]) +    print(s, file=F) +    if "mex" in p["name"]: +      print("\tProjectSection(ProjectDependencies) = postProject", file=F) +      print("\t\t{%s} = {%s}" % (main_project[uuid], main_project[uuid]), file=F) +      print("\tEndProjectSection", file=F) +    print("EndProject", file=F) +  print("Global", file=F) +  print("\tGlobalSection(SolutionConfigurationPlatforms) = preSolution", file=F) +  for c in configs: +    print("\t\t" + c.name() + " = " + c.name(), file=F) +  print("\tEndGlobalSection", file=F) +  print("\tGlobalSection(ProjectConfigurationPlatforms) = postSolution", file=F) +  for p in projects: +    if "entries" in p: +      continue +    for c in configs: +      print("\t\t{" + p[uuid] + "}." + c.name() + ".ActiveCfg = " + c.name(), file=F) +      print("\t\t{" + p[uuid] + "}." + c.name() + ".Build.0 = " + c.name(), file=F) +  print("\tEndGlobalSection", file=F) +  print("\tGlobalSection(SolutionProperties) = preSolution", file=F) +  print("\t\tHideSolutionNode = FALSE", file=F) +  print("\tEndGlobalSection", file=F) +  print("\tGlobalSection(NestedProjects) = preSolution", file=F) +  for p in projects: +    if "entries" not in p: +      continue +    for e in p["entries"]: +      print("\t\t{" + e[uuid] + "} = {" + p[uuid] + "}", file=F) +  print("\tEndGlobalSection", file=F) +  print("EndGlobal", file=F) +  F.close() + +def write_project11_start(P, F): +  print(bom + '<?xml version="1.0" encoding="utf-8"?>', file=F) +  print('<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">', file=F) +  print('  <ItemGroup Label="ProjectConfigurations">', file=F) +  for c in configs: +    print('    <ProjectConfiguration Include="' + c.name() + '">', file=F) +    print('      <Configuration>' + c.config() + '</Configuration>', file=F) +    print('      <Platform>' + c.platform() + '</Platform>', file=F) +    print('    </ProjectConfiguration>', file=F) +  print('  </ItemGroup>', file=F) +  print('  <PropertyGroup Label="Globals">', file=F) +  if 'mex' in P["name"]: +    print('    <ProjectName>' + P["name"] + '</ProjectName>', file=F) +  print('    <ProjectGuid>{' + P["uuid11"] + '}</ProjectGuid>', file=F) +  if 'mex' in P["name"]: +    print('    <RootNamespace>astraMatlab</RootNamespace>', file=F) +  else: +    print('    <RootNamespace>' + P["name"] + '</RootNamespace>', file=F) +  print('  </PropertyGroup>', file=F) +  print('  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />', file=F) +  for c in configs: +    print('''  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='%s'" Label="Configuration">''' % (c.name(), ), file=F) +    print('    <ConfigurationType>DynamicLibrary</ConfigurationType>', file=F) +    if 'mex' not in P["name"]: +      if c.debug: +        print('    <UseDebugLibraries>true</UseDebugLibraries>', file=F) +      else: +        print('    <UseDebugLibraries>false</UseDebugLibraries>', file=F) +    print('    <PlatformToolset>v110</PlatformToolset>', file=F) +    if 'mex' not in P["name"]: +      if not c.debug: +        print('    <WholeProgramOptimization>true</WholeProgramOptimization>', file=F) +      print('    <CharacterSet>MultiByte</CharacterSet>', file=F) +    print('  </PropertyGroup>', file=F) +  print('  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />', file=F) +  print('  <ImportGroup Label="ExtensionSettings">', file=F) +  if "mex" not in P["name"]: +    print('    <Import Project="$(VCTargetsPath)\BuildCustomizations\CUDA 5.5.props" />', file=F) +  print('  </ImportGroup>', file=F) +  for c in configs: +    print('''  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='%s'">''' % (c.name(), ), file=F) +    print('''    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />''', file=F) +    print('''  </ImportGroup>''', file=F) +  print('  <PropertyGroup Label="UserMacros" />', file=F) + +def write_project11_end(P, F): +  l = [ f for f in P["files"] if len(f) > 4 and f[-4:] == ".cpp" ] +  if l: +    print('  <ItemGroup>', file=F) +    for f in l: +      if ("cuda" in f) or ("Cuda" in f): +        print('    <ClCompile Include="' + f + '">', file=F) +        for c in configs: +          if not c.cuda: +            print('''      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='%s'">true</ExcludedFromBuild>''' % (c.name(), ), file=F) +        print('    </ClCompile>', file=F) +      else: +        print('    <ClCompile Include="' + f + '" />', file=F) +    print('  </ItemGroup>', file=F) +  l = [ f for f in P["files"] if len(f) > 2 and f[-2:] == ".h" ] +  if l: +    print('  <ItemGroup>', file=F) +    for f in l: +      print('    <ClInclude Include="' + f + '" />', file=F) +    print('  </ItemGroup>', file=F) +  l = [ f for f in P["files"] if len(f) > 3 and f[-3:] == ".cu" ] +  if l: +    print('  <ItemGroup>', file=F) +    for f in l: +      print('    <CudaCompile Include="' + f + '">', file=F) +      for c in configs: +        if not c.cuda: +          print('''      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='%s'">true</ExcludedFromBuild>''' % (c.name(), ), file=F) +      print('    </CudaCompile>', file=F) +    print('  </ItemGroup>', file=F) +  l = [ f for f in P["files"] if len(f) > 4 and f[-4:] == ".inl" ] +  if l: +    print('  <ItemGroup>', file=F) +    for f in l: +      print('    <None Include="' + f + '" />', file=F) +    print('  </ItemGroup>', file=F) +  print('  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />', file=F) +  print('  <ImportGroup Label="ExtensionTargets">', file=F) +  if "mex" not in P["name"]: +    print('    <Import Project="$(VCTargetsPath)\BuildCustomizations\CUDA 5.5.targets" />', file=F) +  print('  </ImportGroup>', file=F) +  print('</Project>', end="", file=F) + + +def write_main_project11(): +  P = P_astra; +  F = open(P["file11"], "w") +  write_project11_start(P, F) +  for c in configs: +    print('''  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='%s'">''' % (c.name(), ), file=F) +    if c.cuda: +      print('    <IncludePath>$(CUDA_INC_PATH);$(IncludePath)</IncludePath>', file=F) +      print('    <LibraryPath>$(CUDA_LIB_PATH);$(LibraryPath)</LibraryPath>', file=F) +    print('    <OutDir>$(SolutionDir)bin\\$(Platform)\\' + c.config() + '\\</OutDir>', file=F) +    print('    <IntDir>$(OutDir)obj\\</IntDir>', file=F) +    print('    <TargetExt>.dll</TargetExt>', file=F) +    print('    <TargetName>' + c.target() + '</TargetName>', file=F) +    print('    <GenerateManifest>true</GenerateManifest>', file=F) +    print('  </PropertyGroup>', file=F) +  for c in configs: +    print('''  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='%s'">''' % (c.name(), ), file=F) +    print('    <ClCompile>', file=F) +    if c.debug: +      print('      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>', file=F) +    else: +      print('      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>', file=F) +    print('      <WarningLevel>Level3</WarningLevel>', file=F) +    print('      <AdditionalIncludeDirectories>lib\include;include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>', file=F) +    print('      <OpenMPSupport>true</OpenMPSupport>', file=F) +    if not c.x64: # /arch:SSE2 is implicit on x64 +      print('      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet>', file=F) +    if c.debug: +      print('      <Optimization>Disabled</Optimization>', file=F) +    else: +      print('      <Optimization>MaxSpeed</Optimization>', file=F) +      print('      <FunctionLevelLinking>true</FunctionLevelLinking>', file=F) +      print('      <IntrinsicFunctions>true</IntrinsicFunctions>', file=F) +      print('      <InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion>', file=F) +      print('      <FavorSizeOrSpeed>Speed</FavorSizeOrSpeed>', file=F) +    d='      <PreprocessorDefinitions>' +    if c.cuda: +      d+="ASTRA_CUDA;" +    d+="__SSE2__;" +    d+="DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;" +    d+='%(PreprocessorDefinitions)</PreprocessorDefinitions>' +    print(d, file=F) +    print('      <MultiProcessorCompilation>true</MultiProcessorCompilation>', file=F) +    print('      <SDLCheck>true</SDLCheck>', file=F) +    print('    </ClCompile>', file=F) +    print('    <Link>', file=F) +    print('      <GenerateDebugInformation>true</GenerateDebugInformation>', file=F) +    if not c.debug: +      print('      <EnableCOMDATFolding>true</EnableCOMDATFolding>', file=F) +      print('      <OptimizeReferences>true</OptimizeReferences>', file=F) +    print('      <OutputFile>bin\\' + c.platform() + '\\' + c.config() + '\\' + c.target() + '.dll</OutputFile>', file=F) +    if c.cuda: +      print('      <AdditionalDependencies>cudart.lib;cufft.lib;%(AdditionalDependencies)</AdditionalDependencies>', file=F) +    l = '      <AdditionalLibraryDirectories>'; +    if c.x64: +      l += 'lib\\x64' +    else: +      l += 'lib\\win32' +    l += ';%(AdditionalLibraryDirectories)' +    if c.cuda: +      l += ';$(CudaToolkitLibDir)' +    l += '</AdditionalLibraryDirectories>' +    print(l, file=F) +    print('    </Link>', file=F) +    if c.cuda: +      print('    <CudaCompile>', file=F) +      if c.x64: +        print('      <TargetMachinePlatform>64</TargetMachinePlatform>', file=F) +      else: +        print('      <TargetMachinePlatform>32</TargetMachinePlatform>', file=F) +      print('      <GenerateLineInfo>true</GenerateLineInfo>', file=F) +      print('      <CodeGeneration>compute_20,sm_20;compute_30,sm_30;compute_30,sm_35;compute_30,compute_30</CodeGeneration>', file=F) +      print('    </CudaCompile>', file=F) +    print('  </ItemDefinitionGroup>', file=F) +  write_project11_end(P, F) +  F.close() + +def write_mex_project11(P): +  F = open("matlab/mex/" + P["name"] + "_vc11.vcxproj", "w") +  write_project11_start(P, F) +  print('  <PropertyGroup>', file=F) +  print('    <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion>', file=F) +  print('  </PropertyGroup>', file=F) +  for c in configs: +    print('''  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='%s'">''' % (c.name(), ), file=F) +    print('    <OutDir>$(SolutionDir)bin\\$(Platform)\\$(Configuration)\\</OutDir>', file=F) +    print('    <IntDir>$(OutDir)obj\\$(ProjectName)\\</IntDir>', file=F) +    print('    <TargetName>$(ProjectName)_c</TargetName>', file=F) +    if c.x64: +      print('    <TargetExt>.mexw64</TargetExt>', file=F) +    else: +      print('    <TargetExt>.mexw32</TargetExt>', file=F) +    print('  </PropertyGroup>', file=F) +  for c in configs: +    print('''  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='%s'">''' % (c.name(), ), file=F) +    print('    <ClCompile>', file=F) +    if c.debug: +      print('      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>', file=F) +    else: +      print('      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>', file=F) +#    print('      <WarningLevel>Level3</WarningLevel>', file=F) +    #print('      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>', file=F) +    # FIXME: This CUDA_PATH shouldn't be necessary +    print('      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>', file=F) +    print('      <OpenMPSupport>true</OpenMPSupport>', file=F) +    if not c.x64: # /arch:SSE2 is implicit on x64 +      print('      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet>', file=F) +    if c.debug: +      print('      <Optimization>Disabled</Optimization>', file=F) +    else: +      print('      <Optimization>MaxSpeed</Optimization>', file=F) +#      print('      <FunctionLevelLinking>true</FunctionLevelLinking>', file=F) +#      print('      <IntrinsicFunctions>true</IntrinsicFunctions>', file=F) +#      print('      <InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion>', file=F) +#      print('      <FavorSizeOrSpeed>Speed</FavorSizeOrSpeed>', file=F) +    d='      <PreprocessorDefinitions>' +    if c.cuda: +      d+="ASTRA_CUDA;" +    d+="__SSE2__;" +#    d+="DLL_EXPORTS;_CRT_SECURE_NO_WARNINGS;" +    d+='%(PreprocessorDefinitions)</PreprocessorDefinitions>' +    print(d, file=F) +    print('      <MultiProcessorCompilation>true</MultiProcessorCompilation>', file=F) +#    print('      <SDLCheck>true</SDLCheck>', file=F) +#   if c.debug: +#   <DebugInformationFormat>EditAndContinue</DebugInformationFormat> ?? +    print('    </ClCompile>', file=F) +    print('    <Link>', file=F) +#    if not c.debug: +#      print('      <EnableCOMDATFolding>true</EnableCOMDATFolding>', file=F) +#      print('      <OptimizeReferences>true</OptimizeReferences>', file=F) +    if c.x64: +      print('      <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile>', file=F) +    else: +      print('      <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile>', file=F) +    print('      <AdditionalDependencies>%s.lib;libmex.lib;libmx.lib;libut.lib;%%(AdditionalDependencies)</AdditionalDependencies>' % (c.target(), ), file=F) +    l = '      <AdditionalLibraryDirectories>'; +    if c.x64: +      l += '..\\..\\lib\\x64\\;..\\..\\bin\\x64\\' +    else: +      l += '..\\..\\lib\\win32\\;..\\..\\bin\\win32\\' +    l += c.config() +    if c.x64: +      l += ';$(MATLAB_ROOT)\extern\lib\win64\microsoft' +    else: +      l += ';$(MATLAB_ROOT)\extern\lib\win32\microsoft' +    l += ';%(AdditionalLibraryDirectories)' +    l += '</AdditionalLibraryDirectories>' +    print(l, file=F) +    print('      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>', file=F) +    print('      <GenerateDebugInformation>true</GenerateDebugInformation>', file=F) +    print('    </Link>', file=F) +    print('  </ItemDefinitionGroup>', file=F) +  write_project11_end(P, F) +  F.close() + +def write_main_filters11(): +  P = P_astra +  F = open(P["name"] + ".vcxproj.filters", "w") +  print(bom + '<?xml version="1.0" encoding="utf-8"?>', file=F) +  print('<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">', file=F) +  print('  <ItemGroup>', file=F) +  for Filter in P_astra["filter_names"]: +    L = P_astra["filters"][Filter][1:] +    l = [ f for f in L if len(f) > 3 and f[-3:] == ".cu" ] +    for f in l: +      print('    <CudaCompile Include="' + f + '">', file=F) +      print('      <Filter>' + Filter + '</Filter>', file=F) +      print('    </CudaCompile>', file=F) +  print('  </ItemGroup>', file=F) +  print('  <ItemGroup>', file=F) +  for Filter in P_astra["filter_names"]: +    L = P_astra["filters"][Filter][1:] +    l = [ f for f in L if len(f) > 4 and f[-4:] == ".cpp" ] +    for f in l: +      print('    <ClCompile Include="' + f + '">', file=F) +      print('      <Filter>' + Filter + '</Filter>', file=F) +      print('    </ClCompile>', file=F) +  print('  </ItemGroup>', file=F) +  print('  <ItemGroup>', file=F) +  for Filter in P_astra["filter_names"]: +    L = P_astra["filters"][Filter][1:] +    l = [ f for f in L if len(f) > 2 and f[-2:] == ".h" ] +    for f in l: +      print('    <ClInclude Include="' + f + '">', file=F) +      print('      <Filter>' + Filter + '</Filter>', file=F) +      print('    </ClInclude>', file=F) +  print('  </ItemGroup>', file=F) +  print('  <ItemGroup>', file=F) +  for Filter in P_astra["filter_names"]: +    L = P_astra["filters"][Filter][1:] +    l = [ f for f in L if len(f) > 4 and f[-4:] == ".inl" ] +    for f in l: +      print('    <None Include="' + f + '">', file=F) +      print('      <Filter>' + Filter + '</Filter>', file=F) +      print('    </None>', file=F) +  print('  </ItemGroup>', file=F) +  print('  <ItemGroup>', file=F) +  for f in P["filter_names"]: +    print('    <Filter Include="' + f + '">', file=F) +    print('      <UniqueIdentifier>{' + P["filters"][f][0] + '}</UniqueIdentifier>', file=F) +    print('    </Filter>', file=F) +  print('  </ItemGroup>', file=F) +  print('</Project>', end="", file=F) +  F.close() + +def write_project09_start(P, F): +  print('<?xml version="1.0" encoding="Windows-1252"?>', file=F) +  print('<VisualStudioProject', file=F) +  print('\tProjectType="Visual C++"', file=F) +  print('\tVersion="9.00"', file=F) +  if "mex" in P["name"]: +    print('\tName="%s"' % (P["name"], ), file=F) +  print('\tProjectGUID="{%s}"' % (P["uuid09"],), file=F) +  if "mex" in P["name"]: +    print('\tRootNamespace="astraMatlab"', file=F) +  else: +    print('\tRootNamespace="astra"', file=F) +  print('\tTargetFrameworkVersion="131072"', file=F) +  print('\t>', file=F) +  print(r'''	<Platforms> +		<Platform +			Name="Win32" +		/> +		<Platform +			Name="x64" +		/> +	</Platforms>''', file=F) + +def write_project09_unused_tools(F): +    print(r'''			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/>''', file=F) + + +def write_main_project09(): +  P = P_astra; +  F = open(P["file09"], "w") +  write_project09_start(P, F) +  print(r'''	<ToolFiles> +		<DefaultToolFile +			FileName="NvCudaRuntimeApi.v5.5.rules" +		/> +	</ToolFiles>''', file=F) +  print('\t<Configurations>', file=F) +  for c in configs: +    print('\t\t<Configuration', file=F) +    print('\t\t\tName="%s"' % (c.name(), ), file=F) +    print('\t\t\tOutputDirectory="$(SolutionDir)bin\$(PlatformName)\%s"' % (c.config(), ), file=F) +    print(r'''			IntermediateDirectory="$(OutDir)/obj" +			ConfigurationType="2" +			>''', file=F) +    write_project09_unused_tools(F) +    print('\t\t\t<Tool', file=F) +    print('\t\t\t\tName="VCCLCompilerTool"', file=F) +    if c.cuda: +      print('\t\t\t\tAdditionalIncludeDirectories=""$(CUDA_INC_PATH)";lib\\include;include"', file=F) +      print('\t\t\t\tPreprocessorDefinitions="ASTRA_CUDA;DLL_EXPORTS;__SSE2__"', file=F) +    else: +      print('\t\t\t\tAdditionalIncludeDirectories="lib\\include;include"', file=F) +      print('\t\t\t\tPreprocessorDefinitions="DLL_EXPORTS;__SSE2__"', file=F) +    if c.debug: +      print(r'''				Optimization="0" +				InlineFunctionExpansion="0" +				FavorSizeOrSpeed="0" +				EnableFiberSafeOptimizations="false" +				WholeProgramOptimization="false" +				RuntimeLibrary="3"''', file=F) +    else: +      print(r'''				Optimization="3" +				InlineFunctionExpansion="2" +				FavorSizeOrSpeed="1" +				RuntimeLibrary="2"''', file=F) +    if not c.x64: # /arch:SSE2 is implicit on x64 +      print('\t\t\t\tEnableEnhancedInstructionSet="2"', file=F) # SSE2 +    print('\t\t\t\tOpenMP="true"', file=F) +    print('\t\t\t\tAdditionalOptions="/MP"', file=F) # build with multiple processes +    print('\t\t\t/>', file=F) +    print('\t\t\t<Tool', file=F) +    print('\t\t\t\tName="VCLinkerTool"', file=F) +    if c.cuda: +      print('\t\t\t\tAdditionalDependencies="cudart.lib cufft.lib"', file=F) +    print('\t\t\t\tOutputFile="bin\\%s\\%s.dll"' % (c.platform(), c.target()), file=F) +    if c.cuda: +      print('\t\t\t\tAdditionalLibraryDirectories="".\\lib\\%s";"$(CUDA_LIB_PATH)""' % (c.platform(), ), file=F) +    else: +      print('\t\t\t\tAdditionalLibraryDirectories="".\\lib\\%s""' % (c.platform(), ), file=F) +    print('\t\t\t\tGenerateManifest="true"', file=F) +    print('\t\t\t\tModuleDefinitionFile=""', file=F) +    if c.debug: +      print('\t\t\t\tGenerateDebugInformation="true"', file=F) +    if c.x64: +      print('\t\t\t\tTargetMachine="17"', file=F) # x64 +    else: +      print('\t\t\t\tTargetMachine="1"', file=F) # x86 +    print('\t\t\t/>', file=F) +    print('\t\t\t<Tool', file=F) +    print('\t\t\t\tName="Cudart Build Rule"', file=F) +    print('\t\t\t\tArch1="20"', file=F) +    print('\t\t\t\tArch2="30"', file=F) +    print('\t\t\t\tArch3="35"', file=F) +    if c.x64: +      print('\t\t\t\tTargetMachinePlatform="1"', file=F) # x64 +    else: +      print('\t\t\t\tTargetMachinePlatform="0"', file=F) # x86 +    if c.debug: +      print('\t\t\t\tRuntime="3"', file=F) # MDD +    else: +      print('\t\t\t\tRuntime="2"', file=F) # MD +    if c.cuda: +      print('\t\t\t\tDefines="-DASTRA_CUDA -DDLL_EXPORTS"', file=F) +    else: # This 'else' doesn't make much sense +      print('\t\t\t\tDefines="-DDLL_EXPORTS"', file=F) +    # TODO!!! +    print('\t\t\t/>', file=F) +    print('\t\t</Configuration>', file=F) +  print('\t</Configurations>', file=F) +  print('\t<References>', file=F) +  print('\t</References>', file=F) +  print('\t<Files>', file=F) +  print(r'''		<Filter +			Name="Resource Files" +			Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav" +			UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" +			> +			<File +				RelativePath=".\src\astra.def" +				> +			</File> +		</Filter>''', file=F) +  curgroup = None +  for Filter in P["filter_names"]: +    if "\\" not in Filter: +      continue +    # TODO +    [ group, subgroup ] = Filter.split("\\") +    if group != curgroup: +      if curgroup != None: +        print('\t\t</Filter>', file=F) +      print('\t\t<Filter', file=F) +      print('\t\t\tName="%s"' % (group, ), file=F) +      print('\t\t\t>', file=F) +      curgroup = group +    print('\t\t\t<Filter', file=F) +    print('\t\t\t\tName="%s"' % (subgroup, ), file=F) +    print('\t\t\t\t>', file=F) +    for f in P["filters"][Filter][1:]: +      print('\t\t\t\t<File', file=F) +      print('\t\t\t\t\tRelativePath=".\\%s"' % (f, ), file=F) +      print('\t\t\t\t\t>', file=F) +      if (("Cuda" in f) or ("cuda" in f)) and not (f[-2:] == ".h"): +        for c in configs: +          if not c.cuda: +            print('\t\t\t\t\t<FileConfiguration', file=F) +            print('\t\t\t\t\t\tName="%s"' % (c.name(), ), file=F) +            print('\t\t\t\t\t\tExcludedFromBuild="true"', file=F) +            print('\t\t\t\t\t\t>', file=F) +            print('\t\t\t\t\t\t<Tool', file=F) +            if len(f) > 3 and f[-3:] == ".cu": +              print('\t\t\t\t\t\t\tName="Cudart Build Rule"', file=F) +            else: +              print('\t\t\t\t\t\t\tName="VCCLCompilerTool"', file=F) +            print('\t\t\t\t\t\t/>', file=F) +            print('\t\t\t\t\t</FileConfiguration>', file=F) +      print('\t\t\t\t</File>', file=F) +    print('\t\t\t</Filter>', file=F) +  print('\t\t</Filter>', file=F) +  print('\t</Files>', file=F) +  print('\t<Globals>', file=F) +  print('\t</Globals>', file=F) +  print('</VisualStudioProject>', file=F) +  F.close() + +def write_mex_project09(P): +  F = open("matlab/mex/" + P["name"] + "_vc09.vcproj", "w") +  write_project09_start(P, F) +  print('\t<ToolFiles>', file=F) +  print('\t</ToolFiles>', file=F) +  print('\t<Configurations>', file=F) +  for c in configs: +    print('\t\t<Configuration', file=F) +    print('\t\t\tName="%s"' % (c.name(), ), file=F) +    print('\t\t\tOutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"', file=F) +    print(r'''			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			>''', file=F) +    write_project09_unused_tools(F) +    print('\t\t\t<Tool', file=F) +    print('\t\t\t\tName="VCCLCompilerTool"', file=F) +    if c.cuda: +      print('\t\t\t\tAdditionalIncludeDirectories="$(MATLAB_ROOT)\\extern\\include\\;"$(CUDA_INC_PATH)";..\\..\\lib\\include;..\\..\\include"', file=F) +      print('\t\t\t\tPreprocessorDefinitions="ASTRA_CUDA;__SSE2__"', file=F) +    else: +      print('\t\t\t\tAdditionalIncludeDirectories="$(MATLAB_ROOT)\\extern\\include\\;..\\..\\lib\\include;..\\..\\include"', file=F) +      print('\t\t\t\tPreprocessorDefinitions="__SSE2__"', file=F) +    if c.debug: +      print(r'''				Optimization="0" +				RuntimeLibrary="3"''', file=F) +    else: +      print(r'''				Optimization="2" +				RuntimeLibrary="2"''', file=F) +    if not c.x64: # /arch:SSE2 is implicit on x64 +      print('\t\t\t\tEnableEnhancedInstructionSet="2"', file=F) # SSE2 +    print('\t\t\t\tOpenMP="true"', file=F) +    print('\t\t\t\tAdditionalOptions="/MP"', file=F) # build with multiple processes +    print('\t\t\t/>', file=F) +    print('\t\t\t<Tool', file=F) +    print('\t\t\t\tName="VCLinkerTool"', file=F) +    print('\t\t\t\tAdditionalDependencies="%s.lib libmex.lib libmx.lib libut.lib"' % (c.target(), ), file=F) +    if c.x64: +      print('\t\t\t\tOutputFile="$(OutDir)\\$(ProjectName)_c.mexw64"', file=F) +    else: +      print('\t\t\t\tOutputFile="$(OutDir)\\$(ProjectName)_c.mexw32"', file=F) +    if c.x64: +      print('\t\t\t\tAdditionalLibraryDirectories="..\\..\\bin\\x64;$(MATLAB_ROOT)\\extern\\lib\\win64\\microsoft;..\\..\\lib\\x64"', file=F) +    else: +      print('\t\t\t\tAdditionalLibraryDirectories="..\\..\\bin\\win32;$(MATLAB_ROOT)\\extern\\lib\\win32\\microsoft;..\\..\\lib\\win32"', file=F) +    print('\t\t\t\tModuleDefinitionFile="mex.def"', file=F) +    if c.debug: +      print('\t\t\t\tGenerateDebugInformation="true"', file=F) +    else: +      print('\t\t\t\tGenerateDebugInformation="false"', file=F) +    if c.x64: +      print('\t\t\t\tTargetMachine="17"', file=F) # x64 +    else: +      print('\t\t\t\tTargetMachine="1"', file=F) # x86 +    print('\t\t\t/>', file=F) +    print('\t\t</Configuration>', file=F) +  print('\t</Configurations>', file=F) +  print('\t<References>', file=F) +  print('\t</References>', file=F) +  print('\t<Files>', file=F) +  for f in P["files"]: +    print('\t\t<File', file=F) +    print('\t\t\tRelativePath=".\\%s"' % (f, ), file=F) +    print('\t\t\t>', file=F) +    print('\t\t</File>', file=F) +  print('\t</Files>', file=F) +  print('\t<Globals>', file=F) +  print('\t</Globals>', file=F) +  print('</VisualStudioProject>', file=F) + + + +if (len(sys.argv) != 2) or (sys.argv[1] not in ["vc09", "vc11", "all"]): +  print("Usage: python gen.py [vc09|vc11|all]", file=sys.stderr) +  sys.exit(1) + + + +try: +  open("../../src/AstraObjectManager.cpp", "r") +except IOError: +  print("Run gen.py from the build/msvc directory", file=sys.stderr) +  sys.exit(1) + +# Change directory to main dir +os.chdir("../..") + +if sys.argv[1] in ["vc11", "all"]: +  # HACK +  P_astra["name"] = "astra_vc11" +  write_sln(11) +  write_main_project11() +  write_main_filters11() +  write_mex_project11(P0) +  write_mex_project11(P1) +  write_mex_project11(P2) +  write_mex_project11(P3) +  write_mex_project11(P4) +  write_mex_project11(P5) +  write_mex_project11(P6) +  write_mex_project11(P7) + +if sys.argv[1] in ["vc09", "all"]: +  # HACK +  P_astra["name"] = "astra" + +  write_sln(9) +  write_main_project09() +  write_mex_project09(P0) +  write_mex_project09(P1) +  write_mex_project09(P2) +  write_mex_project09(P3) +  write_mex_project09(P4) +  write_mex_project09(P5) +  write_mex_project09(P6) +  write_mex_project09(P7) diff --git a/cuda/2d/astra.cu b/cuda/2d/astra.cu index dc16a56..379c690 100644 --- a/cuda/2d/astra.cu +++ b/cuda/2d/astra.cu @@ -42,12 +42,13 @@ $Id$  #include <fstream>  #include <cuda.h> -#include "../../include/astra/Logger.h"  #include "../../include/astra/VolumeGeometry2D.h"  #include "../../include/astra/ParallelProjectionGeometry2D.h"  #include "../../include/astra/FanFlatProjectionGeometry2D.h"  #include "../../include/astra/FanFlatVecProjectionGeometry2D.h" +#include "../../include/astra/Logging.h" +  // For fan beam FBP weighting  #include "../3d/fdk.h" @@ -538,7 +539,7 @@ bool AstraFBP::setFilter(E_FBPFILTER _eFilter, const float * _pfHostFilter /* =  			int iMaxFilterIndex = iStartFilterIndex + iUsedFilterWidth;  			int iFilterShiftSize = _iFilterWidth / 2; -			 +  			for(int iDetectorIndex = iStartFilterIndex; iDetectorIndex < iMaxFilterIndex; iDetectorIndex++)  			{  				int iFFTInFilterIndex = (iDetectorIndex + iFFTRealDetCount - iFilterShiftSize) % iFFTRealDetCount; @@ -563,7 +564,7 @@ bool AstraFBP::setFilter(E_FBPFILTER _eFilter, const float * _pfHostFilter /* =  		}  		default:  		{ -			fprintf(stderr, "AstraFBP::setFilter: Unknown filter type requested"); +			ASTRA_ERROR("AstraFBP::setFilter: Unknown filter type requested");  			delete [] pHostFilter;  			return false;  		} diff --git a/cuda/2d/darthelper.cu b/cuda/2d/darthelper.cu index 28ca557..1d10d49 100644 --- a/cuda/2d/darthelper.cu +++ b/cuda/2d/darthelper.cu @@ -57,7 +57,7 @@ void roiSelect(float* out, float radius, unsigned int width, unsigned int height  	// We abuse dims here...  	SDimensions dims;  	dims.iVolWidth = width; -	dims.iVolHeight = width; +	dims.iVolHeight = height;  	allocateVolumeData(D_data, pitch, dims);  	copyVolumeToDevice(out, width, dims, D_data, pitch); @@ -245,7 +245,7 @@ void dartMask(float* mask, const float* segmentation, unsigned int conn, unsigne  	// We abuse dims here...  	SDimensions dims;  	dims.iVolWidth = width; -	dims.iVolHeight = width; +	dims.iVolHeight = height;  	allocateVolumeData(D_segmentationData, pitch, dims);  	copyVolumeToDevice(segmentation, width, dims, D_segmentationData, pitch); @@ -278,7 +278,7 @@ __global__ void devDartSmoothingRadius(float* out, const float* in, float b, uns  	unsigned int x = threadIdx.x + 16*blockIdx.x;  	unsigned int y = threadIdx.y + 16*blockIdx.y; -	// Sacrifice the border pixels to simplify the implementation.  +	// Sacrifice the border pixels to simplify the implementation.  	if (x > radius-1 && x < width - radius && y > radius-1 && y < height - radius)  	{  		float* d = (float*)in; @@ -286,9 +286,10 @@ __global__ void devDartSmoothingRadius(float* out, const float* in, float b, uns  		unsigned int o2 = y*pitch+x;  		int r = radius; +                float count = 4*r*(r+1);  		float res = -d[o2]; -		for (int row = -r; row < r; row++)  +		for (int row = -r; row <= r; row++)   		{  			unsigned int o1 = (y+row)*pitch+x;   			for (int col = -r; col <= r; col++)  @@ -297,7 +298,7 @@ __global__ void devDartSmoothingRadius(float* out, const float* in, float b, uns  			}  		} -		res *= b / 4*r*(r+1); +		res *= b / count;  		res += (1.0f-b) * d[o2];  		m[o2] = res; @@ -333,7 +334,7 @@ void dartSmoothing(float* out, const float* in, float b, unsigned int radius, un  	// We abuse dims here...  	SDimensions dims;  	dims.iVolWidth = width; -	dims.iVolHeight = width; +	dims.iVolHeight = height;  	allocateVolumeData(D_inData, pitch, dims);  	copyVolumeToDevice(in, width, dims, D_inData, pitch); diff --git a/cuda/2d/fft.cu b/cuda/2d/fft.cu index d105e29..2bfd493 100644 --- a/cuda/2d/fft.cu +++ b/cuda/2d/fft.cu @@ -34,7 +34,7 @@ $Id$  #include <cuda.h>  #include <fstream> -#include "../../include/astra/Logger.h" +#include "../../include/astra/Logging.h"  using namespace astra; @@ -43,25 +43,22 @@ using namespace astra;  #define CHECK_ERROR(errorMessage) do {                                     \    cudaError_t err = cudaThreadSynchronize();                               \    if( cudaSuccess != err) {                                                \ -      fprintf(stderr, "Cuda error: %s in file '%s' in line %i : %s.\n",    \ -              errorMessage, __FILE__, __LINE__, cudaGetErrorString( err) );\ -			  CLogger::writeTerminalCUDAError(__FILE__, __LINE__, cudaGetErrorString( err)); \ +      ASTRA_ERROR("Cuda error %s : %s",                                    \ +              errorMessage,cudaGetErrorString( err));                      \        exit(EXIT_FAILURE);                                                  \    } } while (0)  #define SAFE_CALL( call) do {                                              \    cudaError err = call;                                                    \    if( cudaSuccess != err) {                                                \ -      fprintf(stderr, "Cuda error in file '%s' in line %i : %s.\n",        \ -              __FILE__, __LINE__, cudaGetErrorString( err) );              \ -	  CLogger::writeTerminalCUDAError(__FILE__, __LINE__, cudaGetErrorString( err)); \ +      ASTRA_ERROR("Cuda error: %s ",                                       \ +              cudaGetErrorString( err));                                   \        exit(EXIT_FAILURE);                                                  \    }                                                                        \    err = cudaThreadSynchronize();                                           \    if( cudaSuccess != err) {                                                \ -      fprintf(stderr, "Cuda error in file '%s' in line %i : %s.\n",        \ -              __FILE__, __LINE__, cudaGetErrorString( err) );              \ -	  CLogger::writeTerminalCUDAError(__FILE__, __LINE__, cudaGetErrorString( err)); \ +      ASTRA_ERROR("Cuda error: %s : ",                                     \ +              cudaGetErrorString( err));                                   \        exit(EXIT_FAILURE);                                                  \    } } while (0) @@ -140,7 +137,7 @@ static bool invokeCudaFFT(int _iProjectionCount, int _iDetectorCount,  	result = cufftPlan1d(&plan, _iDetectorCount, CUFFT_R2C, _iProjectionCount);  	if(result != CUFFT_SUCCESS)  	{ -		std::cerr << "Failed to plan 1d r2c fft" << std::endl; +		ASTRA_ERROR("Failed to plan 1d r2c fft");  		return false;  	} @@ -149,7 +146,7 @@ static bool invokeCudaFFT(int _iProjectionCount, int _iDetectorCount,  	if(result != CUFFT_SUCCESS)  	{ -		std::cerr << "Failed to exec 1d r2c fft" << std::endl; +		ASTRA_ERROR("Failed to exec 1d r2c fft");  		return false;  	} @@ -166,18 +163,18 @@ static bool invokeCudaIFFT(int _iProjectionCount, int _iDetectorCount,  	result = cufftPlan1d(&plan, _iDetectorCount, CUFFT_C2R, _iProjectionCount);  	if(result != CUFFT_SUCCESS)  	{ -		std::cerr << "Failed to plan 1d c2r fft" << std::endl; +		ASTRA_ERROR("Failed to plan 1d c2r fft");  		return false;  	}  	// todo: why do we have to get rid of the const qualifier?  	result = cufftExecC2R(plan, (cufftComplex *)_pDevSourceComplex, -                          (cufftReal *)_pfDevTarget); +	                      (cufftReal *)_pfDevTarget);  	cufftDestroy(plan);  	if(result != CUFFT_SUCCESS)  	{ -		std::cerr << "Failed to exec 1d c2r fft" << std::endl; +		ASTRA_ERROR("Failed to exec 1d c2r fft");  		return false;  	} @@ -257,7 +254,7 @@ bool runCudaIFFT(int _iProjectionCount, const cufftComplex* _pDevSourceComplex,  	}  	rescaleInverseFourier(_iProjectionCount, _iFFTRealDetectorCount, -                          pfDevRealFFTTarget); +	                      pfDevRealFFTTarget);  	SAFE_CALL(cudaMemset(_pfRealTarget, 0, sizeof(float) * _iProjectionCount * _iTargetPitch)); @@ -460,7 +457,7 @@ void genFilter(E_FBPFILTER _eFilter, float _fD, int _iProjectionCount,  			const float fA1 = 0.48f;  			const float fA2 = 0.38f;  			float fNMinusOne = (float)(_iFFTFourierDetectorCount) - 1.0f; -			 +  			for(int iDetectorIndex = 1; iDetectorIndex < _iFFTFourierDetectorCount; iDetectorIndex++)  			{  				float fSmallN = (float)iDetectorIndex; @@ -633,7 +630,7 @@ void genFilter(E_FBPFILTER _eFilter, float _fD, int _iProjectionCount,  		}  		default:  		{ -			std::cerr << "Cannot serve requested filter" << std::endl; +			ASTRA_ERROR("Cannot serve requested filter");  		}  	} @@ -746,7 +743,7 @@ void testCudaFFT()  	{  		for(int iDetectorIndex = 0; iDetectorIndex < iDetectorCount; iDetectorIndex++)  		{ -//			int  +//			int  //			pfHostProj[iIndex] = (float)rand() / (float)RAND_MAX;  		} @@ -767,13 +764,13 @@ void testCudaFFT()  	result = cufftPlan1d(&plan, iDetectorCount, CUFFT_R2C, iProjectionCount);  	if(result != CUFFT_SUCCESS)  	{ -		cerr << "Failed to plan 1d r2c fft" << endl; +		ASTRA_ERROR("Failed to plan 1d r2c fft");  	}  	result = cufftExecR2C(plan, pfDevProj, pDevFourProj);  	if(result != CUFFT_SUCCESS)  	{ -		cerr << "Failed to exec 1d r2c fft" << endl; +		ASTRA_ERROR("Failed to exec 1d r2c fft");  	}  	cufftDestroy(plan); @@ -787,7 +784,7 @@ void testCudaFFT()  	float * pfHostFourProjImaginary = new float[iTotalElementCount];  	convertComplexToRealImg(pHostFourProj, iTotalElementCount, pfHostFourProjReal, pfHostFourProjImaginary); -	 +  	writeToMatlabFile("proj_four_real.mat", pfHostFourProjReal, iProjectionCount, iDetectorCount);  	writeToMatlabFile("proj_four_imaginary.mat", pfHostFourProjImaginary, iProjectionCount, iDetectorCount); @@ -797,13 +794,13 @@ void testCudaFFT()  	result = cufftPlan1d(&plan, iDetectorCount, CUFFT_C2R, iProjectionCount);  	if(result != CUFFT_SUCCESS)  	{ -		cerr << "Failed to plan 1d c2r fft" << endl; +		ASTRA_ERROR("Failed to plan 1d c2r fft");  	}  	result = cufftExecC2R(plan, pDevFourProj, pfDevInFourProj);  	if(result != CUFFT_SUCCESS)  	{ -		cerr << "Failed to exec 1d c2r fft" << endl; +		ASTRA_ERROR("Failed to exec 1d c2r fft");  	}  	cufftDestroy(plan); diff --git a/cuda/2d/par_fp.cu b/cuda/2d/par_fp.cu index d0ca7ff..bb8b909 100644 --- a/cuda/2d/par_fp.cu +++ b/cuda/2d/par_fp.cu @@ -487,7 +487,7 @@ bool FP_simple_internal(float* D_volumeData, unsigned int volumePitch,  	unsigned int blockEnd = 0;  	bool blockVertical = false;  	for (unsigned int a = 0; a <= dims.iProjAngles; ++a) { -		bool vertical; +		bool vertical = false;  		// TODO: Having <= instead of < below causes a 5% speedup.  		// Maybe we should detect corner cases and put them in the optimal  		// group of angles. diff --git a/cuda/2d/util.cu b/cuda/2d/util.cu index 81e368f..a4f8f3e 100644 --- a/cuda/2d/util.cu +++ b/cuda/2d/util.cu @@ -30,6 +30,8 @@ $Id$  #include <cassert>  #include "util.h" +#include "../../include/astra/Logging.h" +  namespace astraCUDA {  bool copyVolumeToDevice(const float* in_data, unsigned int in_pitch, @@ -91,7 +93,7 @@ bool allocateVolume(float*& ptr, unsigned int width, unsigned int height, unsign  	cudaError_t ret = cudaMallocPitch((void**)&ptr, &p, sizeof(float)*width, height);  	if (ret != cudaSuccess) {  		reportCudaError(ret); -		fprintf(stderr, "Failed to allocate %dx%d GPU buffer\n", width, height); +		ASTRA_ERROR("Failed to allocate %dx%d GPU buffer", width, height);  		return false;  	} @@ -259,7 +261,7 @@ bool cudaTextForceKernelsCompletion()  	cudaError_t returnedCudaError = cudaThreadSynchronize();  	if(returnedCudaError != cudaSuccess) { -		fprintf(stderr, "Failed to force completion of cuda kernels: %d: %s.\n", returnedCudaError, cudaGetErrorString(returnedCudaError)); +		ASTRA_ERROR("Failed to force completion of cuda kernels: %d: %s.", returnedCudaError, cudaGetErrorString(returnedCudaError));  		return false;  	} @@ -269,7 +271,7 @@ bool cudaTextForceKernelsCompletion()  void reportCudaError(cudaError_t err)  {  	if(err != cudaSuccess) -		fprintf(stderr, "CUDA error %d: %s.\n", err, cudaGetErrorString(err)); +		ASTRA_ERROR("CUDA error %d: %s.", err, cudaGetErrorString(err));  } diff --git a/cuda/3d/cone_fp.cu b/cuda/3d/cone_fp.cu index bda71ba..b36d2bc 100644 --- a/cuda/3d/cone_fp.cu +++ b/cuda/3d/cone_fp.cu @@ -340,7 +340,7 @@ bool ConeFP_Array_internal(cudaPitchedPtr D_projData,  	// tic(t);  	for (unsigned int a = 0; a <= angleCount; ++a) { -		int dir; +		int dir = -1;  		if (a != angleCount) {  			float dX = fabsf(angles[a].fSrcX - (angles[a].fDetSX + dims.iProjU*angles[a].fDetUX*0.5f + dims.iProjV*angles[a].fDetVX*0.5f));  			float dY = fabsf(angles[a].fSrcY - (angles[a].fDetSY + dims.iProjU*angles[a].fDetUY*0.5f + dims.iProjV*angles[a].fDetVY*0.5f)); diff --git a/cuda/3d/par3d_fp.cu b/cuda/3d/par3d_fp.cu index 8d44540..b14c494 100644 --- a/cuda/3d/par3d_fp.cu +++ b/cuda/3d/par3d_fp.cu @@ -440,7 +440,7 @@ bool Par3DFP_Array_internal(cudaPitchedPtr D_projData,  	// tic(t);  	for (unsigned int a = 0; a <= angleCount; ++a) { -		int dir; +		int dir = -1;  		if (a != dims.iProjAngles) {  			float dX = fabsf(angles[a].fRayX);  			float dY = fabsf(angles[a].fRayY); diff --git a/cuda/3d/util3d.cu b/cuda/3d/util3d.cu index d85a928..537ed69 100644 --- a/cuda/3d/util3d.cu +++ b/cuda/3d/util3d.cu @@ -31,6 +31,8 @@ $Id$  #include "util3d.h"  #include "../2d/util.h" +#include "../../include/astra/Logging.h" +  namespace astraCUDA3d { @@ -46,7 +48,7 @@ cudaPitchedPtr allocateVolumeData(const SDimensions3D& dims)  	cudaError err = cudaMalloc3D(&volData, extentV);  	if (err != cudaSuccess) {  		astraCUDA::reportCudaError(err); -		fprintf(stderr, "Failed to allocate %dx%dx%d GPU buffer\n", dims.iVolX, dims.iVolY, dims.iVolZ); +		ASTRA_ERROR("Failed to allocate %dx%dx%d GPU buffer", dims.iVolX, dims.iVolY, dims.iVolZ);  		volData.ptr = 0;  		// TODO: return 0 somehow?  	} @@ -65,7 +67,7 @@ cudaPitchedPtr allocateProjectionData(const SDimensions3D& dims)  	cudaError err = cudaMalloc3D(&projData, extentP);  	if (err != cudaSuccess) {  		astraCUDA::reportCudaError(err); -		fprintf(stderr, "Failed to allocate %dx%dx%d GPU buffer\n", dims.iProjU, dims.iProjAngles, dims.iProjV); +		ASTRA_ERROR("Failed to allocate %dx%dx%d GPU buffer", dims.iProjU, dims.iProjAngles, dims.iProjV);  		projData.ptr = 0;  		// TODO: return 0 somehow?  	} @@ -303,7 +305,7 @@ cudaArray* allocateVolumeArray(const SDimensions3D& dims)  	cudaError err = cudaMalloc3DArray(&cuArray, &channelDesc, extentA);  	if (err != cudaSuccess) {  		astraCUDA::reportCudaError(err); -		fprintf(stderr, "Failed to allocate %dx%dx%d GPU array\n", dims.iVolX, dims.iVolY, dims.iVolZ); +		ASTRA_ERROR("Failed to allocate %dx%dx%d GPU array", dims.iVolX, dims.iVolY, dims.iVolZ);  		return 0;  	} @@ -321,7 +323,7 @@ cudaArray* allocateProjectionArray(const SDimensions3D& dims)  	if (err != cudaSuccess) {  		astraCUDA::reportCudaError(err); -		fprintf(stderr, "Failed to allocate %dx%dx%d GPU array\n", dims.iProjU, dims.iProjAngles, dims.iProjV); +		ASTRA_ERROR("Failed to allocate %dx%dx%d GPU array", dims.iProjU, dims.iProjAngles, dims.iProjV);  		return 0;  	} @@ -397,7 +399,7 @@ bool cudaTextForceKernelsCompletion()  	cudaError_t returnedCudaError = cudaThreadSynchronize();  	if(returnedCudaError != cudaSuccess) { -		fprintf(stderr, "Failed to force completion of cuda kernels: %d: %s.\n", returnedCudaError, cudaGetErrorString(returnedCudaError)); +		ASTRA_ERROR("Failed to force completion of cuda kernels: %d: %s.", returnedCudaError, cudaGetErrorString(returnedCudaError));  		return false;  	} diff --git a/include/astra/AstraObjectFactory.h b/include/astra/AstraObjectFactory.h index ba4ec11..1ed4955 100644 --- a/include/astra/AstraObjectFactory.h +++ b/include/astra/AstraObjectFactory.h @@ -110,7 +110,7 @@ template <typename T, typename TypeList>  T* CAstraObjectFactory<T, TypeList>::create(const Config& _cfg)  {  	functor_find<T> finder = functor_find<T>(); -	finder.tofind = _cfg.self->getAttribute("type"); +	finder.tofind = _cfg.self.getAttribute("type");  	CreateObject<TypeList>::find(finder);  	if (finder.res == NULL) return NULL;  	if (finder.res->initialize(_cfg)) diff --git a/include/astra/Config.h b/include/astra/Config.h index 9893c90..c10a16e 100644 --- a/include/astra/Config.h +++ b/include/astra/Config.h @@ -44,13 +44,14 @@ namespace astra {  struct _AstraExport Config {  	Config(); -	Config(XMLNode* _self); +	Config(XMLNode _self);  	~Config();  	void initialize(std::string rootname); -	XMLNode* self; -	XMLNode* global; +	XMLNode self; + +	XMLDocument *_doc;  };  struct ConfigCheckData { diff --git a/include/astra/Float32ProjectionData2D.h b/include/astra/Float32ProjectionData2D.h index 7461491..bb99f4b 100644 --- a/include/astra/Float32ProjectionData2D.h +++ b/include/astra/Float32ProjectionData2D.h @@ -101,6 +101,19 @@ public:  	 * Copy constructor  	 */  	CFloat32ProjectionData2D(const CFloat32ProjectionData2D& _other); +	 +	/** Constructor. Create an instance of the CFloat32ProjectionData2D class with pre-allocated memory. +	 * +	 * Creates an instance of the CFloat32ProjectionData2D class. Memory  +	 * is pre-allocated and passed via the abstract CFloat32CustomMemory handle +	 * class. The handle will be deleted when the memory can be freed. +	 * You should override the destructor to provide custom behaviour on free. +	 * +	 * @param _pGeometry Projection Geometry object.  This object will be HARDCOPIED into this class. +	 * @param _pCustomMemory custom memory handle +	 * +	 */ +	CFloat32ProjectionData2D(CProjectionGeometry2D* _pGeometry, CFloat32CustomMemory* _pCustomMemory);  	/**  	 * Assignment operator @@ -148,6 +161,18 @@ public:  	 * @param _fScalar scalar value to be put at each index.  	 */  	bool initialize(CProjectionGeometry2D* _pGeometry, float32 _fScalar); +	 +	/** Initialization. Initializes an instance of the CFloat32ProjectionData2D class with pre-allocated memory. +	 * +	 * Memory is pre-allocated and passed via the abstract CFloat32CustomMemory handle +	 * class. The handle will be deleted when the memory can be freed. +	 * You should override the destructor to provide custom behaviour on free. +	 * +	 * @param _pGeometry Projection Geometry object.  This object will be HARDCOPIED into this class. +	 * @param _pCustomMemory custom memory handle +	 * +	 */ +	bool initialize(CProjectionGeometry2D* _pGeometry, CFloat32CustomMemory* _pCustomMemory);  	/** Get the number of detectors.  	 * diff --git a/include/astra/Float32ProjectionData3D.h b/include/astra/Float32ProjectionData3D.h index 79b762e..329c9a4 100644 --- a/include/astra/Float32ProjectionData3D.h +++ b/include/astra/Float32ProjectionData3D.h @@ -196,6 +196,11 @@ public:  	 * @return pointer to projection geometry.  	 */  	virtual CProjectionGeometry3D* getGeometry() const; + +	/** Change the projection geometry. +	 *  Note that this can't change the dimensions of the data. +	 */ +	virtual void changeGeometry(CProjectionGeometry3D* pGeometry);  }; diff --git a/include/astra/Float32VolumeData2D.h b/include/astra/Float32VolumeData2D.h index 4f44a8c..abecebf 100644 --- a/include/astra/Float32VolumeData2D.h +++ b/include/astra/Float32VolumeData2D.h @@ -92,6 +92,19 @@ public:  	 * Copy constructor  	 */  	CFloat32VolumeData2D(const CFloat32VolumeData2D& _other); +	 +	/** Constructor. Create an instance of the CFloat32VolumeData2D class with pre-allocated memory. +	 * +	 * Creates an instance of the CFloat32VolumeData2D class. Memory  +	 * is pre-allocated and passed via the abstract CFloat32CustomMemory handle +	 * class. The handle will be deleted when the memory can be freed. +	 * You should override the destructor to provide custom behaviour on free. +	 * +	 * @param _pGeometry Volume Geometry object.  This object will be HARDCOPIED into this class. +	 * @param _pCustomMemory custom memory handle +	 * +	 */ +	CFloat32VolumeData2D(CVolumeGeometry2D* _pGeometry, CFloat32CustomMemory* _pCustomMemory);  	/**  	 * Assignment operator @@ -132,6 +145,18 @@ public:  	 * @param _fScalar scalar value to be put at each index.  	 */  	bool initialize(CVolumeGeometry2D* _pGeometry, float32 _fScalar); +	 +	/** Initialization. Initializes an instance of the CFloat32VolumeData2D class with pre-allocated memory. +	 * +	 * Memory is pre-allocated and passed via the abstract CFloat32CustomMemory handle +	 * class. The handle will be deleted when the memory can be freed. +	 * You should override the destructor to provide custom behaviour on free. +	 * +	 * @param _pGeometry Volume Geometry object.  This object will be HARDCOPIED into this class. +	 * @param _pCustomMemory custom memory handle +	 * +	 */ +	bool initialize(CVolumeGeometry2D* _pGeometry, CFloat32CustomMemory* _pCustomMemory);  	/** Destructor.  	 */ diff --git a/include/astra/Float32VolumeData3D.h b/include/astra/Float32VolumeData3D.h index d8f0ae9..07df78f 100644 --- a/include/astra/Float32VolumeData3D.h +++ b/include/astra/Float32VolumeData3D.h @@ -214,6 +214,11 @@ public:  	 * @return The geometry describing the data stored in this volume  	 */  	virtual CVolumeGeometry3D* getGeometry() const; + +	/** Change the projection geometry. +	 *  Note that this can't change the dimensions of the data. +	 */ +	virtual void changeGeometry(CVolumeGeometry3D* pGeometry);  };  //---------------------------------------------------------------------------------------- diff --git a/include/astra/Logger.h b/include/astra/Logger.h deleted file mode 100644 index 34fd364..0000000 --- a/include/astra/Logger.h +++ /dev/null @@ -1,72 +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$ -*/ - -#ifndef _INC_ASTRA_LOGGER -#define _INC_ASTRA_LOGGER - -#include <cstdio> - -namespace astra -{ - -/** - *  This is the first stab at a decent logger. If the file "astra_logger.txt", it will be replaced - *  with the text sent to this logger. If the file doesn't exist when the app starts, nothing is written. - */ -class CLogger -{ -	static std::FILE * m_pOutFile; -	static bool m_bInitialized; - -	static void _assureIsInitialized(); - -	CLogger(); - -public: - -	/** -	 * Writes a line to the log file (newline is added). Ignored if logging is turned off. -	 * -	 * @param _text char pointer to text in line -	 */ -	static void writeLine(const char * _text); - -	/** -	 * Formats and writes a CUDA error to the log file. Ignored if logging is turned off. -	 * -	 * @param _fileName filename where error occurred (typically __FILE__) -	 * @param _line line in file (typically __LINE__) -	 * @param _errString string describing the error, can be output of cudaGetErrorString -	 */ -	static void writeTerminalCUDAError(const char * _fileName, int _iLine, const char * _errString); -}; - -} - -#endif /* _INC_ASTRA_LOGGER */ - diff --git a/include/astra/Logging.h b/include/astra/Logging.h new file mode 100644 index 0000000..8e19ea4 --- /dev/null +++ b/include/astra/Logging.h @@ -0,0 +1,159 @@ +/* +----------------------------------------------------------------------- +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$ +*/ + +#ifndef _INC_ASTRA_LOGGING +#define _INC_ASTRA_LOGGING + +#include "astra/Globals.h" + +#define ASTRA_DEBUG(...) astra::CLogger::debug(__FILE__,__LINE__, __VA_ARGS__) +#define ASTRA_INFO(...) astra::CLogger::info(__FILE__,__LINE__, __VA_ARGS__) +#define ASTRA_WARN(...) astra::CLogger::warn(__FILE__,__LINE__, __VA_ARGS__) +#define ASTRA_ERROR(...) astra::CLogger::error(__FILE__,__LINE__, __VA_ARGS__) + +namespace astra +{ + +enum log_level { +    LOG_DEBUG, +    LOG_INFO, +    LOG_WARN, +    LOG_ERROR +}; + +class _AstraExport CLogger +{ +	CLogger(); +  ~CLogger(); +  static bool m_bEnabledFile; +  static bool m_bEnabledScreen; +  static bool m_bFileProvided; +  static bool m_bInitialized; +  static void _assureIsInitialized(); +  static void _setLevel(int id, log_level m_eLevel); + +public: + +	/** +	 * Writes a line to the log file (newline is added). Ignored if logging is turned off. +	 * +	 * @param sfile +   * The name of the source file making this log call (e.g. __FILE__). +   * +   * @param sline +   * The line number of the call in the source code (e.g. __LINE__). +   * +   * @param id +   * The id of the logger to write to. +   * +   * @param fmt +   * The format string for the message (printf formatting). +   * +   * @param ... +   * Any additional format arguments. +	 */ +  static void debug(const char *sfile, int sline, const char *fmt, ...); +  static void info(const char *sfile, int sline, const char *fmt, ...); +  static void warn(const char *sfile, int sline, const char *fmt, ...); +  static void error(const char *sfile, int sline, const char *fmt, ...); + +  /** +	 * Sets the file to log to, with logging level. +   * +   * @param filename +   * File to log to. +	 * +	 * @param m_eLevel +   * Logging level (LOG_DEBUG, LOG_WARN, LOG_INFO, LOG_ERROR). +   * +	 */ +  static void setOutputFile(const char *filename, log_level m_eLevel); + +  /** +	 * Sets the screen to log to, with logging level. +   * +   * @param screen_fd +   * Screen file descriptor (1 for stdout, 2 for stderr) +	 * +	 * @param m_eLevel +   * Logging level (LOG_DEBUG, LOG_WARN, LOG_INFO, LOG_ERROR). +   * +	 */ +  static void setOutputScreen(int fd, log_level m_eLevel); +   +  /** +   * Set the format string for log messages.  Here are the substitutions you may +   * use: +   * +   *     %f: Source file name generating the log call. +   *     %n: Source line number where the log call was made. +   *     %m: The message text sent to the logger (after printf formatting). +   *     %d: The current date, formatted using the logger's date format. +   *     %t: The current time, formatted using the logger's time format. +   *     %l: The log level (one of "DEBUG", "INFO", "WARN", or "ERROR"). +   *     %%: A literal percent sign. +   * +   * The default format string is "%d %t %f(%n): %l: %m\n". +   * +   * @param fmt +   * The new format string, which must be less than 256 bytes. +   * You probably will want to end this with a newline (\n). +   * +   */ +  static void setFormatFile(const char *fmt); +  static void setFormatScreen(const char *fmt); + + +  /** +   * Enable logging. +   * +   */ +  static void enable(); +  static void enableScreen(); +  static void enableFile(); + +  /** +   * Disable logging. +   * +   */ +  static void disable(); +  static void disableScreen(); +  static void disableFile(); + +  /** +   * Set callback function for logging to screen. +   * @return whether callback was set succesfully. +   * +   */ +  static bool setCallbackScreen(void (*cb)(const char *msg, size_t len)); + +}; + +} + +#endif /* _INC_ASTRA_LOGGING */ diff --git a/include/astra/ParallelBeamBlobKernelProjector2D.inl b/include/astra/ParallelBeamBlobKernelProjector2D.inl index 203eb51..1945cdd 100644 --- a/include/astra/ParallelBeamBlobKernelProjector2D.inl +++ b/include/astra/ParallelBeamBlobKernelProjector2D.inl @@ -31,21 +31,21 @@ template <typename Policy>  void CParallelBeamBlobKernelProjector2D::project(Policy& p)  {  	projectBlock_internal(0, m_pProjectionGeometry->getProjectionAngleCount(), -		                  0, m_pProjectionGeometry->getDetectorCount(), p); +						  0, m_pProjectionGeometry->getDetectorCount(), p);  }  template <typename Policy>  void CParallelBeamBlobKernelProjector2D::projectSingleProjection(int _iProjection, Policy& p)  {  	projectBlock_internal(_iProjection, _iProjection + 1, -	                      0, m_pProjectionGeometry->getDetectorCount(), p); +						  0, m_pProjectionGeometry->getDetectorCount(), p);  }  template <typename Policy>  void CParallelBeamBlobKernelProjector2D::projectSingleRay(int _iProjection, int _iDetector, Policy& p)  {  	projectBlock_internal(_iProjection, _iProjection + 1, -	                      _iDetector, _iDetector + 1, p); +						  _iDetector, _iDetector + 1, p);  }  //---------------------------------------------------------------------------------------- @@ -53,12 +53,6 @@ void CParallelBeamBlobKernelProjector2D::projectSingleRay(int _iProjection, int  template <typename Policy>  void CParallelBeamBlobKernelProjector2D::projectBlock_internal(int _iProjFrom, int _iProjTo, int _iDetFrom, int _iDetTo, Policy& p)  { -	// variables -	float32 detX, detY, x, y, c, r, update_c, update_r, offset, invBlobExtent, inv_pixelLengthX, inv_pixelLengthY, weight, d; -	int iVolumeIndex, iRayIndex, row, col, iAngle, iDetector, colCount, rowCount, detCount; -	int col_left, col_right, row_top, row_bottom, index; -	const SParProjection * proj = 0; -  	// get vector geometry  	const CParallelVecProjectionGeometry2D* pVecProjectionGeometry;  	if (dynamic_cast<CParallelProjectionGeometry2D*>(m_pProjectionGeometry)) { @@ -68,16 +62,22 @@ void CParallelBeamBlobKernelProjector2D::projectBlock_internal(int _iProjFrom, i  	}  	// precomputations -	inv_pixelLengthX = 1.0f / m_pVolumeGeometry->getPixelLengthX(); -	inv_pixelLengthY = 1.0f / m_pVolumeGeometry->getPixelLengthY(); -	colCount = m_pVolumeGeometry->getGridColCount(); -	rowCount = m_pVolumeGeometry->getGridRowCount(); -	detCount = pVecProjectionGeometry->getDetectorCount(); +	const float32 inv_pixelLengthX = 1.0f / m_pVolumeGeometry->getPixelLengthX(); +	const float32 inv_pixelLengthY = 1.0f / m_pVolumeGeometry->getPixelLengthY(); +	const int colCount = m_pVolumeGeometry->getGridColCount(); +	const int rowCount = m_pVolumeGeometry->getGridRowCount(); +	const int detCount = pVecProjectionGeometry->getDetectorCount();  	// loop angles -	for (iAngle = _iProjFrom; iAngle < _iProjTo; ++iAngle) { +	#pragma omp parallel for +	for (int iAngle = _iProjFrom; iAngle < _iProjTo; ++iAngle) { + +		// variables +		float32 detX, detY, x, y, c, r, update_c, update_r, offset, invBlobExtent, weight, d; +		int iVolumeIndex, iRayIndex, row, col, iDetector; +		int col_left, col_right, row_top, row_bottom, index; -		proj = &pVecProjectionGeometry->getProjectionVectors()[iAngle]; +		const SParProjection * proj = &pVecProjectionGeometry->getProjectionVectors()[iAngle];  		bool vertical = fabs(proj->fRayX) < fabs(proj->fRayY);  		if (vertical) { diff --git a/include/astra/ParallelBeamLineKernelProjector2D.inl b/include/astra/ParallelBeamLineKernelProjector2D.inl index dc3153d..9c58d60 100644 --- a/include/astra/ParallelBeamLineKernelProjector2D.inl +++ b/include/astra/ParallelBeamLineKernelProjector2D.inl @@ -55,12 +55,6 @@ void CParallelBeamLineKernelProjector2D::projectSingleRay(int _iProjection, int  template <typename Policy>  void CParallelBeamLineKernelProjector2D::projectBlock_internal(int _iProjFrom, int _iProjTo, int _iDetFrom, int _iDetTo, Policy& p)  { -	// variables -	float32 detX, detY, S, T, I, x, y, c, r, update_c, update_r, offset; -	float32 lengthPerRow, lengthPerCol, inv_pixelLengthX, inv_pixelLengthY, invTminSTimesLengthPerRow, invTminSTimesLengthPerCol; -	int iVolumeIndex, iRayIndex, row, col, iAngle, iDetector, colCount, rowCount, detCount; -	const SParProjection * proj = 0; -  	// get vector geometry  	const CParallelVecProjectionGeometry2D* pVecProjectionGeometry;  	if (dynamic_cast<CParallelProjectionGeometry2D*>(m_pProjectionGeometry)) { @@ -70,16 +64,22 @@ void CParallelBeamLineKernelProjector2D::projectBlock_internal(int _iProjFrom, i  	}  	// precomputations -	inv_pixelLengthX = 1.0f / m_pVolumeGeometry->getPixelLengthX(); -	inv_pixelLengthY = 1.0f / m_pVolumeGeometry->getPixelLengthY(); -	colCount = m_pVolumeGeometry->getGridColCount(); -	rowCount = m_pVolumeGeometry->getGridRowCount(); -	detCount = pVecProjectionGeometry->getDetectorCount(); +	const float32 inv_pixelLengthX = 1.0f / m_pVolumeGeometry->getPixelLengthX(); +	const float32 inv_pixelLengthY = 1.0f / m_pVolumeGeometry->getPixelLengthY(); +	const int colCount = m_pVolumeGeometry->getGridColCount(); +	const int rowCount = m_pVolumeGeometry->getGridRowCount(); +	const int detCount = pVecProjectionGeometry->getDetectorCount();  	// loop angles -	for (iAngle = _iProjFrom; iAngle < _iProjTo; ++iAngle) { +	#pragma omp parallel for +	for (int iAngle = _iProjFrom; iAngle < _iProjTo; ++iAngle) { + +		// variables +		float32 detX, detY, S, T, I, x, y, c, r, update_c, update_r, offset; +		float32 lengthPerRow, lengthPerCol, invTminSTimesLengthPerRow, invTminSTimesLengthPerCol; +		int iVolumeIndex, iRayIndex, row, col, iDetector; -		proj = &pVecProjectionGeometry->getProjectionVectors()[iAngle]; +		const SParProjection * proj = &pVecProjectionGeometry->getProjectionVectors()[iAngle];  		bool vertical = fabs(proj->fRayX) < fabs(proj->fRayY);  		if (vertical) { diff --git a/include/astra/ParallelBeamLinearKernelProjector2D.inl b/include/astra/ParallelBeamLinearKernelProjector2D.inl index 9f898ce..79b82d4 100644 --- a/include/astra/ParallelBeamLinearKernelProjector2D.inl +++ b/include/astra/ParallelBeamLinearKernelProjector2D.inl @@ -54,12 +54,6 @@ void CParallelBeamLinearKernelProjector2D::projectSingleRay(int _iProjection, in  template <typename Policy>  void CParallelBeamLinearKernelProjector2D::projectBlock_internal(int _iProjFrom, int _iProjTo, int _iDetFrom, int _iDetTo, Policy& p)  { -	// variables -	float32 detX, detY, x, y, c, r, update_c, update_r, offset; -	float32 lengthPerRow, lengthPerCol, inv_pixelLengthX, inv_pixelLengthY; -	int iVolumeIndex, iRayIndex, row, col, iAngle, iDetector, colCount, rowCount, detCount; -	const SParProjection * proj = 0; -  	// get vector geometry  	const CParallelVecProjectionGeometry2D* pVecProjectionGeometry;  	if (dynamic_cast<CParallelProjectionGeometry2D*>(m_pProjectionGeometry)) { @@ -69,16 +63,22 @@ void CParallelBeamLinearKernelProjector2D::projectBlock_internal(int _iProjFrom,  	}  	// precomputations -	inv_pixelLengthX = 1.0f / m_pVolumeGeometry->getPixelLengthX(); -	inv_pixelLengthY = 1.0f / m_pVolumeGeometry->getPixelLengthY(); -	colCount = m_pVolumeGeometry->getGridColCount(); -	rowCount = m_pVolumeGeometry->getGridRowCount(); -	detCount = pVecProjectionGeometry->getDetectorCount(); +	const float32 inv_pixelLengthX = 1.0f / m_pVolumeGeometry->getPixelLengthX(); +	const float32 inv_pixelLengthY = 1.0f / m_pVolumeGeometry->getPixelLengthY(); +	const int colCount = m_pVolumeGeometry->getGridColCount(); +	const int rowCount = m_pVolumeGeometry->getGridRowCount(); +	const int detCount = pVecProjectionGeometry->getDetectorCount();  	// loop angles -	for (iAngle = _iProjFrom; iAngle < _iProjTo; ++iAngle) { +	#pragma omp parallel for +	for (int iAngle = _iProjFrom; iAngle < _iProjTo; ++iAngle) { + +		// variables +		float32 detX, detY, x, y, c, r, update_c, update_r, offset; +		float32 lengthPerRow, lengthPerCol; +		int iVolumeIndex, iRayIndex, row, col, iDetector; -		proj = &pVecProjectionGeometry->getProjectionVectors()[iAngle]; +		const SParProjection * proj = &pVecProjectionGeometry->getProjectionVectors()[iAngle];  		bool vertical = fabs(proj->fRayX) < fabs(proj->fRayY);  		if (vertical) { diff --git a/include/astra/ParallelBeamStripKernelProjector2D.inl b/include/astra/ParallelBeamStripKernelProjector2D.inl index 31d222a..85faaa3 100644 --- a/include/astra/ParallelBeamStripKernelProjector2D.inl +++ b/include/astra/ParallelBeamStripKernelProjector2D.inl @@ -52,13 +52,6 @@ void CParallelBeamStripKernelProjector2D::projectSingleRay(int _iProjection, int  template <typename Policy>  void CParallelBeamStripKernelProjector2D::projectBlock_internal(int _iProjFrom, int _iProjTo, int _iDetFrom, int _iDetTo, Policy& p)  { -	// variables -	float32 detLX, detLY, detRX, detRY, S, T, update_c, update_r, offsetL, offsetR, invTminS; -	float32 inv_pixelLengthX, inv_pixelLengthY, pixelArea, res, fRxOverRy, fRyOverRx; -	int iVolumeIndex, iRayIndex, iAngle, iDetector; -	int row, row_top, row_bottom, col, col_left, col_right, colCount, rowCount, detCount; -	const SParProjection * proj = 0; -	  	// get vector geometry  	const CParallelVecProjectionGeometry2D* pVecProjectionGeometry;  	if (dynamic_cast<CParallelProjectionGeometry2D*>(m_pProjectionGeometry)) { @@ -68,17 +61,24 @@ void CParallelBeamStripKernelProjector2D::projectBlock_internal(int _iProjFrom,  	}  	// precomputations -	inv_pixelLengthX = 1.0f / m_pVolumeGeometry->getPixelLengthX(); -	inv_pixelLengthY = 1.0f / m_pVolumeGeometry->getPixelLengthY(); -	pixelArea = m_pVolumeGeometry->getPixelLengthX() * m_pVolumeGeometry->getPixelLengthY(); -	colCount = m_pVolumeGeometry->getGridColCount(); -	rowCount = m_pVolumeGeometry->getGridRowCount(); -	detCount = pVecProjectionGeometry->getDetectorCount(); +	const float32 inv_pixelLengthX = 1.0f / m_pVolumeGeometry->getPixelLengthX(); +	const float32 inv_pixelLengthY = 1.0f / m_pVolumeGeometry->getPixelLengthY(); +	const float32 pixelArea = m_pVolumeGeometry->getPixelLengthX() * m_pVolumeGeometry->getPixelLengthY(); +	const int colCount = m_pVolumeGeometry->getGridColCount(); +	const int rowCount = m_pVolumeGeometry->getGridRowCount(); +	const int detCount = pVecProjectionGeometry->getDetectorCount();  	// loop angles -	for (iAngle = _iProjFrom; iAngle < _iProjTo; ++iAngle) { +	#pragma omp parallel for +	for (int iAngle = _iProjFrom; iAngle < _iProjTo; ++iAngle) { + +		// variables +		float32 detLX, detLY, detRX, detRY, S, T, update_c, update_r, offsetL, offsetR, invTminS; +		float32 res, fRxOverRy, fRyOverRx; +		int iVolumeIndex, iRayIndex, iDetector; +		int row, row_top, row_bottom, col, col_left, col_right; -		proj = &pVecProjectionGeometry->getProjectionVectors()[iAngle]; +		const SParProjection * proj = &pVecProjectionGeometry->getProjectionVectors()[iAngle];  		bool vertical = fabs(proj->fRayX) < fabs(proj->fRayY);  		if (vertical) { diff --git a/include/astra/XMLDocument.h b/include/astra/XMLDocument.h index 869e1a3..eddd908 100644 --- a/include/astra/XMLDocument.h +++ b/include/astra/XMLDocument.h @@ -78,7 +78,7 @@ public:  	 *  	 * @return first XML node of the document  	 */ -	XMLNode* getRootNode(); +	XMLNode getRootNode();  	/** Save an XML DOM tree to an XML file  	 * diff --git a/include/astra/XMLNode.h b/include/astra/XMLNode.h index eceffe1..4d29d5c 100644 --- a/include/astra/XMLNode.h +++ b/include/astra/XMLNode.h @@ -64,71 +64,68 @@ public:  	/** Deconstructor  	 */  	~XMLNode(); -	 + +	/** Check validity +	 */ +	operator bool() const { return fDOMElement != 0; }  	/** Get a single child XML node. If there are more, the first one is returned  	 *  	 * @param _sName tagname of the requested child node  	 * @return first child node with the correct tagname, null pointer if it doesn't exist  	 */ -	XMLNode* getSingleNode(string _sName); +	XMLNode getSingleNode(string _sName) const;  	/** Get all child XML nodes that have the tagname name  	 *   	 * @param _sName tagname of the requested child nodes  	 * @return list with all child nodes with the correct tagname  	 */ -	std::list<XMLNode*> getNodes(string _sName); +	std::list<XMLNode> getNodes(string _sName) const;  	/** Get all child XML nodes  	 *   	 * @return list with all child nodes   	 */ -	std::list<XMLNode*> getNodes(); +	std::list<XMLNode> getNodes() const;  	/** Get the name of this node  	 *   	 * @return name of node  	 */ -	std::string getName(); +	std::string getName() const;  	/** Get the content of the XML node as a single string.  	 *  	 * @return node content  	 */  -	string getContent(); +	string getContent() const;  	/** Get the content of the XML node as a numerical.  	 *  	 * @return node content  	 */  -	float32 getContentNumerical(); +	float32 getContentNumerical() const;  	/** Get the content of the XML node as a boolean.  	 *  	 * @return node content  	 */  -	bool getContentBool(); +	bool getContentBool() const;  	/** Get the content of the XML node as a vector of strings.  	 *  	 * @return node content  	 */  -	vector<string> getContentArray(); - -	/** Get the content of the XML node as a c-array of float32 data. -	 * -	 * @param _pfData data array, shouldn't be initialized already. -	 * @param _iSize number of elements stored in _pfData -	 */  -	void getContentNumericalArray(float32*& _pfData, int& _iSize); +	vector<string> getContentArray() const;  	/** Get the content of the XML node as a stl container of float32 data. +	 *  NB: A 2D matrix is returned as a linear list  	 *  	 * @return node content  	 */  -	vector<float32> getContentNumericalArray(); -	vector<double> getContentNumericalArrayDouble(); +	vector<float32> getContentNumericalArray() const; +	vector<double> getContentNumericalArrayDouble() const; @@ -137,7 +134,7 @@ public:  	 * @param _sName of the attribute.  	 * @return attribute value, empty string if it doesn't exist.  	 */  -	bool hasAttribute(string _sName); +	bool hasAttribute(string _sName) const;  	/** Get the value of an attribute.  	 * @@ -145,7 +142,7 @@ public:  	 * @param _sDefaultValue value to return if the attribute isn't found  	 * @return attribute value, _sDefaultValue if it doesn't exist.  	 */  -	string getAttribute(string _sName, string _sDefaultValue = ""); +	string getAttribute(string _sName, string _sDefaultValue = "") const;  	/** Get the value of a numerical attribute.  	 * @@ -153,8 +150,8 @@ public:  	 * @param _fDefaultValue value to return if the attribute isn't found  	 * @return attribute value, _fDefaultValue if it doesn't exist.  	 */  -	float32 getAttributeNumerical(string _sName, float32 _fDefaultValue = 0); -	double getAttributeNumericalDouble(string _sName, double _fDefaultValue = 0); +	float32 getAttributeNumerical(string _sName, float32 _fDefaultValue = 0) const; +	double getAttributeNumericalDouble(string _sName, double _fDefaultValue = 0) const;  	/** Get the value of a boolean attribute.  	 * @@ -162,7 +159,7 @@ public:  	 * @param _bDefaultValue value to return if the attribute isn't found  	 * @return attribute value, _bDefaultValue if it doesn't exist.  	 */  -	bool getAttributeBool(string _sName, bool _bDefaultValue = false); +	bool getAttributeBool(string _sName, bool _bDefaultValue = false) const; @@ -172,7 +169,7 @@ public:  	 * @param _sKey option key  	 * @return true if option does exist  	 */  -	bool hasOption(string _sKey); +	bool hasOption(string _sKey) const;  	/** Get the value of an option within this XML Node  	 * @@ -180,7 +177,7 @@ public:  	 * @param _sDefaultValue value to return if key isn't found  	 * @return option value, _sDefaultValue if the option doesn't exist  	 */  -	string getOption(string _sKey, string _sDefaultValue = ""); +	string getOption(string _sKey, string _sDefaultValue = "") const;  	/** Get the value of an option within this XML Node  	 * @@ -188,7 +185,7 @@ public:  	 * @param _fDefaultValue value to return if key isn't found  	 * @return option value, _fDefaultValue if the option doesn't exist  	 */  -	float32 getOptionNumerical(string _sKey, float32 _fDefaultValue = 0); +	float32 getOptionNumerical(string _sKey, float32 _fDefaultValue = 0) const;  	/** Get the value of an option within this XML Node  	 * @@ -196,14 +193,14 @@ public:  	 * @param _bDefaultValue value to return if key isn't found  	 * @return option value, _bDefaultValue if the option doesn't exist  	 */  -	bool getOptionBool(string _sKey, bool _bDefaultValue = false); +	bool getOptionBool(string _sKey, bool _bDefaultValue = false) const;  	/** Get the value of an option within this XML Node  	 *  	 * @param _sKey option key  	 * @return numerical array  	 */  -	vector<float32> getOptionNumericalArray(string _sKey); +	vector<float32> getOptionNumericalArray(string _sKey) const; @@ -214,7 +211,7 @@ public:  	 * @param _sNodeName the name of the new childnode  	 * @return new child node  	 */  -	XMLNode* addChildNode(string _sNodeName); +	XMLNode addChildNode(string _sNodeName);  	/** Create a new XML node as a child to this one, also add some content:   	 * <...><_sNodeName>_sValue</_sNodeName></...> @@ -223,7 +220,7 @@ public:  	 * @param _sValue some node content  	 * @return new child node  	 */  -	XMLNode* addChildNode(string _sNodeName, string _sValue); +	XMLNode addChildNode(string _sNodeName, string _sValue);  	/** Create a new XML node as a child to this one, also add some numerical content:   	 * <...><_sNodeName>_sValue</_sNodeName></...> @@ -232,7 +229,7 @@ public:  	 * @param _fValue some node content  	 * @return new child node  	 */  -	XMLNode* addChildNode(string _sNodeName, float32 _fValue); +	XMLNode addChildNode(string _sNodeName, float32 _fValue);  	/** Create a new XML node as a child to this one, also add a list of numerical content:   	 * <...><_sNodeName>_sValue</_sNodeName></...> @@ -242,7 +239,7 @@ public:  	 * @param _iSize number of elements in _pfList  	 * @return new child node  	 */  -	XMLNode* addChildNode(string _sNodeName, float32* _pfList, int _iSize); +	XMLNode addChildNode(string _sNodeName, float32* _pfList, int _iSize);  	/** Add some text to the node: <...>_sText</...>  	 * @@ -256,13 +253,38 @@ public:  	 */   	void setContent(float32 _fValue); -	/** Add a list of numerical data to the node: <...>_sText</...> +	/** Add a list of numerical data to the node  	 *  	 * @param _pfList data  	 * @param _iSize number of elements in the list  	 */   	void setContent(float32* _pfList, int _iSize); +	/** Add a list of numerical data to the node +	 * +	 * @param _pfList data +	 * @param _iSize number of elements in the list +	 */ +	void setContent(double* _pfList, int _iSize); + +	/** Add a (2D) matrix of numerical data to the node +	 * +	 * @param _pfMatrix data +	 * @param _iWidth width of the matrix +	 * @param _iHeight height of the matrix +	 * @param transposed true is C order, false is Fortran order +	 */ +	void setContent(float32* _pfMatrix, int _iWidth, int _iHeight, bool transposed); + +	/** Add a (2D) matrix of numerical data to the node +	 * +	 * @param _pfMatrix data +	 * @param _iWidth width of the matrix +	 * @param _iHeight height of the matrix +	 * @param transposed true is C order, false is Fortran order +	 */ +	void setContent(double* _pfMatrix, int _iWidth, int _iHeight, bool transposed); +  	/** Add an attribute to this node: <... _sName="_sValue">  	 *  	 * @param _sName name of the attribute @@ -294,11 +316,11 @@ public:  	/** Print to String  	 */ -	std::string toString(); +	std::string toString() const;  	/** Print the node  	 */  -	void print(); +	void print() const;  protected: diff --git a/include/astra/clog.h b/include/astra/clog.h new file mode 100644 index 0000000..6ffb660 --- /dev/null +++ b/include/astra/clog.h @@ -0,0 +1,693 @@ +/* clog: Extremely simple logger for C. + * + * Features: + * - Implemented purely as a single header file. + * - Create multiple loggers. + * - Four log levels (debug, info, warn, error). + * - Custom formats. + * - Fast. + * + * Dependencies: + * - Should conform to C89, C++98 (but requires vsnprintf, unfortunately). + * - POSIX environment. + * + * USAGE: + * + * Include this header in any file that wishes to write to logger(s).  In + * exactly one file (per executable), define CLOG_MAIN first (e.g. in your + * main .c file). + * + *     #define CLOG_MAIN + *     #include "clog.h" + * + * This will define the actual objects that all the other units will use. + * + * Loggers are identified by integers (0 - 15).  It's expected that you'll + * create meaningful constants and then refer to the loggers as such. + * + * Example: + * + *  const int MY_LOGGER = 0; + * + *  int main() { + *      int r; + *      r = clog_init_path(MY_LOGGER, "my_log.txt"); + *      if (r != 0) { + *          fprintf(stderr, "Logger initialization failed.\n"); + *          return 1; + *      } + *      clog_info(CLOG(MY_LOGGER), "Hello, world!"); + *      clog_free(MY_LOGGER); + *      return 0; + *  } + * + * The CLOG macro used in the call to clog_info is a helper that passes the + * __FILE__ and __LINE__ parameters for you, so you don't have to type them + * every time. (It could be prettier with variadic macros, but that requires + * C99 or C++11 to be standards compliant.) + * + * Errors encountered by clog will be printed to stderr.  You can suppress + * these by defining a macro called CLOG_SILENT before including clog.h. + * + * License: Do whatever you want. It would be nice if you contribute + * improvements as pull requests here: + * + *   https://github.com/mmueller/clog + * + * Copyright 2013 Mike Mueller <mike@subfocal.net>. + * + * As is; no warranty is provided; use at your own risk. + */ + +#ifndef __CLOG_H__ +#define __CLOG_H__ + +#include <sys/types.h> +#include <sys/stat.h> +#include <errno.h> +#include <fcntl.h> +#include <stdarg.h> +#include <stdlib.h> +#include <stdio.h> +#include <string.h> +#include <time.h> +#ifndef _MSC_VER +#include <unistd.h> +#else +#define WIN32_LEAN_AND_MEAN +#include <windows.h> +#include <io.h> +#define open _open +#define close _close +#define write _write +#define snprintf _snprintf +#endif + +/* Number of loggers that can be defined. */ +#define CLOG_MAX_LOGGERS 16 + +/* Format strings cannot be longer than this. */ +#define CLOG_FORMAT_LENGTH 256 + +/* Formatted times and dates should be less than this length. If they are not, + * they will not appear in the log. */ +#define CLOG_DATETIME_LENGTH 256 + +/* Default format strings. */ +#define CLOG_DEFAULT_FORMAT "%d %t %f(%n): %l: %m\n" +#define CLOG_DEFAULT_DATE_FORMAT "%Y-%m-%d" +#define CLOG_DEFAULT_TIME_FORMAT "%H:%M:%S" + +#ifdef __cplusplus +extern "C" { +#endif + +enum clog_level { +    CLOG_DEBUG, +    CLOG_INFO, +    CLOG_WARN, +    CLOG_ERROR +}; + +struct clog; + +/** + * Create a new logger writing to the given file path.  The file will always + * be opened in append mode. + * + * @param id + * A constant integer between 0 and 15 that uniquely identifies this logger. + * + * @param path + * Path to the file where log messages will be written. + * + * @return + * Zero on success, non-zero on failure. + */ +int clog_init_path(int id, const char *const path); + +/** + * Create a new logger writing to a file descriptor. + * + * @param id + * A constant integer between 0 and 15 that uniquely identifies this logger. + * + * @param fd + * The file descriptor where log messages will be written. + * + * @return + * Zero on success, non-zero on failure. + */ +int clog_init_fd(int id, int fd); + +/** + * Destroy (clean up) a logger.  You should do this at the end of execution, + * or when you are done using the logger. + * + * @param id + * The id of the logger to destroy. + */ +void clog_free(int id); + +#define CLOG(id) __FILE__, __LINE__, id + +/** + * Log functions (one per level).  Call these to write messages to the log + * file.  The first three arguments can be replaced with a call to the CLOG + * macro defined above, e.g.: + * + *     clog_debug(CLOG(MY_LOGGER_ID), "This is a log message."); + * + * @param sfile + * The name of the source file making this log call (e.g. __FILE__). + * + * @param sline + * The line number of the call in the source code (e.g. __LINE__). + * + * @param id + * The id of the logger to write to. + * + * @param fmt + * The format string for the message (printf formatting). + * + * @param ... + * Any additional format arguments. + */ +void clog_debug(const char *sfile, int sline, int id, const char *fmt, va_list ap); +void clog_info(const char *sfile, int sline, int id, const char *fmt, va_list ap); +void clog_warn(const char *sfile, int sline, int id, const char *fmt, va_list ap); +void clog_error(const char *sfile, int sline, int id, const char *fmt, va_list ap); + +/** + * Set the minimum level of messages that should be written to the log. + * Messages below this level will not be written.  By default, loggers are + * created with level == CLOG_DEBUG. + * + * @param id + * The identifier of the logger. + * + * @param level + * The new minimum log level. + * + * @return + * Zero on success, non-zero on failure. + */ +int clog_set_level(int id, enum clog_level level); + +/** + * Set the format string used for times.  See strftime(3) for how this string + * should be defined.  The default format string is CLOG_DEFAULT_TIME_FORMAT. + * + * @param fmt + * The new format string, which must be less than CLOG_FORMAT_LENGTH bytes. + * + * @return + * Zero on success, non-zero on failure. + */ +int clog_set_time_fmt(int id, const char *fmt); + +/** + * Set the format string used for dates.  See strftime(3) for how this string + * should be defined.  The default format string is CLOG_DEFAULT_DATE_FORMAT. + * + * @param fmt + * The new format string, which must be less than CLOG_FORMAT_LENGTH bytes. + * + * @return + * Zero on success, non-zero on failure. + */ +int clog_set_date_fmt(int id, const char *fmt); + +/** + * Set the format string for log messages.  Here are the substitutions you may + * use: + * + *     %f: Source file name generating the log call. + *     %n: Source line number where the log call was made. + *     %m: The message text sent to the logger (after printf formatting). + *     %d: The current date, formatted using the logger's date format. + *     %t: The current time, formatted using the logger's time format. + *     %l: The log level (one of "DEBUG", "INFO", "WARN", or "ERROR"). + *     %%: A literal percent sign. + * + * The default format string is CLOG_DEFAULT_FORMAT. + * + * @param fmt + * The new format string, which must be less than CLOG_FORMAT_LENGTH bytes. + * You probably will want to end this with a newline (\n). + * + * @return + * Zero on success, non-zero on failure. + */ +int clog_set_fmt(int id, const char *fmt); + +/** + * Set the callback function. + * + * @param cb + * The new callback function. + * + * @return + * Zero on success, non-zero on failure. + */ +int clog_set_cb(int id, void (*cb)(const char *msg, size_t len)); + +/** + * Set the file descriptor. + * + * @param id + * The identifier of the logger. + * + * @param fd + * The new file descriptor. + * + * @return + * Zero on success, non-zero on failure. + */ +int clog_set_fd(int id, int fd); + + +/* + * No need to read below this point. + */ + +/** + * The C logger structure. + */ +struct clog { + +    /* The current level of this logger. Messages below it will be dropped. */ +    enum clog_level level; + +    /* The file being written. */ +    int fd; + +    /* The format specifier. */ +    char fmt[CLOG_FORMAT_LENGTH]; + +    /* Date format */ +    char date_fmt[CLOG_FORMAT_LENGTH]; + +    /* Time format */ +    char time_fmt[CLOG_FORMAT_LENGTH]; + +    /* Tracks whether the fd needs to be closed eventually. */ +    int opened; + +    /* Callback function for each log message. */ +    void (*cb)(const char *msg, size_t len); +}; + +void _clog_err(const char *fmt, ...); + +#ifdef CLOG_MAIN +struct clog *_clog_loggers[CLOG_MAX_LOGGERS] = { 0 }; +#else +extern struct clog *_clog_loggers[CLOG_MAX_LOGGERS]; +#endif + +#ifdef CLOG_MAIN + +const char *const CLOG_LEVEL_NAMES[] = { +    "Debug", +    "Info", +    "Warning", +    "Error", +}; + +int +clog_init_path(int id, const char *const path) +{ +    int fd = open(path, O_CREAT | O_WRONLY | O_APPEND, 0666); +    if (fd == -1) { +        _clog_err("Unable to open %s: %s\n", path, strerror(errno)); +        return 1; +    } +    if (clog_init_fd(id, fd)) { +        close(fd); +        return 1; +    } +    _clog_loggers[id]->opened = 1; +    return 0; +} + +int +clog_init_fd(int id, int fd) +{ +    struct clog *logger; + +    if (_clog_loggers[id] != NULL) { +        _clog_err("Logger %d already initialized.\n", id); +        return 1; +    } + +    logger = (struct clog *) malloc(sizeof(struct clog)); +    if (logger == NULL) { +        _clog_err("Failed to allocate logger: %s\n", strerror(errno)); +        return 1; +    } + +    logger->level = CLOG_DEBUG; +    logger->fd = fd; +    logger->opened = 0; +    strcpy(logger->fmt, CLOG_DEFAULT_FORMAT); +    strcpy(logger->date_fmt, CLOG_DEFAULT_DATE_FORMAT); +    strcpy(logger->time_fmt, CLOG_DEFAULT_TIME_FORMAT); +    logger->cb = NULL; + +    _clog_loggers[id] = logger; +    return 0; +} + +void +clog_free(int id) +{ +    if (_clog_loggers[id]) { +        if (_clog_loggers[id]->opened) { +            close(_clog_loggers[id]->fd); +        } +        free(_clog_loggers[id]); +        _clog_loggers[id]=NULL; +    } +} + +int +clog_set_level(int id, enum clog_level level) +{ +    if (_clog_loggers[id] == NULL) { +        return 1; +    } +    if ((unsigned) level > CLOG_ERROR) { +        return 1; +    } +    _clog_loggers[id]->level = level; +    return 0; +} + +int +clog_set_fd(int id, int fd) +{ +    if (_clog_loggers[id] == NULL) { +        return 1; +    } +    _clog_loggers[id]->fd = fd; +    return 0; +} + +int +clog_set_time_fmt(int id, const char *fmt) +{ +    struct clog *logger = _clog_loggers[id]; +    if (logger == NULL) { +        _clog_err("clog_set_time_fmt: No such logger: %d\n", id); +        return 1; +    } +    if (strlen(fmt) >= CLOG_FORMAT_LENGTH) { +        _clog_err("clog_set_time_fmt: Format specifier too long.\n"); +        return 1; +    } +    strcpy(logger->time_fmt, fmt); +    return 0; +} + +int +clog_set_date_fmt(int id, const char *fmt) +{ +    struct clog *logger = _clog_loggers[id]; +    if (logger == NULL) { +        _clog_err("clog_set_date_fmt: No such logger: %d\n", id); +        return 1; +    } +    if (strlen(fmt) >= CLOG_FORMAT_LENGTH) { +        _clog_err("clog_set_date_fmt: Format specifier too long.\n"); +        return 1; +    } +    strcpy(logger->date_fmt, fmt); +    return 0; +} + +int +clog_set_fmt(int id, const char *fmt) +{ +    struct clog *logger = _clog_loggers[id]; +    if (logger == NULL) { +        _clog_err("clog_set_fmt: No such logger: %d\n", id); +        return 1; +    } +    if (strlen(fmt) >= CLOG_FORMAT_LENGTH) { +        _clog_err("clog_set_fmt: Format specifier too long.\n"); +        return 1; +    } +    strcpy(logger->fmt, fmt); +    return 0; +} + +int +clog_set_cb(int id, void (*cb)(const char *msg, size_t len)) +{ +    struct clog *logger = _clog_loggers[id]; +    if (logger == NULL) { +        _clog_err("clog_set_cb: No such logger: %d\n", id); +        return 1; +    } +    logger->cb = cb; +    return 0; +} + +/* Internal functions */ + +size_t +_clog_append_str(char **dst, char *orig_buf, const char *src, size_t cur_size) +{ +    size_t new_size = cur_size; + +    while (strlen(*dst) + strlen(src) >= new_size) { +        new_size *= 2; +    } +    if (new_size != cur_size) { +        if (*dst == orig_buf) { +            *dst = (char *) malloc(new_size); +            strcpy(*dst, orig_buf); +        } else { +            *dst = (char *) realloc(*dst, new_size); +        } +    } + +    strcat(*dst, src); +    return new_size; +} + +size_t +_clog_append_int(char **dst, char *orig_buf, long int d, size_t cur_size) +{ +    char buf[40]; /* Enough for 128-bit decimal */ +    if (snprintf(buf, 40, "%ld", d) >= 40) { +        return cur_size; +    } +    return _clog_append_str(dst, orig_buf, buf, cur_size); +} + +size_t +_clog_append_time(char **dst, char *orig_buf, struct tm *lt, +                  const char *fmt, size_t cur_size) +{ +    char buf[CLOG_DATETIME_LENGTH]; +    size_t result = strftime(buf, CLOG_DATETIME_LENGTH, fmt, lt); + +    if (result > 0) { +        return _clog_append_str(dst, orig_buf, buf, cur_size); +    } + +    return cur_size; +} + +const char * +_clog_basename(const char *path) +{ +    const char *slash = strrchr(path, '/'); +    if (slash) { +        path = slash + 1; +    } +#ifdef _WIN32 +    slash = strrchr(path, '\\'); +    if (slash) { +        path = slash + 1; +    } +#endif +    return path; +} + +char * +_clog_format(const struct clog *logger, char buf[], size_t buf_size, +             const char *sfile, int sline, const char *level, +             const char *message) +{ +    size_t cur_size = buf_size; +    char *result = buf; +    enum { NORMAL, SUBST } state = NORMAL; +    size_t fmtlen = strlen(logger->fmt); +    size_t i; +    time_t t = time(NULL); +    struct tm *lt = localtime(&t); + +    sfile = _clog_basename(sfile); +    result[0] = 0; +    for (i = 0; i < fmtlen; ++i) { +        if (state == NORMAL) { +            if (logger->fmt[i] == '%') { +                state = SUBST; +            } else { +                char str[2] = { 0 }; +                str[0] = logger->fmt[i]; +                cur_size = _clog_append_str(&result, buf, str, cur_size); +            } +        } else { +            switch (logger->fmt[i]) { +                case '%': +                    cur_size = _clog_append_str(&result, buf, "%", cur_size); +                    break; +                case 't': +                    cur_size = _clog_append_time(&result, buf, lt, +                                                 logger->time_fmt, cur_size); +                    break; +                case 'd': +                    cur_size = _clog_append_time(&result, buf, lt, +                                                 logger->date_fmt, cur_size); +                    break; +                case 'l': +                    cur_size = _clog_append_str(&result, buf, level, cur_size); +                    break; +                case 'n': +                    cur_size = _clog_append_int(&result, buf, sline, cur_size); +                    break; +                case 'f': +                    cur_size = _clog_append_str(&result, buf, sfile, cur_size); +                    break; +                case 'm': +                    cur_size = _clog_append_str(&result, buf, message, +                                                cur_size); +                    break; +            } +            state = NORMAL; +        } +    } + +    return result; +} + +void +_clog_log(const char *sfile, int sline, enum clog_level level, +          int id, const char *fmt, va_list ap) +{ +    /* For speed: Use a stack buffer until message exceeds 4096, then switch +     * to dynamically allocated.  This should greatly reduce the number of +     * memory allocations (and subsequent fragmentation). */ +    char buf[4096]; +    size_t buf_size = 4096; +    char *dynbuf = buf; +    char *message; +    int result; +    struct clog *logger = _clog_loggers[id]; + +    if (!logger) { +        _clog_err("No such logger: %d\n", id); +        return; +    } + +    if (level < logger->level) { +        return; +    } + +    /* Format the message text with the argument list. */ +    result = vsnprintf(dynbuf, buf_size, fmt, ap); +    if ((size_t) result >= buf_size) { +        buf_size = result + 1; +        dynbuf = (char *) malloc(buf_size); +        result = vsnprintf(dynbuf, buf_size, fmt, ap); +        if ((size_t) result >= buf_size) { +            /* Formatting failed -- too large */ +            _clog_err("Formatting failed (1).\n"); +            free(dynbuf); +            return; +        } +    } + +    /* Format according to log format and write to log */ +    { +        char message_buf[4096]; +        message = _clog_format(logger, message_buf, 4096, sfile, sline, +                               CLOG_LEVEL_NAMES[level], dynbuf); +        if (!message) { +            _clog_err("Formatting failed (2).\n"); +            if (dynbuf != buf) { +                free(dynbuf); +            } +            return; +        } +        result = write(logger->fd, message, strlen(message)); +        if (logger->cb) logger->cb(message,strlen(message)); +        if (result == -1) { +            _clog_err("Unable to write to log file: %s\n", strerror(errno)); +        } +        if (message != message_buf) { +            free(message); +        } +        if (dynbuf != buf) { +            free(dynbuf); +        } +#ifndef _MSC_VER +        fsync(logger->fd); +#else +        HANDLE h = (HANDLE) _get_osfhandle(logger->fd); +        if (h != INVALID_HANDLE_VALUE) { +            // This call will fail on a console fd, but that's ok. +            FlushFileBuffers(h); +        } +#endif +    } +} + +void +clog_debug(const char *sfile, int sline, int id, const char *fmt, va_list ap) +{ +    _clog_log(sfile, sline, CLOG_DEBUG, id, fmt, ap); +} + +void +clog_info(const char *sfile, int sline, int id, const char *fmt, va_list ap) +{ +    _clog_log(sfile, sline, CLOG_INFO, id, fmt, ap); +} + +void +clog_warn(const char *sfile, int sline, int id, const char *fmt, va_list ap) +{ +    _clog_log(sfile, sline, CLOG_WARN, id, fmt, ap); +} + +void +clog_error(const char *sfile, int sline, int id, const char *fmt, va_list ap) +{ +    _clog_log(sfile, sline, CLOG_ERROR, id, fmt, ap); +} + +void +_clog_err(const char *fmt, ...) +{ +#ifdef CLOG_SILENT +    (void) fmt; +#else +    va_list ap; + +    va_start(ap, fmt); +    vfprintf(stderr, fmt, ap); +#endif +} + +#endif /* CLOG_MAIN */ + +#ifdef __cplusplus +} /* extern "C" */ +#endif + +#endif /* __CLOG_H__ */ diff --git a/matlab/algorithms/DART/IterativeTomography.m b/matlab/algorithms/DART/IterativeTomography.m index 3875e6b..c3e737f 100644 --- a/matlab/algorithms/DART/IterativeTomography.m +++ b/matlab/algorithms/DART/IterativeTomography.m @@ -77,7 +77,7 @@ classdef IterativeTomography < matlab.mixin.Copyable  		function ok = initialize(this)  			% Initialize this object.  Returns 1 if succesful.  			% >> tomography.initialize(); -			 +			disp('sdfqnlmkqdsfmlkjdfqsjklm');  			% create projection geometry with super-resolution  			if this.superresolution > 1  				this.proj_geom_sr = astra_geom_superresolution(this.proj_geom, this.superresolution); diff --git a/matlab/algorithms/DART/examples/example1.m b/matlab/algorithms/DART/examples/example1.m index cb02e0f..791e440 100644 --- a/matlab/algorithms/DART/examples/example1.m +++ b/matlab/algorithms/DART/examples/example1.m @@ -35,36 +35,41 @@ vol_geom = astra_create_vol_geom(det_count, det_count);  [sinogram_id, sinogram] = astra_create_sino_cuda(I, proj_geom, vol_geom);  astra_mex_data2d('delete', sinogram_id); -% DART -D						= DARTalgorithm(sinogram, proj_geom); -D.t0					= 100; -D.t						= 10; +	% DART +	D						= DARTalgorithm(sinogram, proj_geom); +	D.t0					= 100; +	D.t						= 10; -D.tomography.method		= 'SIRT_CUDA'; -D.tomography.gpu_core	= gpu_core; -D.tomography.use_minc	= 'yes'; +	D.tomography.method		= 'SIRT'; +	D.tomography.gpu_core	= gpu_core; +	D.tomography.use_minc	= 'yes'; +	D.tomography.gpu        = 'no'; -D.segmentation.rho		= rho; -D.segmentation.tau		= tau; +	D.segmentation          = SegmentationPDM(); +	D.segmentation.rho		= rho*1.8; +	D.segmentation.tau		= tau*1.5; +	D.segmentation.interval = 5; -D.smoothing.b			= 0.1; -D.smoothing.gpu_core	= gpu_core; -  -D.masking.random		= 0.1; -D.masking.gpu_core		= gpu_core; +	D.smoothing.b			= 0.1; +	D.smoothing.gpu_core	= gpu_core; +	D.smoothing.gpu        = 'no'; +	 +	D.masking.random		= 0.1; +	D.masking.gpu_core		= gpu_core; +	D.masking.gpu        = 'no'; +	 +	D.output.directory		= outdir; +	D.output.pre			= [prefix '_']; +	D.output.save_images	= 'no'; +	D.output.save_results	= {'stats', 'settings', 'S', 'V'}; +	D.output.save_interval	= dart_iterations; +	D.output.verbose		= 'yes'; -D.output.directory		= outdir; -D.output.pre			= [prefix '_']; -D.output.save_images	= 'no'; -D.output.save_results	= {'stats', 'settings', 'S', 'V'}; -D.output.save_interval	= dart_iterations; -D.output.verbose		= 'yes'; +	D.statistics.proj_diff	= 'no'; -D.statistics.proj_diff	= 'no'; +	D.initialize(); -D.initialize(); - -D.iterate(dart_iterations); +	D.iterate(dart_iterations);  % save the reconstruction and the segmentation to file  imwritesc(D.S, [outdir '/' prefix '_S.png']); diff --git a/matlab/mex/astra_mex.cpp b/matlab/mex/astra_mex.cpp index 0eb5662..4bf42dd 100644 --- a/matlab/mex/astra_mex.cpp +++ b/matlab/mex/astra_mex.cpp @@ -28,6 +28,7 @@ $Id$  #include <mex.h>  #include "mexHelpFunctions.h" +#include "mexInitFunctions.h"  #include "astra/Globals.h" @@ -104,6 +105,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		return;  	} +	initASTRAMex(); +  	// SWITCH (MODE)  	if (sMode ==  std::string("version")) {   		astra_mex_version(nlhs, plhs, nrhs, prhs);  diff --git a/matlab/mex/astra_mex_algorithm_c.cpp b/matlab/mex/astra_mex_algorithm_c.cpp index 669af8c..ec7aa72 100644 --- a/matlab/mex/astra_mex_algorithm_c.cpp +++ b/matlab/mex/astra_mex_algorithm_c.cpp @@ -32,6 +32,7 @@ $Id$   */  #include <mex.h>  #include "mexHelpFunctions.h" +#include "mexInitFunctions.h"  #include "astra/Globals.h"  #define USE_MATLAB_UNDOCUMENTED @@ -80,7 +81,7 @@ void astra_mex_algorithm_create(int nlhs, mxArray* plhs[], int nrhs, const mxArr  	// turn MATLAB struct to an XML-based Config object  	Config* cfg = structToConfig("Algorithm", prhs[1]); -	CAlgorithm* pAlg = CAlgorithmFactory::getSingleton().create(cfg->self->getAttribute("type")); +	CAlgorithm* pAlg = CAlgorithmFactory::getSingleton().create(cfg->self.getAttribute("type"));  	if (!pAlg) {  		delete cfg;  		mexErrMsgTxt("Unknown algorithm. \n"); @@ -325,6 +326,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		return;  	} +	initASTRAMex(); +  	// SWITCH (MODE)  	if (sMode == "create") {  		astra_mex_algorithm_create(nlhs, plhs, nrhs, prhs); diff --git a/matlab/mex/astra_mex_algorithm_vc08.vcproj b/matlab/mex/astra_mex_algorithm_vc09.vcproj index baa4c44..d5cebc0 100644 --- a/matlab/mex/astra_mex_algorithm_vc08.vcproj +++ b/matlab/mex/astra_mex_algorithm_vc09.vcproj @@ -19,7 +19,7 @@  	</ToolFiles>  	<Configurations>  		<Configuration -			Name="Release|Win32" +			Name="Debug_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -40,12 +40,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -55,16 +49,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -85,9 +69,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release|x64" +			Name="Debug_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -108,12 +111,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -123,15 +120,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -152,9 +140,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|Win32" +			Name="Debug|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -175,13 +181,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -191,16 +190,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="false" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -221,9 +210,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|x64" +			Name="Debug|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -244,13 +252,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -260,15 +261,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -289,9 +281,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|Win32" +			Name="Release_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -312,14 +322,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -329,16 +331,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -359,9 +351,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|x64" +			Name="Release_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -380,16 +391,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				BrowseInformation="1" -				DebugInformationFormat="4"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -401,17 +402,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -432,9 +422,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug|Win32" +			Name="Release|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -455,13 +463,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -471,16 +472,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -501,9 +492,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug|x64" +			Name="Release|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -522,13 +532,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -540,16 +543,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -570,6 +563,24 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  	</Configurations>  	<References> @@ -587,6 +598,14 @@  			RelativePath=".\mexHelpFunctions.h"  			>  		</File> +		<File +			RelativePath=".\mexInitFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.h" +			> +		</File>  	</Files>  	<Globals>  	</Globals> diff --git a/matlab/mex/astra_mex_algorithm_vc11.vcxproj b/matlab/mex/astra_mex_algorithm_vc11.vcxproj index bdbca46..c133e26 100644 --- a/matlab/mex/astra_mex_algorithm_vc11.vcxproj +++ b/matlab/mex/astra_mex_algorithm_vc11.vcxproj @@ -40,19 +40,15 @@      <RootNamespace>astraMatlab</RootNamespace>    </PropertyGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> -    <ConfigurationType>DynamicLibrary</ConfigurationType> -    <PlatformToolset>v110</PlatformToolset> -  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -60,7 +56,7 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -68,6 +64,10 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset> @@ -75,215 +75,230 @@    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />    <ImportGroup Label="ExtensionSettings">    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup>    <PropertyGroup Label="UserMacros" />    <PropertyGroup>      <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> -    <TargetExt>.mexw64</TargetExt>      <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <GenerateDebugInformation>false</GenerateDebugInformation> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_INC_PATH);..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <BrowseInformation>true</BrowseInformation> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation> -      <TargetMachine>MachineX64</TargetMachine>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup>    <ItemGroup>      <ClCompile Include="astra_mex_algorithm_c.cpp" />      <ClCompile Include="mexHelpFunctions.cpp" /> -    <ClCompile Include="mexCopyDataHelpFunctions.cpp"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClCompile> -    <ClCompile Include="mexDataManagerHelpFunctions.cpp" /> +    <ClCompile Include="mexInitFunctions.cpp" />    </ItemGroup>    <ItemGroup>      <ClInclude Include="mexHelpFunctions.h" /> -    <ClInclude Include="mexCopyDataHelpFunctions.h"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClInclude> -    <ClInclude Include="mexDataManagerHelpFunctions.h" /> +    <ClInclude Include="mexInitFunctions.h" />    </ItemGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />    <ImportGroup Label="ExtensionTargets"> diff --git a/matlab/mex/astra_mex_c.cpp b/matlab/mex/astra_mex_c.cpp index 760bd51..4a331f5 100644 --- a/matlab/mex/astra_mex_c.cpp +++ b/matlab/mex/astra_mex_c.cpp @@ -33,6 +33,7 @@ $Id$  #include <mex.h>  #include "mexHelpFunctions.h" +#include "mexInitFunctions.h"  #include "astra/Globals.h" @@ -128,6 +129,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		return;  	} +	initASTRAMex(); +  	// SWITCH (MODE)  	if (sMode ==  std::string("version")) {   		astra_mex_version(nlhs, plhs, nrhs, prhs);  diff --git a/matlab/mex/astra_mex_data2d_c.cpp b/matlab/mex/astra_mex_data2d_c.cpp index 62c5d80..6863b7a 100644 --- a/matlab/mex/astra_mex_data2d_c.cpp +++ b/matlab/mex/astra_mex_data2d_c.cpp @@ -32,6 +32,7 @@ $Id$   */  #include <mex.h>  #include "mexHelpFunctions.h" +#include "mexInitFunctions.h"  #include <list> @@ -149,7 +150,7 @@ void astra_mex_data2d_create(int& nlhs, mxArray* plhs[], int& nrhs, const mxArra  		Config* cfg = structToConfig("ProjectionGeometry", prhs[2]);  		// FIXME: Change how the base class is created. (This is duplicated  		// in 'change_geometry' and Projector2D.cpp.) -		std::string type = cfg->self->getAttribute("type"); +		std::string type = cfg->self.getAttribute("type");  		CProjectionGeometry2D* pGeometry;  		if (type == "sparse_matrix") {  			pGeometry = new CSparseMatrixProjectionGeometry2D(); @@ -440,7 +441,7 @@ void astra_mex_data2d_change_geometry(int nlhs, mxArray* plhs[], int nrhs, const  		Config* cfg = structToConfig("ProjectionGeometry2D", prhs[2]);  		// FIXME: Change how the base class is created. (This is duplicated  		// in 'create' and Projector2D.cpp.) -		std::string type = cfg->self->getAttribute("type"); +		std::string type = cfg->self.getAttribute("type");  		CProjectionGeometry2D* pGeometry;  		if (type == "sparse_matrix") {  			pGeometry = new CSparseMatrixProjectionGeometry2D(); @@ -640,6 +641,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		return;  	} +	initASTRAMex(); +  	// SWITCH (MODE)  	if (sMode ==  std::string("get")) {   		astra_mex_data2d_get(nlhs, plhs, nrhs, prhs);  diff --git a/matlab/mex/astra_mex_data2d_vc08.vcproj b/matlab/mex/astra_mex_data2d_vc09.vcproj index 8f1fc13..2c8a63f 100644 --- a/matlab/mex/astra_mex_data2d_vc08.vcproj +++ b/matlab/mex/astra_mex_data2d_vc09.vcproj @@ -19,7 +19,7 @@  	</ToolFiles>  	<Configurations>  		<Configuration -			Name="Release|Win32" +			Name="Debug_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -40,12 +40,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -55,15 +49,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -84,9 +69,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release|x64" +			Name="Debug_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -107,12 +111,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -122,15 +120,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -151,9 +140,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|Win32" +			Name="Debug|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -174,13 +181,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -190,15 +190,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -219,9 +210,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|x64" +			Name="Debug|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -242,13 +252,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -258,15 +261,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -287,9 +281,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|Win32" +			Name="Release_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -310,14 +322,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -327,16 +331,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -357,9 +351,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|x64" +			Name="Release_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -378,16 +391,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				BrowseInformation="1" -				DebugInformationFormat="4"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -399,17 +402,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -430,9 +422,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug|Win32" +			Name="Release|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -453,13 +463,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -469,16 +472,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -499,9 +492,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug|x64" +			Name="Release|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -520,13 +532,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -538,16 +543,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -568,6 +563,24 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  	</Configurations>  	<References> @@ -585,6 +598,30 @@  			RelativePath=".\mexHelpFunctions.h"  			>  		</File> +		<File +			RelativePath=".\mexCopyDataHelpFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexCopyDataHelpFunctions.h" +			> +		</File> +		<File +			RelativePath=".\mexDataManagerHelpFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexDataManagerHelpFunctions.h" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.h" +			> +		</File>  	</Files>  	<Globals>  	</Globals> diff --git a/matlab/mex/astra_mex_data2d_vc11.vcxproj b/matlab/mex/astra_mex_data2d_vc11.vcxproj index eb09332..636780a 100644 --- a/matlab/mex/astra_mex_data2d_vc11.vcxproj +++ b/matlab/mex/astra_mex_data2d_vc11.vcxproj @@ -40,19 +40,15 @@      <RootNamespace>astraMatlab</RootNamespace>    </PropertyGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> -    <ConfigurationType>DynamicLibrary</ConfigurationType> -    <PlatformToolset>v110</PlatformToolset> -  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -60,7 +56,7 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -68,6 +64,10 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset> @@ -75,213 +75,234 @@    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />    <ImportGroup Label="ExtensionSettings">    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup>    <PropertyGroup Label="UserMacros" />    <PropertyGroup>      <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir>      <TargetName>$(ProjectName)_c</TargetName>      <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(CUDA_INC_PATH);$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <BrowseInformation>true</BrowseInformation> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation> -      <TargetMachine>MachineX64</TargetMachine>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup>    <ItemGroup>      <ClCompile Include="astra_mex_data2d_c.cpp" />      <ClCompile Include="mexHelpFunctions.cpp" /> -    <ClCompile Include="mexCopyDataHelpFunctions.cpp"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">false</ExcludedFromBuild> -    </ClCompile> +    <ClCompile Include="mexCopyDataHelpFunctions.cpp" />      <ClCompile Include="mexDataManagerHelpFunctions.cpp" /> +    <ClCompile Include="mexInitFunctions.cpp" />    </ItemGroup>    <ItemGroup>      <ClInclude Include="mexHelpFunctions.h" /> -    <ClInclude Include="mexCopyDataHelpFunctions.h"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">false</ExcludedFromBuild> -    </ClInclude> +    <ClInclude Include="mexCopyDataHelpFunctions.h" />      <ClInclude Include="mexDataManagerHelpFunctions.h" /> +    <ClInclude Include="mexInitFunctions.h" />    </ItemGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />    <ImportGroup Label="ExtensionTargets"> diff --git a/matlab/mex/astra_mex_data3d_c.cpp b/matlab/mex/astra_mex_data3d_c.cpp index 0a3f85d..fe4ce37 100644 --- a/matlab/mex/astra_mex_data3d_c.cpp +++ b/matlab/mex/astra_mex_data3d_c.cpp @@ -32,6 +32,7 @@ $Id$   */  #include <mex.h>  #include "mexHelpFunctions.h" +#include "mexInitFunctions.h"  #include "mexCopyDataHelpFunctions.h"  #include "mexDataManagerHelpFunctions.h" @@ -147,8 +148,8 @@ void astra_mex_data3d_link(int& nlhs, mxArray* plhs[], int& nrhs, const mxArray*  		return;  	} -	if (data && !checkDataType(data)) { -		mexErrMsgTxt("Data must be single or double."); +	if (data && !mxIsSingle(data)) { +		mexErrMsgTxt("Data must be single.");  		return;  	} @@ -309,6 +310,112 @@ void astra_mex_data3d_get_geometry(int nlhs, mxArray* plhs[], int nrhs, const mx  }  //----------------------------------------------------------------------------------------- +/** astra_mex_data3d('change_geometry', id, geom); + * + * Change the geometry of a 3d data object. + * id: identifier of the 3d data object as stored in the astra-library. + * geom: the new geometry struct, as created by astra_create_vol/proj_geom + */ +void astra_mex_data3d_change_geometry(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	// parse input +	if (nrhs < 3) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} + +	// get data object +	CFloat32Data3DMemory* pDataObject = NULL; +	if (!checkID(mxGetScalar(prhs[1]), pDataObject)) { +		mexErrMsgTxt("Data object not found or not initialized properly.\n"); +		return; +	} + +	const mxArray * const geometry = prhs[2]; + +	if (!checkStructs(geometry)) { +		mexErrMsgTxt("Argument 3 is not a valid MATLAB struct.\n"); +		return; +	} + +	CFloat32ProjectionData3D* pProjData = dynamic_cast<CFloat32ProjectionData3D*>(pDataObject); +	if (pProjData) { +		// Projection data + +		// Read geometry +		astra::Config* cfg = structToConfig("ProjectionGeometry3D", geometry); +		// FIXME: Change how the base class is created. (This is duplicated +		// in Projector3D.cpp.) +		std::string type = cfg->self.getAttribute("type"); +		astra::CProjectionGeometry3D* pGeometry = 0; +		if (type == "parallel3d") { +			pGeometry = new astra::CParallelProjectionGeometry3D(); +		} else if (type == "parallel3d_vec") { +			pGeometry = new astra::CParallelVecProjectionGeometry3D(); +		} else if (type == "cone") { +			pGeometry = new astra::CConeProjectionGeometry3D(); +		} else if (type == "cone_vec") { +			pGeometry = new astra::CConeVecProjectionGeometry3D(); +		} else { +			mexErrMsgTxt("Invalid geometry type.\n"); +			return; +		} + +		if (!pGeometry->initialize(*cfg)) { +			mexErrMsgTxt("Geometry class not initialized. \n"); +			delete pGeometry; +			delete cfg; +			return; +		} +		delete cfg; + +		// Check dimensions +		if (pGeometry->getDetectorColCount() != pProjData->getDetectorColCount() || +		    pGeometry->getProjectionCount() != pProjData->getAngleCount() || +		    pGeometry->getDetectorRowCount() != pProjData->getDetectorRowCount()) +		{ +			mexErrMsgTxt("The dimensions of the data do not match those specified in the geometry. \n"); +			delete pGeometry; +			return; +		} + +		// If ok, change geometry +		pProjData->changeGeometry(pGeometry); +		delete pGeometry; +	} else { +		// Volume data +		CFloat32VolumeData3D* pVolData = dynamic_cast<CFloat32VolumeData3D*>(pDataObject); +		assert(pVolData); + +		// Read geometry +		astra::Config* cfg = structToConfig("VolumeGeometry3D", geometry); +		astra::CVolumeGeometry3D* pGeometry = new astra::CVolumeGeometry3D(); +		if (!pGeometry->initialize(*cfg)) +		{ +			mexErrMsgTxt("Geometry class not initialized. \n"); +			delete pGeometry; +			delete cfg; +			return; +		} +		delete cfg; + +				// Check dimensions +		if (pGeometry->getGridColCount() != pVolData->getColCount() || +		    pGeometry->getGridRowCount() != pVolData->getRowCount() || +		    pGeometry->getGridSliceCount() != pVolData->getSliceCount()) +		{ +			mexErrMsgTxt("The dimensions of the data do not match those specified in the geometry. \n"); +			delete pGeometry; +			return; +		} + +		// If ok, change geometry +		pVolData->changeGeometry(pGeometry); +		delete pGeometry; +	} +} + +//-----------------------------------------------------------------------------------------  /**   * astra_mex_data3d('delete', did1, did2, ...);   */ @@ -350,7 +457,7 @@ static void printHelp()  {  	mexPrintf("Please specify a mode of operation.\n");  	mexPrintf("Valid modes: create, get, get_single, delete, clear, info\n"); -	mexPrintf("             dimensions\n"); +	mexPrintf("             dimensions, get_geometry, change_geometry\n");  } @@ -371,6 +478,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		return;  	} +	initASTRAMex(); +  	// 3D data  	if (sMode ==  std::string("create")) {   		astra_mex_data3d_create(nlhs, plhs, nrhs, prhs);  @@ -395,6 +504,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		astra_mex_data3d_dimensions(nlhs, plhs, nrhs, prhs);   	} else if (sMode == std::string("get_geometry")) {  		astra_mex_data3d_get_geometry(nlhs, plhs, nrhs, prhs); +	} else if (sMode == std::string("change_geometry")) { +		astra_mex_data3d_change_geometry(nlhs, plhs, nrhs, prhs);  	} else {  		printHelp();  	} diff --git a/matlab/mex/astra_mex_data3d_vc09.vcproj b/matlab/mex/astra_mex_data3d_vc09.vcproj new file mode 100644 index 0000000..fd861a3 --- /dev/null +++ b/matlab/mex/astra_mex_data3d_vc09.vcproj @@ -0,0 +1,628 @@ +<?xml version="1.0" encoding="Windows-1252"?> +<VisualStudioProject +	ProjectType="Visual C++" +	Version="9.00" +	Name="astra_mex_data3d" +	ProjectGUID="{0BEC029B-0929-4BF9-BD8B-9C9806A52065}" +	RootNamespace="astraMatlab" +	TargetFrameworkVersion="131072" +	> +	<Platforms> +		<Platform +			Name="Win32" +		/> +		<Platform +			Name="x64" +		/> +	</Platforms> +	<ToolFiles> +	</ToolFiles> +	<Configurations> +		<Configuration +			Name="Debug_CUDA|Win32" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)" +			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/> +		</Configuration> +		<Configuration +			Name="Debug_CUDA|x64" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)" +			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/> +		</Configuration> +		<Configuration +			Name="Debug|Win32" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)" +			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/> +		</Configuration> +		<Configuration +			Name="Debug|x64" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)" +			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/> +		</Configuration> +		<Configuration +			Name="Release_CUDA|Win32" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)" +			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/> +		</Configuration> +		<Configuration +			Name="Release_CUDA|x64" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)" +			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/> +		</Configuration> +		<Configuration +			Name="Release|Win32" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)" +			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/> +		</Configuration> +		<Configuration +			Name="Release|x64" +			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)" +			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)" +			ConfigurationType="2" +			> +			<Tool +				Name="VCPreBuildEventTool" +			/> +			<Tool +				Name="VCCustomBuildTool" +			/> +			<Tool +				Name="VCXMLDataGeneratorTool" +			/> +			<Tool +				Name="VCWebServiceProxyGeneratorTool" +			/> +			<Tool +				Name="VCMIDLTool" +			/> +			<Tool +				Name="VCManagedResourceCompilerTool" +			/> +			<Tool +				Name="VCResourceCompilerTool" +			/> +			<Tool +				Name="VCPreLinkEventTool" +			/> +			<Tool +				Name="VCALinkTool" +			/> +			<Tool +				Name="VCManifestTool" +			/> +			<Tool +				Name="VCXDCMakeTool" +			/> +			<Tool +				Name="VCBscMakeTool" +			/> +			<Tool +				Name="VCFxCopTool" +			/> +			<Tool +				Name="VCAppVerifierTool" +			/> +			<Tool +				Name="VCPostBuildEventTool" +			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/> +		</Configuration> +	</Configurations> +	<References> +	</References> +	<Files> +		<File +			RelativePath=".\astra_mex_data3d_c.cpp" +			> +		</File> +		<File +			RelativePath=".\mexHelpFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexHelpFunctions.h" +			> +		</File> +		<File +			RelativePath=".\mexCopyDataHelpFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexCopyDataHelpFunctions.h" +			> +		</File> +		<File +			RelativePath=".\mexDataManagerHelpFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexDataManagerHelpFunctions.h" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.h" +			> +		</File> +	</Files> +	<Globals> +	</Globals> +</VisualStudioProject> diff --git a/matlab/mex/astra_mex_data3d_vc11.vcxproj b/matlab/mex/astra_mex_data3d_vc11.vcxproj index b85d90b..1c3c620 100644 --- a/matlab/mex/astra_mex_data3d_vc11.vcxproj +++ b/matlab/mex/astra_mex_data3d_vc11.vcxproj @@ -40,19 +40,15 @@      <RootNamespace>astraMatlab</RootNamespace>    </PropertyGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> -    <ConfigurationType>DynamicLibrary</ConfigurationType> -    <PlatformToolset>v110</PlatformToolset> -  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -60,7 +56,7 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -68,6 +64,10 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset> @@ -75,218 +75,234 @@    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />    <ImportGroup Label="ExtensionSettings">    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup>    <PropertyGroup Label="UserMacros" />    <PropertyGroup>      <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir>      <TargetName>$(ProjectName)_c</TargetName>      <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport>        <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport>        <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat>        <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat>        <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup>    <ItemGroup>      <ClCompile Include="astra_mex_data3d_c.cpp" />      <ClCompile Include="mexHelpFunctions.cpp" /> -    <ClCompile Include="mexCopyDataHelpFunctions.cpp"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">false</ExcludedFromBuild> -    </ClCompile> +    <ClCompile Include="mexCopyDataHelpFunctions.cpp" />      <ClCompile Include="mexDataManagerHelpFunctions.cpp" /> +    <ClCompile Include="mexInitFunctions.cpp" />    </ItemGroup>    <ItemGroup>      <ClInclude Include="mexHelpFunctions.h" /> -    <ClInclude Include="mexCopyDataHelpFunctions.h"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">false</ExcludedFromBuild> -    </ClInclude> +    <ClInclude Include="mexCopyDataHelpFunctions.h" />      <ClInclude Include="mexDataManagerHelpFunctions.h" /> +    <ClInclude Include="mexInitFunctions.h" />    </ItemGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />    <ImportGroup Label="ExtensionTargets"> diff --git a/matlab/mex/astra_mex_log_c.cpp b/matlab/mex/astra_mex_log_c.cpp new file mode 100644 index 0000000..ea4621e --- /dev/null +++ b/matlab/mex/astra_mex_log_c.cpp @@ -0,0 +1,305 @@ +/* +----------------------------------------------------------------------- +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$ +*/ + +/** \file astra_mex_log_c.cpp + * + *  \brief Manages astra logging + */ +#include <mex.h> +#include "mexHelpFunctions.h" +#include "mexInitFunctions.h" + +#include "astra/Logging.h" + +using namespace std; +using namespace astra; +//----------------------------------------------------------------------------------------- +/** astra_mex_log('debug', file, line, message); + * + * Log a debug message. + * file: Originating file name + * line: Originating line number + * message: Log message. + */ +void astra_mex_log_debug(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	if (nrhs < 4) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} +	string filename = mexToString(prhs[1]); +	int linenumber = (int)mxGetScalar(prhs[2]); +	string message = mexToString(prhs[3]); +	astra::CLogger::debug(filename.c_str(),linenumber,message.c_str()); +} + +//----------------------------------------------------------------------------------------- +/** astra_mex_log('info', file, line, message); + * + * Log an info message. + * file: Originating file name + * line: Originating line number + * message: Log message. + */ +void astra_mex_log_info(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	if (nrhs < 4) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} +	string filename = mexToString(prhs[1]); +	int linenumber = (int)mxGetScalar(prhs[2]); +	string message = mexToString(prhs[3]); +	astra::CLogger::info(filename.c_str(),linenumber,message.c_str()); +} + +//----------------------------------------------------------------------------------------- +/** astra_mex_log('warn', file, line, message); + * + * Log a warning message. + * file: Originating file name + * line: Originating line number + * message: Log message. + */ +void astra_mex_log_warn(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	if (nrhs < 4) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} +	string filename = mexToString(prhs[1]); +	int linenumber = (int)mxGetScalar(prhs[2]); +	string message = mexToString(prhs[3]); +	astra::CLogger::warn(filename.c_str(),linenumber,message.c_str()); +} + +//----------------------------------------------------------------------------------------- +/** astra_mex_log('error', file, line, message); + * + * Log an error message. + * file: Originating file name + * line: Originating line number + * message: Log message. + */ +void astra_mex_log_error(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	if (nrhs < 4) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} +	string filename = mexToString(prhs[1]); +	int linenumber = (int)mxGetScalar(prhs[2]); +	string message = mexToString(prhs[3]); +	astra::CLogger::error(filename.c_str(),linenumber,message.c_str()); +} + +//----------------------------------------------------------------------------------------- +/** astra_mex_log('enable', type); + * + * Enable logging. + * type: which output to enable ('all', 'file', 'screen') + */ +void astra_mex_log_enable(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	if (nrhs < 2) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} +	string sType = mexToString(prhs[1]); +	if(sType == "all"){ +		astra::CLogger::enable(); +	}else if(sType == "file"){ +		astra::CLogger::enableFile(); +	}else if(sType == "screen"){ +		astra::CLogger::enableScreen(); +	} else { +		mexErrMsgTxt("Specify which output to enable ('all', 'file', or 'screen')"); +	} +} + +//----------------------------------------------------------------------------------------- +/** astra_mex_log('disable', type); + * + * Disable logging. + * type: which output to disable ('all', 'file', 'screen') + */ +void astra_mex_log_disable(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	if (nrhs < 2) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} +	string sType = mexToString(prhs[1]); +	if(sType == "all"){ +		astra::CLogger::disable(); +	}else if(sType == "file"){ +		astra::CLogger::disableFile(); +	}else if(sType == "screen"){ +		astra::CLogger::disableScreen(); +	} else { +		mexErrMsgTxt("Specify which output to disable ('all', 'file', or 'screen')"); +	} +} + +//----------------------------------------------------------------------------------------- +/** astra_mex_log('format', type, fmt); + * + * Enable logging. + * type: which output to format ('file', 'screen') + * fmt: format string + *      Here are the substitutions you may use: + *      %f: Source file name generating the log call. + *      %n: Source line number where the log call was made. + *      %m: The message text sent to the logger (after printf formatting). + *      %d: The current date, formatted using the logger's date format. + *      %t: The current time, formatted using the logger's time format. + *      %l: The log level (one of "DEBUG", "INFO", "WARN", or "ERROR"). + *      %%: A literal percent sign. + *      The default format string is "%d %t %f(%n): %l: %m\n". + */ +void astra_mex_log_format(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	if (nrhs < 3) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} +	string sType = mexToString(prhs[1]); +	string sFormat = mexToString(prhs[2]); +	if (!sFormat.empty()) +	{ +		char lastChar = *sFormat.rbegin(); +		if (lastChar!='\n'){ +			sFormat += '\n'; +		} +	}else{ +		sFormat += '\n'; +	} +	if(sType == "file"){ +		astra::CLogger::setFormatFile(sFormat.c_str()); +	}else if(sType == "screen"){ +		astra::CLogger::setFormatScreen(sFormat.c_str()); +	} else { +		mexErrMsgTxt("Specify which output to format ('file' or 'screen')"); +	} +} + +//----------------------------------------------------------------------------------------- +/** astra_mex_log('output', type, output, level); + * + * Set output file / output screen. + * type: which output to set ('file', 'screen') + * output: which output file / screen to use: + *         'file': filename + *         'screen': 'stdout' or 'stderr' + * level: logging level to use ('debug', 'info', 'warn', or 'error') + */ +void astra_mex_log_output(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[]) +{ +	if (nrhs < 4) { +		mexErrMsgTxt("Not enough arguments.  See the help document for a detailed argument list. \n"); +		return; +	} +	string sType = mexToString(prhs[1]); +	string sOutput = mexToString(prhs[2]); +	string sLevel = mexToString(prhs[3]); +	log_level eLevel; +	if(sLevel == "debug"){ +		eLevel = LOG_DEBUG; +	}else if(sLevel == "info"){ +		eLevel = LOG_INFO; +	}else if(sLevel == "warn"){ +		eLevel = LOG_WARN; +	}else if(sLevel == "error"){ +		eLevel = LOG_ERROR; +	}else{ +		mexErrMsgTxt("Specify which log level to use ('debug', 'info', 'warn', or 'error')"); +	} +	if(sType == "file"){ +		astra::CLogger::setOutputFile(sOutput.c_str(),eLevel); +	}else if(sType == "screen"){ +		int fd; +		if(sOutput == "stdout"){ +			fd=1; +		}else if(sOutput == "stderr"){ +			fd=2; +		}else{ +			mexErrMsgTxt("Specify which screen to output to ('stdout' or 'stderr')"); +		} +		astra::CLogger::setOutputScreen(fd,eLevel); +	} else { +		mexErrMsgTxt("Specify which output to set ('file' or 'screen')"); +	} +} + +//----------------------------------------------------------------------------------------- +static void printHelp() +{ +	mexPrintf("Please specify a mode of operation.\n"); +	mexPrintf("Valid modes: debug, info, warn, error, enable, disable, format, output\n"); +} + +//----------------------------------------------------------------------------------------- +/** + * ... = astra_mex_log(mode, ...); + */ +void mexFunction(int nlhs, mxArray* plhs[], +				 int nrhs, const mxArray* prhs[]) +{ +	// INPUT: Mode +	string sMode = ""; +	if (1 <= nrhs) { +		sMode = mexToString(prhs[0]);	 +	} else { +		printHelp(); +		return; +	} + +	initASTRAMex(); + +	// SWITCH (MODE) +	if (sMode == "debug") { +		astra_mex_log_debug(nlhs, plhs, nrhs, prhs); +    }else if (sMode == "info") { +		astra_mex_log_info(nlhs, plhs, nrhs, prhs); +	}else if (sMode == "warn") { +		astra_mex_log_warn(nlhs, plhs, nrhs, prhs); +	}else if (sMode == "error") { +		astra_mex_log_error(nlhs, plhs, nrhs, prhs); +	}else if (sMode == "enable") { +		astra_mex_log_enable(nlhs, plhs, nrhs, prhs); +	}else if (sMode == "disable") { +		astra_mex_log_disable(nlhs, plhs, nrhs, prhs); +	}else if (sMode == "format") { +		astra_mex_log_format(nlhs, plhs, nrhs, prhs); +	}else if (sMode == "output") { +		astra_mex_log_output(nlhs, plhs, nrhs, prhs); +	} else { +		printHelp(); +	} +	return; +} diff --git a/matlab/mex/astra_mex_data3d_vc08.vcproj b/matlab/mex/astra_mex_log_vc09.vcproj index 2e69c16..0e0d469 100644 --- a/matlab/mex/astra_mex_data3d_vc08.vcproj +++ b/matlab/mex/astra_mex_log_vc09.vcproj @@ -2,8 +2,8 @@  <VisualStudioProject  	ProjectType="Visual C++"  	Version="9.00" -	Name="astra_mex_data3d" -	ProjectGUID="{0BEC029B-0929-4BF9-BD8B-9C9806A52065}" +	Name="astra_mex_log" +	ProjectGUID="{CA2840B3-DA68-41B5-AC57-F5DFD20ED8F8}"  	RootNamespace="astraMatlab"  	TargetFrameworkVersion="131072"  	> @@ -19,7 +19,7 @@  	</ToolFiles>  	<Configurations>  		<Configuration -			Name="Release|Win32" +			Name="Debug_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -40,12 +40,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -55,15 +49,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -84,9 +69,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release|x64" +			Name="Debug_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -107,12 +111,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -122,15 +120,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -151,9 +140,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|Win32" +			Name="Debug|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -174,13 +181,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -190,15 +190,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -219,9 +210,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|x64" +			Name="Debug|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -242,13 +252,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -258,15 +261,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -287,9 +281,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|Win32" +			Name="Release_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -310,14 +322,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -327,16 +331,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -357,9 +351,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|x64" +			Name="Release_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -378,14 +391,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -397,16 +402,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -427,9 +422,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug|Win32" +			Name="Release|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -450,13 +463,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -466,16 +472,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -496,9 +492,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug|x64" +			Name="Release|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -517,13 +532,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -535,16 +543,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -565,13 +563,31 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  	</Configurations>  	<References>  	</References>  	<Files>  		<File -			RelativePath=".\astra_mex_data3d_c.cpp" +			RelativePath=".\astra_mex_log_c.cpp"  			>  		</File>  		<File @@ -582,6 +598,14 @@  			RelativePath=".\mexHelpFunctions.h"  			>  		</File> +		<File +			RelativePath=".\mexInitFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.h" +			> +		</File>  	</Files>  	<Globals>  	</Globals> diff --git a/matlab/mex/astra_mex_log_vc11.vcxproj b/matlab/mex/astra_mex_log_vc11.vcxproj new file mode 100644 index 0000000..0a939cf --- /dev/null +++ b/matlab/mex/astra_mex_log_vc11.vcxproj @@ -0,0 +1,306 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> +  <ItemGroup Label="ProjectConfigurations"> +    <ProjectConfiguration Include="Debug_CUDA|Win32"> +      <Configuration>Debug_CUDA</Configuration> +      <Platform>Win32</Platform> +    </ProjectConfiguration> +    <ProjectConfiguration Include="Debug_CUDA|x64"> +      <Configuration>Debug_CUDA</Configuration> +      <Platform>x64</Platform> +    </ProjectConfiguration> +    <ProjectConfiguration Include="Debug|Win32"> +      <Configuration>Debug</Configuration> +      <Platform>Win32</Platform> +    </ProjectConfiguration> +    <ProjectConfiguration Include="Debug|x64"> +      <Configuration>Debug</Configuration> +      <Platform>x64</Platform> +    </ProjectConfiguration> +    <ProjectConfiguration Include="Release_CUDA|Win32"> +      <Configuration>Release_CUDA</Configuration> +      <Platform>Win32</Platform> +    </ProjectConfiguration> +    <ProjectConfiguration Include="Release_CUDA|x64"> +      <Configuration>Release_CUDA</Configuration> +      <Platform>x64</Platform> +    </ProjectConfiguration> +    <ProjectConfiguration Include="Release|Win32"> +      <Configuration>Release</Configuration> +      <Platform>Win32</Platform> +    </ProjectConfiguration> +    <ProjectConfiguration Include="Release|x64"> +      <Configuration>Release</Configuration> +      <Platform>x64</Platform> +    </ProjectConfiguration> +  </ItemGroup> +  <PropertyGroup Label="Globals"> +    <ProjectName>astra_mex_log</ProjectName> +    <ProjectGuid>{03B833F5-4FD6-4FBE-AAF4-E3305CD56D2E}</ProjectGuid> +    <RootNamespace>astraMatlab</RootNamespace> +  </PropertyGroup> +  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup> +  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> +  <ImportGroup Label="ExtensionSettings"> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> +  </ImportGroup> +  <PropertyGroup Label="UserMacros" /> +  <PropertyGroup> +    <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir> +    <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir> +    <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir> +    <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir> +    <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir> +    <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir> +    <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir> +    <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt> +  </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +    <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir> +    <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt> +  </PropertyGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +    </ClCompile> +    <Link> +      <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> +      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation> +    </Link> +  </ItemDefinitionGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +    </ClCompile> +    <Link> +      <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> +      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation> +    </Link> +  </ItemDefinitionGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +    </ClCompile> +    <Link> +      <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> +      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation> +    </Link> +  </ItemDefinitionGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +    </ClCompile> +    <Link> +      <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> +      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation> +    </Link> +  </ItemDefinitionGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +    </ClCompile> +    <Link> +      <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> +      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation> +    </Link> +  </ItemDefinitionGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +    </ClCompile> +    <Link> +      <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> +      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation> +    </Link> +  </ItemDefinitionGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +    </ClCompile> +    <Link> +      <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> +      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation> +    </Link> +  </ItemDefinitionGroup> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +    <ClCompile> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> +      <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation> +    </ClCompile> +    <Link> +      <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> +      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation> +    </Link> +  </ItemDefinitionGroup> +  <ItemGroup> +    <ClCompile Include="astra_mex_log_c.cpp" /> +    <ClCompile Include="mexHelpFunctions.cpp" /> +    <ClCompile Include="mexInitFunctions.cpp" /> +  </ItemGroup> +  <ItemGroup> +    <ClInclude Include="mexHelpFunctions.h" /> +    <ClInclude Include="mexInitFunctions.h" /> +  </ItemGroup> +  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> +  <ImportGroup Label="ExtensionTargets"> +  </ImportGroup> +</Project>
\ No newline at end of file diff --git a/matlab/mex/astra_mex_matrix_c.cpp b/matlab/mex/astra_mex_matrix_c.cpp index 01ad08b..aa31383 100644 --- a/matlab/mex/astra_mex_matrix_c.cpp +++ b/matlab/mex/astra_mex_matrix_c.cpp @@ -32,6 +32,7 @@ $Id$   */  #include <mex.h>  #include "mexHelpFunctions.h" +#include "mexInitFunctions.h"  #include <list> @@ -412,6 +413,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		return;  	} +	initASTRAMex(); +  	// SWITCH (MODE)  	if (sMode ==  std::string("get")) {   		astra_mex_matrix_get(nlhs, plhs, nrhs, prhs);  diff --git a/matlab/mex/astra_mex_matrix_vc08.vcproj b/matlab/mex/astra_mex_matrix_vc09.vcproj index 47509f6..3aa17a5 100644 --- a/matlab/mex/astra_mex_matrix_vc08.vcproj +++ b/matlab/mex/astra_mex_matrix_vc09.vcproj @@ -19,7 +19,7 @@  	</ToolFiles>  	<Configurations>  		<Configuration -			Name="Release|Win32" +			Name="Debug_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -40,12 +40,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -55,15 +49,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -84,9 +69,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release|x64" +			Name="Debug_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -107,12 +111,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -122,15 +120,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -151,9 +140,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|Win32" +			Name="Debug|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -174,13 +181,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -190,15 +190,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -219,9 +210,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|x64" +			Name="Debug|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -242,13 +252,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -258,15 +261,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -287,9 +281,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|Win32" +			Name="Release_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -310,14 +322,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -327,16 +331,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -357,9 +351,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|x64" +			Name="Release_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -378,16 +391,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				BrowseInformation="1" -				DebugInformationFormat="4"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -399,17 +402,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -430,9 +422,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug|Win32" +			Name="Release|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -453,13 +463,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -469,16 +472,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -499,9 +492,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug|x64" +			Name="Release|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -520,13 +532,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -538,16 +543,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -568,6 +563,24 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  	</Configurations>  	<References> @@ -585,6 +598,14 @@  			RelativePath=".\mexHelpFunctions.h"  			>  		</File> +		<File +			RelativePath=".\mexInitFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.h" +			> +		</File>  	</Files>  	<Globals>  	</Globals> diff --git a/matlab/mex/astra_mex_matrix_vc11.vcxproj b/matlab/mex/astra_mex_matrix_vc11.vcxproj index 12393bf..abf86a7 100644 --- a/matlab/mex/astra_mex_matrix_vc11.vcxproj +++ b/matlab/mex/astra_mex_matrix_vc11.vcxproj @@ -40,19 +40,15 @@      <RootNamespace>astraMatlab</RootNamespace>    </PropertyGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> -    <ConfigurationType>DynamicLibrary</ConfigurationType> -    <PlatformToolset>v110</PlatformToolset> -  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -60,7 +56,7 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -68,6 +64,10 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset> @@ -75,213 +75,230 @@    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />    <ImportGroup Label="ExtensionSettings">    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup>    <PropertyGroup Label="UserMacros" />    <PropertyGroup>      <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir>      <TargetName>$(ProjectName)_c</TargetName>      <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(CUDA_INC_PATH);$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <BrowseInformation>true</BrowseInformation> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation> -      <TargetMachine>MachineX64</TargetMachine>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup>    <ItemGroup>      <ClCompile Include="astra_mex_matrix_c.cpp" />      <ClCompile Include="mexHelpFunctions.cpp" /> -    <ClCompile Include="mexCopyDataHelpFunctions.cpp"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClCompile> -    <ClCompile Include="mexDataManagerHelpFunctions.cpp" /> +    <ClCompile Include="mexInitFunctions.cpp" />    </ItemGroup>    <ItemGroup>      <ClInclude Include="mexHelpFunctions.h" /> -    <ClInclude Include="mexCopyDataHelpFunctions.h"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClInclude> -    <ClInclude Include="mexDataManagerHelpFunctions.h" /> +    <ClInclude Include="mexInitFunctions.h" />    </ItemGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />    <ImportGroup Label="ExtensionTargets"> diff --git a/matlab/mex/astra_mex_projector3d_c.cpp b/matlab/mex/astra_mex_projector3d_c.cpp index 5381cf6..c3b547f 100644 --- a/matlab/mex/astra_mex_projector3d_c.cpp +++ b/matlab/mex/astra_mex_projector3d_c.cpp @@ -33,6 +33,7 @@ $Id$  #include <mex.h>  #include "mexHelpFunctions.h" +#include "mexInitFunctions.h"  #include "astra/Globals.h" @@ -403,6 +404,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		return;  	} +	initASTRAMex(); +  	// SWITCH (MODE)  	if (sMode == "create") {  		astra_mex_projector3d_create(nlhs, plhs, nrhs, prhs); diff --git a/matlab/mex/astra_mex_projector3d_vc08.vcproj b/matlab/mex/astra_mex_projector3d_vc09.vcproj index bedc53b..b9464a2 100644 --- a/matlab/mex/astra_mex_projector3d_vc08.vcproj +++ b/matlab/mex/astra_mex_projector3d_vc09.vcproj @@ -19,7 +19,7 @@  	</ToolFiles>  	<Configurations>  		<Configuration -			Name="Release|Win32" +			Name="Debug_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -40,12 +40,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -55,15 +49,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -84,9 +69,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release|x64" +			Name="Debug_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -107,12 +111,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -122,15 +120,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -151,9 +140,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|Win32" +			Name="Debug|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -174,13 +181,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -190,15 +190,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -219,9 +210,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|x64" +			Name="Debug|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -242,13 +252,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -258,15 +261,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -287,9 +281,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|Win32" +			Name="Release_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -310,14 +322,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -327,16 +331,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -357,9 +351,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|x64" +			Name="Release_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -378,14 +391,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -397,16 +402,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -427,9 +422,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug|Win32" +			Name="Release|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -450,13 +463,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -466,16 +472,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -496,9 +492,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug|x64" +			Name="Release|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -517,13 +532,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -535,16 +543,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -565,6 +563,24 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  	</Configurations>  	<References> @@ -582,6 +598,14 @@  			RelativePath=".\mexHelpFunctions.h"  			>  		</File> +		<File +			RelativePath=".\mexInitFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.h" +			> +		</File>  	</Files>  	<Globals>  	</Globals> diff --git a/matlab/mex/astra_mex_projector3d_vc11.vcxproj b/matlab/mex/astra_mex_projector3d_vc11.vcxproj index 7981806..42eb0f1 100644 --- a/matlab/mex/astra_mex_projector3d_vc11.vcxproj +++ b/matlab/mex/astra_mex_projector3d_vc11.vcxproj @@ -40,19 +40,15 @@      <RootNamespace>astraMatlab</RootNamespace>    </PropertyGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> -    <ConfigurationType>DynamicLibrary</ConfigurationType> -    <PlatformToolset>v110</PlatformToolset> -  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -60,7 +56,7 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -68,6 +64,10 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset> @@ -75,210 +75,230 @@    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />    <ImportGroup Label="ExtensionSettings">    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup>    <PropertyGroup Label="UserMacros" />    <PropertyGroup>      <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir>      <TargetName>$(ProjectName)_c</TargetName>      <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_INC_PATH);..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_INC_PATH);..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup>    <ItemGroup>      <ClCompile Include="astra_mex_projector3d_c.cpp" />      <ClCompile Include="mexHelpFunctions.cpp" /> -    <ClCompile Include="mexCopyDataHelpFunctions.cpp"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClCompile> -    <ClCompile Include="mexDataManagerHelpFunctions.cpp" /> +    <ClCompile Include="mexInitFunctions.cpp" />    </ItemGroup>    <ItemGroup>      <ClInclude Include="mexHelpFunctions.h" /> -    <ClInclude Include="mexCopyDataHelpFunctions.h"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClInclude> -    <ClInclude Include="mexDataManagerHelpFunctions.h" /> +    <ClInclude Include="mexInitFunctions.h" />    </ItemGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />    <ImportGroup Label="ExtensionTargets"> diff --git a/matlab/mex/astra_mex_projector_c.cpp b/matlab/mex/astra_mex_projector_c.cpp index 58cd953..204ba8e 100644 --- a/matlab/mex/astra_mex_projector_c.cpp +++ b/matlab/mex/astra_mex_projector_c.cpp @@ -34,6 +34,7 @@ $Id$  #include <mex.h>  #include "mexHelpFunctions.h" +#include "mexInitFunctions.h"  #include "astra/AstraObjectManager.h"  #include "astra/Projector2D.h" @@ -476,6 +477,8 @@ void mexFunction(int nlhs, mxArray* plhs[],  		return;  	} +	initASTRAMex(); +  	// SWITCH (MODE)  	if (sMode == "create") {  		astra_mex_projector_create(nlhs, plhs, nrhs, prhs); diff --git a/matlab/mex/astra_mex_projector_vc08.vcproj b/matlab/mex/astra_mex_projector_vc09.vcproj index 1380061..05c207f 100644 --- a/matlab/mex/astra_mex_projector_vc08.vcproj +++ b/matlab/mex/astra_mex_projector_vc09.vcproj @@ -19,7 +19,7 @@  	</ToolFiles>  	<Configurations>  		<Configuration -			Name="Release|Win32" +			Name="Debug_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -40,12 +40,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -55,15 +49,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -84,9 +69,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release|x64" +			Name="Debug_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -107,12 +111,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -122,15 +120,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -151,9 +140,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|Win32" +			Name="Debug|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -174,13 +181,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -190,15 +190,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -219,9 +210,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|x64" +			Name="Debug|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -242,13 +252,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories=""$(MATLAB_ROOT)\extern\include\";"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -258,15 +261,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -287,9 +281,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|Win32" +			Name="Release_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -310,14 +322,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -327,16 +331,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -357,9 +351,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|x64" +			Name="Release_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -378,16 +391,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				BrowseInformation="1" -				DebugInformationFormat="4"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -399,17 +402,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -430,9 +422,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug|Win32" +			Name="Release|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -453,13 +463,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -469,16 +472,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -499,9 +492,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug|x64" +			Name="Release|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -520,13 +532,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -538,16 +543,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -568,6 +563,24 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  	</Configurations>  	<References> @@ -585,6 +598,14 @@  			RelativePath=".\mexHelpFunctions.h"  			>  		</File> +		<File +			RelativePath=".\mexInitFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.h" +			> +		</File>  	</Files>  	<Globals>  	</Globals> diff --git a/matlab/mex/astra_mex_projector_vc11.vcxproj b/matlab/mex/astra_mex_projector_vc11.vcxproj index 3ab1806..e944949 100644 --- a/matlab/mex/astra_mex_projector_vc11.vcxproj +++ b/matlab/mex/astra_mex_projector_vc11.vcxproj @@ -40,19 +40,15 @@      <RootNamespace>astraMatlab</RootNamespace>    </PropertyGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> -    <ConfigurationType>DynamicLibrary</ConfigurationType> -    <PlatformToolset>v110</PlatformToolset> -  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -60,7 +56,7 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -68,6 +64,10 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset> @@ -75,213 +75,230 @@    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />    <ImportGroup Label="ExtensionSettings">    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup>    <PropertyGroup Label="UserMacros" />    <PropertyGroup>      <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir>      <TargetName>$(ProjectName)_c</TargetName>      <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_INC_PATH);..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <BrowseInformation>true</BrowseInformation> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation> -      <TargetMachine>MachineX64</TargetMachine>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup>    <ItemGroup>      <ClCompile Include="astra_mex_projector_c.cpp" />      <ClCompile Include="mexHelpFunctions.cpp" /> -    <ClCompile Include="mexCopyDataHelpFunctions.cpp"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClCompile> -    <ClCompile Include="mexDataManagerHelpFunctions.cpp" /> +    <ClCompile Include="mexInitFunctions.cpp" />    </ItemGroup>    <ItemGroup>      <ClInclude Include="mexHelpFunctions.h" /> -    <ClInclude Include="mexCopyDataHelpFunctions.h"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClInclude> -    <ClInclude Include="mexDataManagerHelpFunctions.h" /> +    <ClInclude Include="mexInitFunctions.h" />    </ItemGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />    <ImportGroup Label="ExtensionTargets"> diff --git a/matlab/mex/astra_mex_vc08.vcproj b/matlab/mex/astra_mex_vc09.vcproj index 58c1e0a..e4d7d07 100644 --- a/matlab/mex/astra_mex_vc08.vcproj +++ b/matlab/mex/astra_mex_vc09.vcproj @@ -19,7 +19,7 @@  	</ToolFiles>  	<Configurations>  		<Configuration -			Name="Release|Win32" +			Name="Debug_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -40,12 +40,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -55,15 +49,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -84,9 +69,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release|x64" +			Name="Debug_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -107,12 +111,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -122,15 +120,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -151,9 +140,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|Win32" +			Name="Debug|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -174,13 +181,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -190,15 +190,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -219,9 +210,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Release_CUDA|x64" +			Name="Debug|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -242,13 +252,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="2" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\lib\include\cuda;..\..\include\;" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="2" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -258,15 +261,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -287,9 +281,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="0" +				RuntimeLibrary="3" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="true" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|Win32" +			Name="Release_CUDA|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -310,14 +322,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -327,16 +331,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -357,9 +351,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug_CUDA|x64" +			Name="Release_CUDA|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -378,16 +391,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories=""$(CUDA_INC_PATH)";$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				PreprocessorDefinitions="ASTRA_CUDA" -				RuntimeLibrary="3" -				BrowseInformation="1" -				DebugInformationFormat="4"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -399,17 +402,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="AstraCuda64D.lib libmex.lib libmx.lib libut.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -430,9 +422,27 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;"$(CUDA_INC_PATH)";..\..\lib\include;..\..\include" +				PreprocessorDefinitions="ASTRA_CUDA;__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="AstraCuda64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  		<Configuration -			Name="Debug|Win32" +			Name="Release|Win32"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -453,13 +463,6 @@  				Name="VCMIDLTool"  			/>  			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3" -				DebugInformationFormat="4" -			/> -			<Tool  				Name="VCManagedResourceCompilerTool"  			/>  			<Tool @@ -469,16 +472,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra32D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" -				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft" -				ModuleDefinitionFile="mex.def" -				GenerateDebugInformation="true" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -499,9 +492,28 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				EnableEnhancedInstructionSet="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra32.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw32" +				AdditionalLibraryDirectories="..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;..\..\lib\win32" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="1" +			/>  		</Configuration>  		<Configuration -			Name="Debug|x64" +			Name="Release|x64"  			OutputDirectory="$(SolutionDir)bin\$(PlatformName)\$(ConfigurationName)"  			IntermediateDirectory="$(OutDir)\obj\$(ProjectName)"  			ConfigurationType="2" @@ -520,13 +532,6 @@  			/>  			<Tool  				Name="VCMIDLTool" -				TargetEnvironment="3" -			/> -			<Tool -				Name="VCCLCompilerTool" -				Optimization="0" -				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" -				RuntimeLibrary="3"  			/>  			<Tool  				Name="VCManagedResourceCompilerTool" @@ -538,16 +543,6 @@  				Name="VCPreLinkEventTool"  			/>  			<Tool -				Name="VCLinkerTool" -				AdditionalDependencies="Astra64D.lib libmex.lib libmx.lib" -				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" -				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft" -				ModuleDefinitionFile="mex.def" -				RandomizedBaseAddress="1" -				DataExecutionPrevention="0" -				TargetMachine="17" -			/> -			<Tool  				Name="VCALinkTool"  			/>  			<Tool @@ -568,6 +563,24 @@  			<Tool  				Name="VCPostBuildEventTool"  			/> +			<Tool +				Name="VCCLCompilerTool" +				AdditionalIncludeDirectories="$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include" +				PreprocessorDefinitions="__SSE2__" +				Optimization="2" +				RuntimeLibrary="2" +				OpenMP="true" +				AdditionalOptions="/MP" +			/> +			<Tool +				Name="VCLinkerTool" +				AdditionalDependencies="Astra64.lib libmex.lib libmx.lib libut.lib" +				OutputFile="$(OutDir)\$(ProjectName)_c.mexw64" +				AdditionalLibraryDirectories="..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;..\..\lib\x64" +				ModuleDefinitionFile="mex.def" +				GenerateDebugInformation="false" +				TargetMachine="17" +			/>  		</Configuration>  	</Configurations>  	<References> @@ -585,6 +598,14 @@  			RelativePath=".\mexHelpFunctions.h"  			>  		</File> +		<File +			RelativePath=".\mexInitFunctions.cpp" +			> +		</File> +		<File +			RelativePath=".\mexInitFunctions.h" +			> +		</File>  	</Files>  	<Globals>  	</Globals> diff --git a/matlab/mex/astra_mex_vc11.vcxproj b/matlab/mex/astra_mex_vc11.vcxproj index 2e6857c..f1324b4 100644 --- a/matlab/mex/astra_mex_vc11.vcxproj +++ b/matlab/mex/astra_mex_vc11.vcxproj @@ -40,19 +40,15 @@      <RootNamespace>astraMatlab</RootNamespace>    </PropertyGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> -    <ConfigurationType>DynamicLibrary</ConfigurationType> -    <PlatformToolset>v110</PlatformToolset> -  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -60,7 +56,7 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="Configuration"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> @@ -68,6 +64,10 @@      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset>    </PropertyGroup> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> +    <ConfigurationType>DynamicLibrary</ConfigurationType> +    <PlatformToolset>v110</PlatformToolset> +  </PropertyGroup>    <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">      <ConfigurationType>DynamicLibrary</ConfigurationType>      <PlatformToolset>v110</PlatformToolset> @@ -75,213 +75,230 @@    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />    <ImportGroup Label="ExtensionSettings">    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup> -  <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> +  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />    </ImportGroup>    <PropertyGroup Label="UserMacros" />    <PropertyGroup>      <_ProjectFileVersion>11.0.60610.1</_ProjectFileVersion>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir>      <TargetName>$(ProjectName)_c</TargetName>      <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw32</TargetExt>    </PropertyGroup> -  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> +  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <OutDir>$(SolutionDir)bin\$(Platform)\$(Configuration)\</OutDir>      <IntDir>$(OutDir)obj\$(ProjectName)\</IntDir> +    <TargetName>$(ProjectName)_c</TargetName> +    <TargetExt>.mexw64</TargetExt>    </PropertyGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Debug;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">      <ClCompile> -      <Optimization>MaxSpeed</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\lib\include\cuda;..\..\include\;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>Disabled</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Debug;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug_CUDA|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(CUDA_INC_PATH);$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <PreprocessorDefinitions>ASTRA_CUDA;%(PreprocessorDefinitions)</PreprocessorDefinitions> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <BrowseInformation>true</BrowseInformation> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>ASTRA_CUDA;__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>AstraCuda64D.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>AstraCuda64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release_CUDA;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation> -      <TargetMachine>MachineX64</TargetMachine>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> -      <DebugInformationFormat>EditAndContinue</DebugInformationFormat> +      <EnableEnhancedInstructionSet>StreamingSIMDExtensions2</EnableEnhancedInstructionSet> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra32D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw32</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\win32;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra32.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\win32\;..\..\bin\win32\Release;$(MATLAB_ROOT)\extern\lib\win32\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile>        <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup> -  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> -    <Midl> -      <TargetEnvironment>X64</TargetEnvironment> -    </Midl> +  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">      <ClCompile> -      <Optimization>Disabled</Optimization> -      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> -      <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> +      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> +      <AdditionalIncludeDirectories>$(MATLAB_ROOT)\extern\include\;$(CUDA_PATH)\include;..\..\lib\include;..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>        <OpenMPSupport>true</OpenMPSupport> +      <Optimization>MaxSpeed</Optimization> +      <PreprocessorDefinitions>__SSE2__;%(PreprocessorDefinitions)</PreprocessorDefinitions> +      <MultiProcessorCompilation>true</MultiProcessorCompilation>      </ClCompile>      <Link> -      <AdditionalDependencies>Astra64D.lib;libmex.lib;libmx.lib;%(AdditionalDependencies)</AdditionalDependencies>        <OutputFile>$(OutDir)$(ProjectName)_c.mexw64</OutputFile> -      <AdditionalLibraryDirectories>..\..\bin\x64;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> +      <AdditionalDependencies>Astra64.lib;libmex.lib;libmx.lib;libut.lib;%(AdditionalDependencies)</AdditionalDependencies> +      <AdditionalLibraryDirectories>..\..\lib\x64\;..\..\bin\x64\Release;$(MATLAB_ROOT)\extern\lib\win64\microsoft;%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories>        <ModuleDefinitionFile>mex.def</ModuleDefinitionFile> -      <TargetMachine>MachineX64</TargetMachine> +      <GenerateDebugInformation>true</GenerateDebugInformation>      </Link>    </ItemDefinitionGroup>    <ItemGroup>      <ClCompile Include="astra_mex_c.cpp" />      <ClCompile Include="mexHelpFunctions.cpp" /> -    <ClCompile Include="mexCopyDataHelpFunctions.cpp"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClCompile> -    <ClCompile Include="mexDataManagerHelpFunctions.cpp" /> +    <ClCompile Include="mexInitFunctions.cpp" />    </ItemGroup>    <ItemGroup>      <ClInclude Include="mexHelpFunctions.h" /> -    <ClInclude Include="mexCopyDataHelpFunctions.h"> -      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release_CUDA|x64'">true</ExcludedFromBuild> -    </ClInclude> -    <ClInclude Include="mexDataManagerHelpFunctions.h" /> +    <ClInclude Include="mexInitFunctions.h" />    </ItemGroup>    <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />    <ImportGroup Label="ExtensionTargets"> diff --git a/matlab/mex/mexCopyDataHelpFunctions.cpp b/matlab/mex/mexCopyDataHelpFunctions.cpp index 80fb834..4db6abd 100644 --- a/matlab/mex/mexCopyDataHelpFunctions.cpp +++ b/matlab/mex/mexCopyDataHelpFunctions.cpp @@ -263,7 +263,7 @@ copyMexToCFloat32Array(const mxArray * const in,  #pragma omp parallel  	{  		// fill with scalar value -		if (mexIsScalar(in)) { +		if (mexIsScalar(in) || mxIsEmpty(in)) {  			astra::float32 fValue = 0.f;  			if (!mxIsEmpty(in)) {  				fValue = (astra::float32)mxGetScalar(in); diff --git a/matlab/mex/mexDataManagerHelpFunctions.cpp b/matlab/mex/mexDataManagerHelpFunctions.cpp index d482428..1794abb 100644 --- a/matlab/mex/mexDataManagerHelpFunctions.cpp +++ b/matlab/mex/mexDataManagerHelpFunctions.cpp @@ -285,7 +285,7 @@ allocateDataObject(const std::string & sDataType,  		astra::Config* cfg = structToConfig("ProjectionGeometry3D", geometry);  		// FIXME: Change how the base class is created. (This is duplicated  		// in Projector3D.cpp.) -		std::string type = cfg->self->getAttribute("type"); +		std::string type = cfg->self.getAttribute("type");  		astra::CProjectionGeometry3D* pGeometry = 0;  		if (type == "parallel3d") {  			pGeometry = new astra::CParallelProjectionGeometry3D(); diff --git a/matlab/mex/mexHelpFunctions.cpp b/matlab/mex/mexHelpFunctions.cpp index c0ac711..87a9672 100644 --- a/matlab/mex/mexHelpFunctions.cpp +++ b/matlab/mex/mexHelpFunctions.cpp @@ -185,7 +185,7 @@ Config* structToConfig(string rootname, const mxArray* pStruct)  }  //----------------------------------------------------------------------------------------- -bool structToXMLNode(XMLNode* node, const mxArray* pStruct)  +bool structToXMLNode(XMLNode node, const mxArray* pStruct)   {  	// loop all fields  	int nfields = mxGetNumberOfFields(pStruct); @@ -199,16 +199,16 @@ bool structToXMLNode(XMLNode* node, const mxArray* pStruct)  		if (mxIsChar(pField)) {  			string sValue = mexToString(pField);  			if (sFieldName == "type") { -				node->addAttribute("type", sValue); +				node.addAttribute("type", sValue);  			} else { -				delete node->addChildNode(sFieldName, sValue); +				node.addChildNode(sFieldName, sValue);  			}  		}  		// scalar  		else if (mxIsNumeric(pField) && mxGetM(pField)*mxGetN(pField) == 1) {  			string sValue = mexToString(pField); -			delete node->addChildNode(sFieldName, sValue); +			node.addChildNode(sFieldName, sValue);  		}  		// numerical array @@ -217,20 +217,9 @@ bool structToXMLNode(XMLNode* node, const mxArray* pStruct)  				mexErrMsgTxt("Numeric input must be double.");  				return false;  			} -			XMLNode* listbase = node->addChildNode(sFieldName); -			listbase->addAttribute("listsize", mxGetM(pField)*mxGetN(pField)); +			XMLNode listbase = node.addChildNode(sFieldName);  			double* pdValues = mxGetPr(pField); -			int index = 0; -			for (unsigned int row = 0; row < mxGetM(pField); row++) { -				for (unsigned int col = 0; col < mxGetN(pField); col++) { -					XMLNode* item = listbase->addChildNode("ListItem"); -					item->addAttribute("index", index); -					item->addAttribute("value", pdValues[col*mxGetM(pField)+row]); -					index++; -					delete item; -				} -			} -			delete listbase; +			listbase.setContent(pdValues, mxGetN(pField), mxGetM(pField), true);  		}  		// not castable to a single string @@ -240,9 +229,8 @@ bool structToXMLNode(XMLNode* node, const mxArray* pStruct)  				if (!ret)  					return false;  			} else { -				XMLNode* newNode = node->addChildNode(sFieldName); +				XMLNode newNode = node.addChildNode(sFieldName);  				bool ret = structToXMLNode(newNode, pField); -				delete newNode;  				if (!ret)  					return false;  			} @@ -254,7 +242,7 @@ bool structToXMLNode(XMLNode* node, const mxArray* pStruct)  }  //-----------------------------------------------------------------------------------------  // Options struct to xml node -bool optionsToXMLNode(XMLNode* node, const mxArray* pOptionStruct) +bool optionsToXMLNode(XMLNode node, const mxArray* pOptionStruct)  {  	// loop all fields  	int nfields = mxGetNumberOfFields(pOptionStruct); @@ -262,7 +250,7 @@ bool optionsToXMLNode(XMLNode* node, const mxArray* pOptionStruct)  		std::string sFieldName = std::string(mxGetFieldNameByNumber(pOptionStruct, i));  		const mxArray* pField = mxGetFieldByNumber(pOptionStruct, 0, i); -		if (node->hasOption(sFieldName)) { +		if (node.hasOption(sFieldName)) {  			mexErrMsgTxt("Duplicate option");  			return false;  		} @@ -270,7 +258,7 @@ bool optionsToXMLNode(XMLNode* node, const mxArray* pOptionStruct)  		// string or scalar  		if (mxIsChar(pField) || mexIsScalar(pField)) {  			string sValue = mexToString(pField); -			node->addOption(sFieldName, sValue); +			node.addOption(sFieldName, sValue);  		}  		// numerical array  		else if (mxIsNumeric(pField) && mxGetM(pField)*mxGetN(pField) > 1) { @@ -279,21 +267,10 @@ bool optionsToXMLNode(XMLNode* node, const mxArray* pOptionStruct)  				return false;  			} -			XMLNode* listbase = node->addChildNode("Option"); -			listbase->addAttribute("key", sFieldName); -			listbase->addAttribute("listsize", mxGetM(pField)*mxGetN(pField)); +			XMLNode listbase = node.addChildNode("Option"); +			listbase.addAttribute("key", sFieldName);  			double* pdValues = mxGetPr(pField); -			int index = 0; -			for (unsigned int row = 0; row < mxGetM(pField); row++) { -				for (unsigned int col = 0; col < mxGetN(pField); col++) { -					XMLNode* item = listbase->addChildNode("ListItem"); -					item->addAttribute("index", index); -					item->addAttribute("value", pdValues[col*mxGetM(pField)+row]); -					index++; -					delete item; -				} -			} -			delete listbase; +			listbase.setContent(pdValues, mxGetN(pField), mxGetM(pField), true);  		} else {  			mexErrMsgTxt("Unsupported option type");  			return false; @@ -343,30 +320,29 @@ mxArray* configToStruct(astra::Config* cfg)  }  //----------------------------------------------------------------------------------------- -mxArray* XMLNodeToStruct(astra::XMLNode* node) +mxArray* XMLNodeToStruct(astra::XMLNode node)  {  	std::map<std::string, mxArray*> mList;  	std::map<std::string, mxArray*> mOptions;  	// type_attribute -	if (node->hasAttribute("type")) { -		mList["type"] = mxCreateString(node->getAttribute("type").c_str()); +	if (node.hasAttribute("type")) { +		mList["type"] = mxCreateString(node.getAttribute("type").c_str());  	} -	list<XMLNode*> nodes = node->getNodes(); -	for (list<XMLNode*>::iterator it = nodes.begin(); it != nodes.end(); it++) { -		XMLNode* subnode = (*it); +	list<XMLNode> nodes = node.getNodes(); +	for (list<XMLNode>::iterator it = nodes.begin(); it != nodes.end(); it++) { +		XMLNode subnode = (*it);  		// option -		if (subnode->getName() == "Option") { -			mOptions[subnode->getAttribute("key")] = stringToMxArray(subnode->getAttribute("value")); +		if (subnode.getName() == "Option") { +			mOptions[subnode.getAttribute("key")] = stringToMxArray(subnode.getAttribute("value"));  		}  		// regular content  		else { -			mList[subnode->getName()] = stringToMxArray(subnode->getContent()); +			mList[subnode.getName()] = stringToMxArray(subnode.getContent());  		} -		delete subnode;  	}  	if (mOptions.size() > 0) mList["options"] = buildStruct(mOptions); diff --git a/matlab/mex/mexHelpFunctions.h b/matlab/mex/mexHelpFunctions.h index f9ffcf2..3ac5bd8 100644 --- a/matlab/mex/mexHelpFunctions.h +++ b/matlab/mex/mexHelpFunctions.h @@ -58,13 +58,13 @@ mxArray* anyToMxArray(boost::any _any);  // turn a MATLAB struct into a Config object  astra::Config* structToConfig(string rootname, const mxArray* pStruct); -bool structToXMLNode(astra::XMLNode* node, const mxArray* pStruct); -bool optionsToXMLNode(astra::XMLNode* node, const mxArray* pOptionStruct); +bool structToXMLNode(astra::XMLNode node, const mxArray* pStruct); +bool optionsToXMLNode(astra::XMLNode node, const mxArray* pOptionStruct);  std::map<std::string, mxArray*> parseStruct(const mxArray* pInput);  // turn a Config object into a MATLAB struct  mxArray* configToStruct(astra::Config* cfg); -mxArray* XMLNodeToStruct(astra::XMLNode* xml); +mxArray* XMLNodeToStruct(astra::XMLNode xml);  mxArray* stringToMxArray(std::string input);  mxArray* buildStruct(std::map<std::string, mxArray*> mInput); diff --git a/matlab/mex/mexInitFunctions.cpp b/matlab/mex/mexInitFunctions.cpp new file mode 100644 index 0000000..d8a50d7 --- /dev/null +++ b/matlab/mex/mexInitFunctions.cpp @@ -0,0 +1,24 @@ +#include <mex.h> +#include "astra/Logging.h" + +bool mexIsInitialized=false; + +/** + * Callback to print log message to Matlab window. + * + */ +void logCallBack(const char *msg, size_t len){ +    mexPrintf(msg); +} + +/** + * Initialize mex functions. + * + */ +void initASTRAMex(){ +    if(mexIsInitialized) return; +    if(!astra::CLogger::setCallbackScreen(&logCallBack)){ +        mexErrMsgTxt("Error initializing mex functions."); +    } +    mexIsInitialized=true; +} diff --git a/matlab/mex/mexInitFunctions.h b/matlab/mex/mexInitFunctions.h new file mode 100644 index 0000000..f16e9c9 --- /dev/null +++ b/matlab/mex/mexInitFunctions.h @@ -0,0 +1,6 @@ +#ifndef _INC_ASTRA_MEX_INITFUNCTIONS +#define _INC_ASTRA_MEX_INITFUNCTIONS + +void initASTRAMex(); + +#endif
\ No newline at end of file diff --git a/matlab/tools/astra_mex_log.m b/matlab/tools/astra_mex_log.m new file mode 100644 index 0000000..28cfa18 --- /dev/null +++ b/matlab/tools/astra_mex_log.m @@ -0,0 +1,33 @@ +function [varargout] = astra_mex_log(varargin) +%------------------------------------------------------------------------ +% Reference page in Help browser +%    <a href="matlab:docsearch('astra_mex_log' )">astra_mex_log</a>. +%------------------------------------------------------------------------ +%------------------------------------------------------------------------ +% This file is part of the ASTRA Toolbox +%  +% Copyright: 2010-2015, iMinds-Vision Lab, University of Antwerp +%            2014-2015, CWI, Amsterdam +% License: Open Source under GPLv3 +% Contact: astra@uantwerpen.be +% Website: http://sf.net/projects/astra-toolbox +%------------------------------------------------------------------------ +% $Id$ +if size(varargin,2)==2 && (strcmp(varargin{1},'debug') || strcmp(varargin{1},'info') || strcmp(varargin{1},'warn') || strcmp(varargin{1},'error')) +    d = dbstack(1); +    if size(d,1)==0 +        astra_mex_log_c(varargin{1},'Unknown',0,varargin{2}) +    else +        astra_mex_log_c(varargin{1},d(1).file,d(1).line,varargin{2}) +    end +else +    if nargout == 0 +        astra_mex_log_c(varargin{:}); +        if exist('ans','var') +            varargout{1} = ans; +        end +    else +        varargout = cell(1,nargout); +        [varargout{:}] = astra_mex_log_c(varargin{:}); +    end +end
\ No newline at end of file diff --git a/matlab/tools/opTomo.m b/matlab/tools/opTomo.m new file mode 100644 index 0000000..14128d2 --- /dev/null +++ b/matlab/tools/opTomo.m @@ -0,0 +1,280 @@ +%OPTOMO Wrapper for ASTRA tomography projector +% +%   OP = OPTOMO(TYPE, PROJ_GEOM, VOL_GEOM) generates a Spot operator OP for +%   the ASTRA forward and backprojection operations. The string TYPE +%   determines the model used for the projections. Possible choices are: +%       TYPE:  * using the CPU +%                'line'   - use a line kernel +%                'linear' - use a Joseph kernel +%                'strip'  - use the strip kernel +%              * using the GPU +%                'cuda'  - use a Joseph kernel, on the GPU, currently using +%                          'cuda' is the only option in 3D. +%   The PROJ_GEOM and VOL_GEOM structures are projection and volume +%   geometries as used in the ASTRA toolbox. +% +%   OP = OPTOMO(TYPE, PROJ_GEOM, VOL_GEOM, GPU_INDEX) also specify the +%   index of the GPU that should be used, if multiple GPUs are present in +%   the host system. By default GPU_INDEX is 0. +% +%   Note: this code depends on the Matlab toolbox  +%   "Spot - A Linear-Operator Toolbox" which can be downloaded from +%   http://www.cs.ubc.ca/labs/scl/spot/ +%-------------------------------------------------------------------------- +% This file is part of the ASTRA Toolbox +%  +% Copyright: 2014-2015, CWI, Amsterdam +% License:   Open Source under GPLv3 +% Author:    Folkert Bleichrodt +% Contact:   F.Bleichrodt@cwi.nl +% Website:   http://sf.net/projects/astra-toolbox +%-------------------------------------------------------------------------- +% $Id$ + +classdef opTomo < opSpot +     +    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +    % Properties +    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +    properties ( Access = private ) +        % multiplication function +        funHandle +        % ASTRA identifiers +        sino_id +        vol_id +        fp_alg_id +        bp_alg_id +        % ASTRA IDs handle +        astra_handle +        % geometries +        proj_geom; +        vol_geom; +    end % properties +     +    properties ( SetAccess = private, GetAccess = public ) +        proj_size +        vol_size +    end % properties +     +    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +    % Methods - public +    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +    methods + +        %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +        % opTomo - constructor +        %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +        function op = opTomo(type, proj_geom, vol_geom, gpu_index) +             +            if nargin < 4 || isempty(gpu_index), gpu_index = 0; end +             +            proj_size = astra_geom_size(proj_geom); +            vol_size  = astra_geom_size(vol_geom); +             +            % construct operator +            op = op@opSpot('opTomo', prod(proj_size), prod(vol_size)); +             +            % determine the dimension +            is2D = ~isfield(vol_geom, 'GridSliceCount'); +            gpuEnabled = strcmpi(type, 'cuda'); +             +            if is2D +                % create a projector +                proj_id = astra_create_projector(type, proj_geom, vol_geom); +                 +                % create a function handle +                op.funHandle = @opTomo_intrnl2D; +                 +                % Initialize ASTRA data objects. +                % projection data +                sino_id = astra_mex_data2d('create', '-sino', proj_geom, 0); +                % image data +                vol_id  = astra_mex_data2d('create', '-vol', vol_geom, 0); +                 +                % Setup forward and back projection algorithms. +                if gpuEnabled +                    fp_alg = 'FP_CUDA'; +                    bp_alg = 'BP_CUDA'; +                    proj_id = []; +                else +                    fp_alg = 'FP'; +                    bp_alg = 'BP'; +                    proj_id = astra_create_projector(type, proj_geom, vol_geom); +                end +                 +                % configuration for ASTRA fp algorithm +                cfg_fp = astra_struct(fp_alg); +                cfg_fp.ProjectorId      = proj_id; +                cfg_fp.ProjectionDataId = sino_id; +                cfg_fp.VolumeDataId     = vol_id; +                 +                % configuration for ASTRA bp algorithm +                cfg_bp = astra_struct(bp_alg); +                cfg_bp.ProjectionDataId     = sino_id; +                cfg_bp.ProjectorId          = proj_id; +                cfg_bp.ReconstructionDataId = vol_id; +                 +                % set GPU index +                if gpuEnabled +                    cfg_fp.option.GPUindex = gpu_index; +                    cfg_bp.option.GPUindex = gpu_index; +                end +                 +                fp_alg_id = astra_mex_algorithm('create', cfg_fp); +                bp_alg_id = astra_mex_algorithm('create', cfg_bp); +                 +                % Create handle to ASTRA objects, so they will be deleted +                % if opTomo is deleted. +                op.astra_handle = opTomo_helper_handle([sino_id, ... +                    vol_id, proj_id, fp_alg_id, bp_alg_id]); +                 +                op.fp_alg_id   = fp_alg_id; +                op.bp_alg_id   = bp_alg_id; +                op.sino_id     = sino_id; +                op.vol_id      = vol_id; +            else +                % 3D +                % only gpu/cuda code for 3D +                if ~gpuEnabled +                    error(['Only type ' 39 'cuda' 39 ' is supported ' ... +                           'for 3D geometries.']) +                end +                 +                % create a function handle +                op.funHandle = @opTomo_intrnl3D; +            end +       +             +            % pass object properties +            op.proj_size   = proj_size; +            op.vol_size    = vol_size; +            op.proj_geom   = proj_geom; +            op.vol_geom    = vol_geom; +            op.cflag       = false; +            op.sweepflag   = false; + +        end % opTomo - constructor +         +    end % methods - public + +    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +    % Methods - protected +    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +    methods( Access = protected ) + +        % multiplication +        function y = multiply(op,x,mode) +             +            % ASTRA cannot handle sparse vectors +            if issparse(x) +                x = full(x); +            end +             +            % convert input to single +            if isa(x, 'single') == false +                x = single(x); +            end +             +            % the multiplication +            y = op.funHandle(op, x, mode); +             +            % make sure output is column vector +            y = y(:); +             +        end % multiply +         +    end % methods - protected +     +    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +    % Methods - private +    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +    methods( Access = private ) +         +        % 2D projection code +        function y = opTomo_intrnl2D(op,x,mode) +                        +            if mode == 1               +                % X is passed as a vector, reshape it into an image.              +                x = reshape(x, op.vol_size); +                 +                % Matlab data copied to ASTRA data +                astra_mex_data2d('store', op.vol_id, x); +                 +                % forward projection +                astra_mex_algorithm('iterate', op.fp_alg_id); +                 +                % retrieve Matlab array +                y = astra_mex_data2d('get_single', op.sino_id); +            else +                % X is passed as a vector, reshape it into a sinogram. +                x = reshape(x, op.proj_size); +                 +                % Matlab data copied to ASTRA data +                astra_mex_data2d('store', op.sino_id, x); +                 +                % backprojection +                astra_mex_algorithm('iterate', op.bp_alg_id); +                 +                % retrieve Matlab array +                y = astra_mex_data2d('get_single', op.vol_id); +            end +        end % opTomo_intrnl2D +         +         +        % 3D projection code +        function y = opTomo_intrnl3D(op,x,mode) +             +            if mode == 1 +                % X is passed as a vector, reshape it into an image +                x = reshape(x, op.vol_size); +                 +                % initialize output +                y = zeros(op.proj_size, 'single'); +                 +                % link matlab array to ASTRA +                vol_id  = astra_mex_data3d_c('link', '-vol', op.vol_geom, x, 0); +                sino_id = astra_mex_data3d_c('link', '-sino', op.proj_geom, y, 1); +                 +                % initialize fp algorithm +                cfg = astra_struct('FP3D_CUDA'); +                cfg.ProjectionDataId = sino_id; +                cfg.VolumeDataId     = vol_id; +                 +                alg_id = astra_mex_algorithm('create', cfg); +                              +                % forward projection +                astra_mex_algorithm('iterate', alg_id); +                 +                % cleanup +                astra_mex_data3d('delete', vol_id); +                astra_mex_data3d('delete', sino_id); +            else +                % X is passed as a vector, reshape it into projection data +                x = reshape(x, op.proj_size); +                 +                % initialize output +                y = zeros(op.vol_size,'single'); +                 +                % link matlab array to ASTRA +                vol_id  = astra_mex_data3d_c('link', '-vol', op.vol_geom, y, 1); +                sino_id = astra_mex_data3d_c('link', '-sino', op.proj_geom, x, 0); +                                 +                % initialize bp algorithm +                cfg = astra_struct('BP3D_CUDA'); +                cfg.ProjectionDataId     = sino_id; +                cfg.ReconstructionDataId = vol_id; +                 +                alg_id = astra_mex_algorithm('create', cfg); + +                % backprojection +                astra_mex_algorithm('iterate', alg_id); +                 +                % cleanup +                astra_mex_data3d('delete', vol_id); +                astra_mex_data3d('delete', sino_id); +            end  +        end % opTomo_intrnl3D +         +    end % methods - private +  +end % classdef diff --git a/matlab/tools/opTomo_helper_handle.m b/matlab/tools/opTomo_helper_handle.m new file mode 100644 index 0000000..d9be51f --- /dev/null +++ b/matlab/tools/opTomo_helper_handle.m @@ -0,0 +1,29 @@ +classdef opTomo_helper_handle < handle +    %ASTRA.OPTOMO_HELPER_HANDLE Handle class around an astra identifier +    %   Automatically deletes the data when object is deleted.  +    %   Multiple id's can be passed as an array as input to  +    %   the constructor. +     +    properties +        id +    end +     +    methods +        function obj = opTomo_helper_handle(id) +            obj.id = id; +        end +        function delete(obj) +            for i = 1:numel(obj.id) +                % delete any kind of object +                astra_mex_data2d('delete', obj.id(i)); +                astra_mex_data3d('delete', obj.id(i)); +                astra_mex_algorithm('delete', obj.id(i)); +                astra_mex_matrix('delete', obj.id(i)); +                astra_mex_projector('delete', obj.id(i)); +                astra_mex_projector3d('delete', obj.id(i)) +            end +        end +    end +     +end + diff --git a/python/astra/ASTRAProjector.py b/python/astra/ASTRAProjector.py deleted file mode 100644 index 96acb10..0000000 --- a/python/astra/ASTRAProjector.py +++ /dev/null @@ -1,138 +0,0 @@ -#----------------------------------------------------------------------- -#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam -# -#Author: Daniel M. Pelt -#Contact: D.M.Pelt@cwi.nl -#Website: http://dmpelt.github.io/pyastratoolbox/ -# -# -#This file is part of the Python interface to the -#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). -# -#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. -# -#----------------------------------------------------------------------- - -import math -from . import creators as ac -from . import data2d - - -class ASTRAProjector2DTranspose(): -    """Implements the ``proj.T`` functionality. - -    Do not use directly, since it can be accessed as member ``.T`` of -    an :class:`ASTRAProjector2D` object. - -    """ -    def __init__(self, parentProj): -        self.parentProj = parentProj - -    def __mul__(self, data): -        return self.parentProj.backProject(data) - - -class ASTRAProjector2D(object): -    """Helps with various common ASTRA Toolbox 2D operations. - -    This class can perform several often used toolbox operations, such as: - -    * Forward projecting -    * Back projecting -    * Reconstructing - -    Note that this class has a some computational overhead, because it -    copies a lot of data. If you use many repeated operations, directly -    using the PyAstraToolbox methods directly is faster. - -    You can use this class as an abstracted weight matrix :math:`W`: multiplying an instance -    ``proj`` of this class by an image results in a forward projection of the image, and multiplying -    ``proj.T`` by a sinogram results in a backprojection of the sinogram:: - -        proj = ASTRAProjector2D(...) -        fp = proj*image -        bp = proj.T*sinogram - -    :param proj_geom: The projection geometry. -    :type proj_geom: :class:`dict` -    :param vol_geom: The volume geometry. -    :type vol_geom: :class:`dict` -    :param proj_type: Projector type, such as ``'line'``, ``'linear'``, ... -    :type proj_type: :class:`string` -    :param useCUDA: If ``True``, use CUDA for calculations, when possible. -    :type useCUDA: :class:`bool` -    """ - -    def __init__(self, proj_geom, vol_geom, proj_type, useCUDA=False): -        self.vol_geom = vol_geom -        self.recSize = vol_geom['GridColCount'] -        self.angles = proj_geom['ProjectionAngles'] -        self.nDet = proj_geom['DetectorCount'] -        nexpow = int(pow(2, math.ceil(math.log(2 * self.nDet, 2)))) -        self.filterSize = nexpow / 2 + 1 -        self.nProj = self.angles.shape[0] -        self.proj_geom = proj_geom -        self.proj_id = ac.create_projector(proj_type, proj_geom, vol_geom) -        self.useCUDA = useCUDA -        self.T = ASTRAProjector2DTranspose(self) - -    def backProject(self, data): -        """Backproject a sinogram. - -        :param data: The sinogram data or ID. -        :type data: :class:`numpy.ndarray` or :class:`int` -        :returns: :class:`numpy.ndarray` -- The backprojection. - -        """ -        vol_id, vol = ac.create_backprojection( -            data, self.proj_id, useCUDA=self.useCUDA, returnData=True) -        data2d.delete(vol_id) -        return vol - -    def forwardProject(self, data): -        """Forward project an image. - -        :param data: The image data or ID. -        :type data: :class:`numpy.ndarray` or :class:`int` -        :returns: :class:`numpy.ndarray` -- The forward projection. - -        """ -        sin_id, sino = ac.create_sino(data, self.proj_id, useCUDA=self.useCUDA, returnData=True) -        data2d.delete(sin_id) -        return sino - -    def reconstruct(self, data, method, **kwargs): -        """Reconstruct an image from a sinogram. - -        :param data: The sinogram data or ID. -        :type data: :class:`numpy.ndarray` or :class:`int` -        :param method: Name of the reconstruction algorithm. -        :type method: :class:`string` -        :param kwargs: Additional named parameters to pass to :func:`astra.creators.create_reconstruction`. -        :returns: :class:`numpy.ndarray` -- The reconstruction. - -        Example of a SIRT reconstruction using CUDA:: - -            proj = ASTRAProjector2D(...) -            rec = proj.reconstruct(sinogram,'SIRT_CUDA',iterations=1000) - -        """ -        kwargs['returnData'] = True -        rec_id, rec = ac.create_reconstruction( -            method, self.proj_id, data, **kwargs) -        data2d.delete(rec_id) -        return rec - -    def __mul__(self, data): -        return self.forwardProject(data) diff --git a/python/astra/CFloat32CustomPython.h b/python/astra/CFloat32CustomPython.h new file mode 100644 index 0000000..d8593fc --- /dev/null +++ b/python/astra/CFloat32CustomPython.h @@ -0,0 +1,17 @@ +class CFloat32CustomPython : public astra::CFloat32CustomMemory { +public: +    CFloat32CustomPython(PyObject * arrIn) +    { +        arr = arrIn; +        // Set pointer to numpy data pointer +        m_fPtr = (float *)PyArray_DATA(arr); +        // Increase reference count since ASTRA has a reference +        Py_INCREF(arr); +    } +    virtual ~CFloat32CustomPython() { +        // Decrease reference count since ASTRA object is destroyed +        Py_DECREF(arr); +    } +private: +    PyObject* arr; +};
\ No newline at end of file diff --git a/python/astra/PyIncludes.pxd b/python/astra/PyIncludes.pxd index ea624fc..540aad4 100644 --- a/python/astra/PyIncludes.pxd +++ b/python/astra/PyIncludes.pxd @@ -27,6 +27,8 @@ from libcpp cimport bool  from libcpp.string cimport string  from .PyXMLDocument cimport XMLNode +include "config.pxi" +  cdef extern from "astra/Globals.h" namespace "astra":  	ctypedef float float32  	ctypedef double float64 @@ -41,7 +43,7 @@ cdef extern from "astra/Config.h" namespace "astra":  	cdef cppclass Config:  		Config()  		void initialize(string rootname) -		XMLNode *self +		XMLNode self  cdef extern from "astra/VolumeGeometry2D.h" namespace "astra":  	cdef cppclass CVolumeGeometry2D: @@ -61,10 +63,14 @@ cdef extern from "astra/VolumeGeometry2D.h" namespace "astra":  		float32 getWindowMaxY()  		Config* getConfiguration() +cdef extern from "astra/Float32Data2D.h" namespace "astra": +	cdef cppclass CFloat32CustomMemory: +		pass  cdef extern from "astra/Float32VolumeData2D.h" namespace "astra":  	cdef cppclass CFloat32VolumeData2D:  		CFloat32VolumeData2D(CVolumeGeometry2D*) +		CFloat32VolumeData2D(CVolumeGeometry2D*, CFloat32CustomMemory*)  		CVolumeGeometry2D * getGeometry()  		int getWidth()  		int getHeight() @@ -132,6 +138,7 @@ cdef extern from "astra/ParallelProjectionGeometry2D.h" namespace "astra":  cdef extern from "astra/Float32ProjectionData2D.h" namespace "astra":  	cdef cppclass CFloat32ProjectionData2D:  		CFloat32ProjectionData2D(CProjectionGeometry2D*) +		CFloat32ProjectionData2D(CProjectionGeometry2D*, CFloat32CustomMemory*)  		CProjectionGeometry2D * getGeometry()  		void changeGeometry(CProjectionGeometry2D*)  		int getDetectorCount() @@ -154,6 +161,20 @@ cdef extern from "astra/Projector2D.h" namespace "astra":  		CVolumeGeometry2D* getVolumeGeometry()  		CSparseMatrix* getMatrix() +cdef extern from "astra/Projector3D.h" namespace "astra": +	cdef cppclass CProjector3D: +		bool isInitialized() +		CProjectionGeometry3D* getProjectionGeometry() +		CVolumeGeometry3D* getVolumeGeometry() + +IF HAVE_CUDA==True: +	cdef extern from "astra/CudaProjector3D.h" namespace "astra": +		cdef cppclass CCudaProjector3D + +	cdef extern from "astra/CudaProjector2D.h" namespace "astra": +		cdef cppclass CCudaProjector2D + +  cdef extern from "astra/SparseMatrix.h" namespace "astra":  	cdef cppclass CSparseMatrix:  		CSparseMatrix(unsigned int,unsigned int,unsigned long) @@ -184,18 +205,30 @@ cdef extern from "astra/VolumeGeometry3D.h" namespace "astra":  		CVolumeGeometry3D()  		bool initialize(Config)  		Config * getConfiguration() +		int getGridColCount() +		int getGridRowCount() +		int getGridSliceCount()  cdef extern from "astra/ProjectionGeometry3D.h" namespace "astra":  	cdef cppclass CProjectionGeometry3D:  		CProjectionGeometry3D()  		bool initialize(Config)  		Config * getConfiguration() +		int getProjectionCount() +		int getDetectorColCount() +		int getDetectorRowCount()  cdef extern from "astra/Float32VolumeData3DMemory.h" namespace "astra":  	cdef cppclass CFloat32VolumeData3DMemory:  		CFloat32VolumeData3DMemory(CVolumeGeometry3D*) +		CFloat32VolumeData3DMemory(CVolumeGeometry3D*, CFloat32CustomMemory*)  		CVolumeGeometry3D* getGeometry() +		void changeGeometry(CVolumeGeometry3D*) +		int getRowCount() +		int getColCount() +		int getSliceCount() +  cdef extern from "astra/ParallelProjectionGeometry3D.h" namespace "astra": @@ -219,7 +252,13 @@ cdef extern from "astra/Float32ProjectionData3DMemory.h" namespace "astra":  	cdef cppclass CFloat32ProjectionData3DMemory:  		CFloat32ProjectionData3DMemory(CProjectionGeometry3D*)  		CFloat32ProjectionData3DMemory(CConeProjectionGeometry3D*) +		CFloat32ProjectionData3DMemory(CProjectionGeometry3D*, CFloat32CustomMemory*) +		CFloat32ProjectionData3DMemory(CConeProjectionGeometry3D*, CFloat32CustomMemory*)  		CProjectionGeometry3D* getGeometry() +		void changeGeometry(CProjectionGeometry3D*) +		int getDetectorColCount() +		int getDetectorRowCount() +		int getAngleCount()  cdef extern from "astra/Float32Data3D.h" namespace "astra":  	cdef cppclass CFloat32Data3D: diff --git a/python/astra/PyProjector3DFactory.pxd b/python/astra/PyProjector3DFactory.pxd new file mode 100644 index 0000000..bcbce94 --- /dev/null +++ b/python/astra/PyProjector3DFactory.pxd @@ -0,0 +1,35 @@ +#----------------------------------------------------------------------- +#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +#Author: Daniel M. Pelt +#Contact: D.M.Pelt@cwi.nl +#Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +#This file is part of the Python interface to the +#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- +from libcpp.string cimport string +from libcpp cimport bool +from .PyIncludes cimport * + +cdef extern from "astra/AstraObjectFactory.h" namespace "astra": +    cdef cppclass CProjector3DFactory: +        CProjector3D *create(Config) + +cdef extern from "astra/AstraObjectFactory.h" namespace "astra::CProjector3DFactory": +    cdef CProjector3DFactory* getSingletonPtr() diff --git a/python/astra/PyProjector3DManager.pxd b/python/astra/PyProjector3DManager.pxd new file mode 100644 index 0000000..b1eac6b --- /dev/null +++ b/python/astra/PyProjector3DManager.pxd @@ -0,0 +1,39 @@ +#----------------------------------------------------------------------- +#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +#Author: Daniel M. Pelt +#Contact: D.M.Pelt@cwi.nl +#Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +#This file is part of the Python interface to the +#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- +from libcpp.string cimport string + +from .PyIncludes cimport * + +cdef extern from "astra/AstraObjectManager.h" namespace "astra": +    cdef cppclass CProjector3DManager: +        string info() +        void clear() +        void remove(int i) +        int store(CProjector3D *) +        CProjector3D * get(int i) + +cdef extern from "astra/AstraObjectManager.h" namespace "astra::CProjector3DManager": +    cdef CProjector3DManager* getSingletonPtr() diff --git a/python/astra/PyXMLDocument.pxd b/python/astra/PyXMLDocument.pxd index 69781f1..033b8ef 100644 --- a/python/astra/PyXMLDocument.pxd +++ b/python/astra/PyXMLDocument.pxd @@ -44,22 +44,24 @@ cdef extern from "astra/Globals.h" namespace "astra":  cdef extern from "astra/XMLNode.h" namespace "astra":      cdef cppclass XMLNode:          string getName() -        XMLNode *addChildNode(string name) -        XMLNode *addChildNode(string, string) +        XMLNode addChildNode(string name) +        XMLNode addChildNode(string, string)          void addAttribute(string, string)          void addAttribute(string, float32)          void addOption(string, string)          bool hasOption(string)          string getAttribute(string) -        list[XMLNode *] getNodes() +        list[XMLNode] getNodes()          vector[float32] getContentNumericalArray() +        void setContent(double*, int, int, bool) +        void setContent(double*, int)          string getContent()          bool hasAttribute(string)  cdef extern from "astra/XMLDocument.h" namespace "astra":      cdef cppclass XMLDocument:          void saveToFile(string sFilename) -        XMLNode *getRootNode() +        XMLNode getRootNode()  cdef extern from "astra/XMLDocument.h" namespace "astra::XMLDocument":      cdef XMLDocument *createDocument(string rootname) diff --git a/python/astra/__init__.py b/python/astra/__init__.py index a61aafc..6c15d30 100644 --- a/python/astra/__init__.py +++ b/python/astra/__init__.py @@ -27,13 +27,15 @@ from . import matlab as m  from .creators import astra_dict,create_vol_geom, create_proj_geom, create_backprojection, create_sino, create_reconstruction, create_projector,create_sino3d_gpu, create_backprojection3d_gpu  from .functions import data_op, add_noise_to_sino, clear, move_vol_geom  from .extrautils import clipCircle -from .ASTRAProjector import ASTRAProjector2D  from . import data2d  from . import astra  from . import data3d  from . import algorithm  from . import projector +from . import projector3d  from . import matrix +from . import log +from .optomo import OpTomo  import os  try: diff --git a/python/astra/creators.py b/python/astra/creators.py index b5ecd5a..4cd7f2d 100644 --- a/python/astra/creators.py +++ b/python/astra/creators.py @@ -30,15 +30,16 @@ import math  from . import data2d  from . import data3d  from . import projector +from . import projector3d  from . import algorithm  def astra_dict(intype):      """Creates a dict to use with the ASTRA Toolbox. -     +      :param intype: Type of the ASTRA object.      :type intype: :class:`string`      :returns: :class:`dict` -- An ASTRA dict of type ``intype``. -     +      """      if intype == 'SIRT_CUDA2':          intype = 'SIRT_CUDA' @@ -268,25 +269,23 @@ This method can be called in a number of ways:              raise Exception('not enough variables: astra_create_proj_geom(parallel3d_vec, det_row_count, det_col_count, V)')          if not args[2].shape[1] == 12:              raise Exception('V should be a Nx12 matrix, with N the number of projections') -        return {'type': 'parallel3d_vec','DetectorRowCount':args[0],'DetectorColCount':args[1],'Vectors':args[2]}     +        return {'type': 'parallel3d_vec','DetectorRowCount':args[0],'DetectorColCount':args[1],'Vectors':args[2]}      elif intype == 'sparse_matrix':          if len(args) < 4:              raise Exception(                  'not enough variables: astra_create_proj_geom(sparse_matrix, det_width, det_count, angles, matrix_id)')          return {'type': 'sparse_matrix', 'DetectorWidth': args[0], 'DetectorCount': args[1], 'ProjectionAngles': args[2], 'MatrixID': args[3]}      else: -        raise Exception('Error: unknown type ' + intype)  +        raise Exception('Error: unknown type ' + intype) -def create_backprojection(data, proj_id, useCUDA=False, returnData=True): +def create_backprojection(data, proj_id, returnData=True):      """Create a backprojection of a sinogram (2D).  :param data: Sinogram data or ID.  :type data: :class:`numpy.ndarray` or :class:`int`  :param proj_id: ID of the projector to use.  :type proj_id: :class:`int` -:param useCUDA: If ``True``, use CUDA for the calculation. -:type useCUDA: :class:`bool`  :param returnData: If False, only return the ID of the backprojection.  :type returnData: :class:`bool`  :returns: :class:`int` or (:class:`int`, :class:`numpy.ndarray`) -- If ``returnData=False``, returns the ID of the backprojection. Otherwise, returns a tuple containing the ID of the backprojection and the backprojection itself, in that order. @@ -300,13 +299,13 @@ def create_backprojection(data, proj_id, useCUDA=False, returnData=True):          sino_id = data      vol_id = data2d.create('-vol', vol_geom, 0) -    algString = 'BP' -    if useCUDA: -        algString = algString + '_CUDA' +    if projector.is_cuda(proj_id): +        algString = 'BP_CUDA' +    else: +        algString = 'BP'      cfg = astra_dict(algString) -    if not useCUDA: -        cfg['ProjectorId'] = proj_id +    cfg['ProjectorId'] = proj_id      cfg['ProjectionDataId'] = sino_id      cfg['ReconstructionDataId'] = vol_id      alg_id = algorithm.create(cfg) @@ -358,20 +357,13 @@ def create_backprojection3d_gpu(data, proj_geom, vol_geom, returnData=True):          return vol_id -def create_sino(data, proj_id=None, proj_geom=None, vol_geom=None, -                useCUDA=False, returnData=True, gpuIndex=None): +def create_sino(data, proj_id, returnData=True, gpuIndex=None):      """Create a forward projection of an image (2D).      :param data: Image data or ID.      :type data: :class:`numpy.ndarray` or :class:`int`      :param proj_id: ID of the projector to use.      :type proj_id: :class:`int` -    :param proj_geom: Projection geometry. -    :type proj_geom: :class:`dict` -    :param vol_geom: Volume geometry. -    :type vol_geom: :class:`dict` -    :param useCUDA: If ``True``, use CUDA for the calculation. -    :type useCUDA: :class:`bool`      :param returnData: If False, only return the ID of the forward projection.      :type returnData: :class:`bool`      :param gpuIndex: Optional GPU index. @@ -382,36 +374,21 @@ def create_sino(data, proj_id=None, proj_geom=None, vol_geom=None,      projection. Otherwise, returns a tuple containing the ID of the      forward projection and the forward projection itself, in that      order. - -    The geometry of setup is defined by ``proj_id`` or with -    ``proj_geom`` and ``vol_geom``. If ``proj_id`` is given, then -    ``proj_geom`` and ``vol_geom`` must be None and vice versa.  """ -    if proj_id is not None: -        proj_geom = projector.projection_geometry(proj_id) -        vol_geom = projector.volume_geometry(proj_id) -    elif proj_geom is not None and vol_geom is not None: -        if not useCUDA: -            # We need more parameters to create projector. -            raise ValueError( -                """A ``proj_id`` is needed when CUDA is not used.""") -    else: -        raise Exception("""The geometry setup is not defined. -        The geometry of setup is defined by ``proj_id`` or with -        ``proj_geom`` and ``vol_geom``. If ``proj_id`` is given, then -        ``proj_geom`` and ``vol_geom`` must be None and vice versa.""") +    proj_geom = projector.projection_geometry(proj_id) +    vol_geom = projector.volume_geometry(proj_id)      if isinstance(data, np.ndarray):          volume_id = data2d.create('-vol', vol_geom, data)      else:          volume_id = data      sino_id = data2d.create('-sino', proj_geom, 0) -    algString = 'FP' -    if useCUDA: -        algString = algString + '_CUDA' +    if projector.is_cuda(proj_id): +        algString = 'FP_CUDA' +    else: +        algString = 'FP'      cfg = astra_dict(algString) -    if not useCUDA: -        cfg['ProjectorId'] = proj_id +    cfg['ProjectorId'] = proj_id      if gpuIndex is not None:          cfg['option'] = {'GPUindex': gpuIndex}      cfg['ProjectionDataId'] = sino_id @@ -509,8 +486,7 @@ def create_reconstruction(rec_type, proj_id, sinogram, iterations=1, use_mask='n      vol_geom = projector.volume_geometry(proj_id)      recon_id = data2d.create('-vol', vol_geom, 0)      cfg = astra_dict(rec_type) -    if not 'CUDA' in rec_type: -        cfg['ProjectorId'] = proj_id +    cfg['ProjectorId'] = proj_id      cfg['ProjectionDataId'] = sino_id      cfg['ReconstructionDataId'] = recon_id      cfg['options'] = {} @@ -573,4 +549,8 @@ def create_projector(proj_type, proj_geom, vol_geom):      cfg = astra_dict(proj_type)      cfg['ProjectionGeometry'] = proj_geom      cfg['VolumeGeometry'] = vol_geom -    return projector.create(cfg) +    types3d = ['linear3d', 'linearcone', 'cuda3d'] +    if proj_type in types3d: +        return projector3d.create(cfg) +    else: +        return projector.create(cfg) diff --git a/python/astra/data2d.py b/python/astra/data2d.py index 8c4be03..f119f05 100644 --- a/python/astra/data2d.py +++ b/python/astra/data2d.py @@ -24,6 +24,7 @@  #  #-----------------------------------------------------------------------  from . import data2d_c as d +import numpy as np  def clear():      """Clear all 2D data objects.""" @@ -52,6 +53,26 @@ def create(datatype, geometry, data=None):      """      return d.create(datatype,geometry,data) +def link(datatype, geometry, data): +    """Link a 2D numpy array with the toolbox. +         +    :param datatype: Data object type, '-vol' or '-sino'. +    :type datatype: :class:`string` +    :param geometry: Volume or projection geometry. +    :type geometry: :class:`dict` +    :param data: Numpy array to link +    :type data: :class:`numpy.ndarray` +    :returns: :class:`int` -- the ID of the constructed object. +     +    """ +    if not isinstance(data,np.ndarray): +        raise ValueError("Input should be a numpy array") +    if not data.dtype==np.float32: +        raise ValueError("Numpy array should be float32") +    if not (data.flags['C_CONTIGUOUS'] and data.flags['ALIGNED']): +        raise ValueError("Numpy array should be C_CONTIGUOUS and ALIGNED") +    return d.create(datatype,geometry,data,True) +  def store(i, data):      """Fill existing 2D object with data. diff --git a/python/astra/data2d_c.pyx b/python/astra/data2d_c.pyx index 882051c..42854b3 100644 --- a/python/astra/data2d_c.pyx +++ b/python/astra/data2d_c.pyx @@ -47,8 +47,18 @@ from .PyIncludes cimport *  cimport utils  from .utils import wrap_from_bytes +from .pythonutils import geom_size + +import operator + +from six.moves import reduce +  cdef CData2DManager * man2d = <CData2DManager * >PyData2DManager.getSingletonPtr() +cdef extern from "CFloat32CustomPython.h": +    cdef cppclass CFloat32CustomPython: +        CFloat32CustomPython(arrIn) +  def clear():      man2d.clear() @@ -61,11 +71,16 @@ def delete(ids):          man2d.remove(ids) -def create(datatype, geometry, data=None): +def create(datatype, geometry, data=None, link=False):      cdef Config *cfg      cdef CVolumeGeometry2D * pGeometry      cdef CProjectionGeometry2D * ppGeometry      cdef CFloat32Data2D * pDataObject2D +    cdef CFloat32CustomMemory * pCustom + +    if link and data.shape!=geom_size(geometry): +        raise Exception("The dimensions of the data do not match those specified in the geometry.") +      if datatype == '-vol':          cfg = utils.dictToConfig(six.b('VolumeGeometry'), geometry)          pGeometry = new CVolumeGeometry2D() @@ -73,7 +88,11 @@ def create(datatype, geometry, data=None):              del cfg              del pGeometry              raise Exception('Geometry class not initialized.') -        pDataObject2D = <CFloat32Data2D * > new CFloat32VolumeData2D(pGeometry) +        if link: +            pCustom = <CFloat32CustomMemory*> new CFloat32CustomPython(data) +            pDataObject2D = <CFloat32Data2D * > new CFloat32VolumeData2D(pGeometry, pCustom) +        else: +            pDataObject2D = <CFloat32Data2D * > new CFloat32VolumeData2D(pGeometry)          del cfg          del pGeometry      elif datatype == '-sino': @@ -93,7 +112,11 @@ def create(datatype, geometry, data=None):              del cfg              del ppGeometry              raise Exception('Geometry class not initialized.') -        pDataObject2D = <CFloat32Data2D * > new CFloat32ProjectionData2D(ppGeometry) +        if link: +            pCustom = <CFloat32CustomMemory*> new CFloat32CustomPython(data) +            pDataObject2D = <CFloat32Data2D * > new CFloat32ProjectionData2D(ppGeometry, pCustom) +        else: +            pDataObject2D = <CFloat32Data2D * > new CFloat32ProjectionData2D(ppGeometry)          del ppGeometry          del cfg      else: @@ -103,7 +126,7 @@ def create(datatype, geometry, data=None):          del pDataObject2D          raise Exception("Couldn't initialize data object.") -    fillDataObject(pDataObject2D, data) +    if not link: fillDataObject(pDataObject2D, data)      return man2d.store(pDataObject2D) diff --git a/python/astra/data3d.py b/python/astra/data3d.py index a2e9201..e5ef6b0 100644 --- a/python/astra/data3d.py +++ b/python/astra/data3d.py @@ -24,6 +24,7 @@  #  #-----------------------------------------------------------------------  from . import data3d_c as d +import numpy as np  def create(datatype,geometry,data=None):      """Create a 3D object. @@ -39,6 +40,27 @@ def create(datatype,geometry,data=None):      """      return d.create(datatype,geometry,data) +def link(datatype, geometry, data): +    """Link a 3D numpy array with the toolbox. +         +    :param datatype: Data object type, '-vol' or '-sino'. +    :type datatype: :class:`string` +    :param geometry: Volume or projection geometry. +    :type geometry: :class:`dict` +    :param data: Numpy array to link +    :type data: :class:`numpy.ndarray` +    :returns: :class:`int` -- the ID of the constructed object. +     +    """ +    if not isinstance(data,np.ndarray): +        raise ValueError("Input should be a numpy array") +    if not data.dtype==np.float32: +        raise ValueError("Numpy array should be float32") +    if not (data.flags['C_CONTIGUOUS'] and data.flags['ALIGNED']): +        raise ValueError("Numpy array should be C_CONTIGUOUS and ALIGNED") +    return d.create(datatype,geometry,data,True) + +  def get(i):      """Get a 3D object. @@ -90,6 +112,17 @@ def get_geometry(i):      """      return d.get_geometry(i) +def change_geometry(i, geometry): +    """Change the geometry of a 3D object. + +    :param i: ID of object. +    :type i: :class:`int` +    :param geometry: Volume or projection geometry. +    :type geometry: :class:`dict` + +    """ +    return d.change_geometry(i, geometry) +  def dimensions(i):      """Get dimensions of a 3D object. diff --git a/python/astra/data3d_c.pyx b/python/astra/data3d_c.pyx index 4b069f7..3b27ab7 100644 --- a/python/astra/data3d_c.pyx +++ b/python/astra/data3d_c.pyx @@ -45,17 +45,33 @@ from .PyXMLDocument cimport XMLDocument  cimport utils  from .utils import wrap_from_bytes +from .pythonutils import geom_size + +import operator + +from six.moves import reduce + +  cdef CData3DManager * man3d = <CData3DManager * >PyData3DManager.getSingletonPtr()  cdef extern from *:      CFloat32Data3DMemory * dynamic_cast_mem "dynamic_cast<astra::CFloat32Data3DMemory*>" (CFloat32Data3D * ) except NULL -def create(datatype,geometry,data=None): +cdef extern from "CFloat32CustomPython.h": +    cdef cppclass CFloat32CustomPython: +        CFloat32CustomPython(arrIn) + +def create(datatype,geometry,data=None, link=False):      cdef Config *cfg      cdef CVolumeGeometry3D * pGeometry      cdef CProjectionGeometry3D * ppGeometry      cdef CFloat32Data3DMemory * pDataObject3D      cdef CConeProjectionGeometry3D* pppGeometry +    cdef CFloat32CustomMemory * pCustom + +    if link and data.shape!=geom_size(geometry): +        raise Exception("The dimensions of the data do not match those specified in the geometry.") +      if datatype == '-vol':          cfg = utils.dictToConfig(six.b('VolumeGeometry'), geometry)          pGeometry = new CVolumeGeometry3D() @@ -63,7 +79,11 @@ def create(datatype,geometry,data=None):              del cfg              del pGeometry              raise Exception('Geometry class not initialized.') -        pDataObject3D = <CFloat32Data3DMemory * > new CFloat32VolumeData3DMemory(pGeometry) +        if link: +            pCustom = <CFloat32CustomMemory*> new CFloat32CustomPython(data) +            pDataObject3D = <CFloat32Data3DMemory * > new CFloat32VolumeData3DMemory(pGeometry, pCustom) +        else: +            pDataObject3D = <CFloat32Data3DMemory * > new CFloat32VolumeData3DMemory(pGeometry)          del cfg          del pGeometry      elif datatype == '-sino' or datatype == '-proj3d': @@ -84,7 +104,11 @@ def create(datatype,geometry,data=None):              del cfg              del ppGeometry              raise Exception('Geometry class not initialized.') -        pDataObject3D = <CFloat32Data3DMemory * > new CFloat32ProjectionData3DMemory(ppGeometry) +        if link: +            pCustom = <CFloat32CustomMemory*> new CFloat32CustomPython(data) +            pDataObject3D = <CFloat32Data3DMemory * > new CFloat32ProjectionData3DMemory(ppGeometry, pCustom) +        else: +            pDataObject3D = <CFloat32Data3DMemory * > new CFloat32ProjectionData3DMemory(ppGeometry)          del ppGeometry          del cfg      elif datatype == "-sinocone": @@ -94,7 +118,11 @@ def create(datatype,geometry,data=None):              del cfg              del pppGeometry              raise Exception('Geometry class not initialized.') -        pDataObject3D = <CFloat32Data3DMemory * > new CFloat32ProjectionData3DMemory(pppGeometry) +        if link: +            pCustom = <CFloat32CustomMemory*> new CFloat32CustomPython(data) +            pDataObject3D = <CFloat32Data3DMemory * > new CFloat32ProjectionData3DMemory(pppGeometry, pCustom) +        else: +            pDataObject3D = <CFloat32Data3DMemory * > new CFloat32ProjectionData3DMemory(pppGeometry)      else:          raise Exception("Invalid datatype.  Please specify '-vol' or '-proj3d'.") @@ -102,7 +130,7 @@ def create(datatype,geometry,data=None):          del pDataObject3D          raise Exception("Couldn't initialize data object.") -    fillDataObject(pDataObject3D, data) +    if not link: fillDataObject(pDataObject3D, data)      pDataObject3D.updateStatistics() @@ -122,6 +150,61 @@ def get_geometry(i):          raise Exception("Not a known data object")      return geom +def change_geometry(i, geom): +    cdef CFloat32Data3DMemory * pDataObject = dynamic_cast_mem(getObject(i)) +    cdef CFloat32ProjectionData3DMemory * pDataObject2 +    cdef CFloat32VolumeData3DMemory * pDataObject3 +    if pDataObject.getType() == THREEPROJECTION: +        pDataObject2 = <CFloat32ProjectionData3DMemory * >pDataObject +        # TODO: Reduce code duplication here +        cfg = utils.dictToConfig(six.b('ProjectionGeometry'), geom) +        tpe = wrap_from_bytes(cfg.self.getAttribute(six.b('type'))) +        if (tpe == "parallel3d"): +            ppGeometry = <CProjectionGeometry3D*> new CParallelProjectionGeometry3D(); +        elif (tpe == "parallel3d_vec"): +            ppGeometry = <CProjectionGeometry3D*> new CParallelVecProjectionGeometry3D(); +        elif (tpe == "cone"): +            ppGeometry = <CProjectionGeometry3D*> new CConeProjectionGeometry3D(); +        elif (tpe == "cone_vec"): +            ppGeometry = <CProjectionGeometry3D*> new CConeVecProjectionGeometry3D(); +        else: +            raise Exception("Invalid geometry type.") +        if not ppGeometry.initialize(cfg[0]): +            del cfg +            del ppGeometry +            raise Exception('Geometry class not initialized.') +        del cfg +        if (ppGeometry.getDetectorColCount() != pDataObject2.getDetectorColCount() or \ +            ppGeometry.getProjectionCount() != pDataObject2.getAngleCount() or \ +            ppGeometry.getDetectorRowCount() != pDataObject2.getDetectorRowCount()): +            del ppGeometry +            raise Exception( +                "The dimensions of the data do not match those specified in the geometry.") +        pDataObject2.changeGeometry(ppGeometry) +        del ppGeometry + +    elif pDataObject.getType() == THREEVOLUME: +        pDataObject3 = <CFloat32VolumeData3DMemory * >pDataObject +        cfg = utils.dictToConfig(six.b('VolumeGeometry'), geom) +        pGeometry = new CVolumeGeometry3D() +        if not pGeometry.initialize(cfg[0]): +            del cfg +            del pGeometry +            raise Exception('Geometry class not initialized.') +        del cfg +        if (pGeometry.getGridColCount() != pDataObject3.getColCount() or \ +            pGeometry.getGridRowCount() != pDataObject3.getRowCount() or \ +            pGeometry.getGridSliceCount() != pDataObject3.getSliceCount()): +            del pGeometry +            raise Exception( +                "The dimensions of the data do not match those specified in the geometry.") +        pDataObject3.changeGeometry(pGeometry) +        del pGeometry + +    else: +        raise Exception("Not a known data object") + +  cdef fillDataObject(CFloat32Data3DMemory * obj, data):      if data is None:          fillDataObjectScalar(obj, 0) diff --git a/python/astra/functions.py b/python/astra/functions.py index bbbb355..13ca911 100644 --- a/python/astra/functions.py +++ b/python/astra/functions.py @@ -32,12 +32,17 @@  from . import creators as ac  import numpy as np -from six.moves import range +try: +    from six.moves import range +except ImportError: +    # six 1.3.0 +    from six.moves import xrange as range  from . import data2d  from . import data3d  from . import projector  from . import algorithm +from . import pythonutils @@ -158,29 +163,7 @@ def geom_size(geom, dim=None):      :param dim: Optional axis index to return      :type dim: :class:`int`      """ - -    if 'GridSliceCount' in geom: -        # 3D Volume geometry? -        s = (geom['GridSliceCount'], geom[ -             'GridRowCount'], geom['GridColCount']) -    elif 'GridColCount' in geom: -        # 2D Volume geometry? -        s = (geom['GridRowCount'], geom['GridColCount']) -    elif geom['type'] == 'parallel' or geom['type'] == 'fanflat': -        s = (len(geom['ProjectionAngles']), geom['DetectorCount']) -    elif geom['type'] == 'parallel3d' or geom['type'] == 'cone': -        s = (geom['DetectorRowCount'], len( -            geom['ProjectionAngles']), geom['DetectorColCount']) -    elif geom['type'] == 'parallel_vec' or geom['type'] == 'fanflat_vec': -        s = (geom['Vectors'].shape[0], geom['DetectorCount']) -    elif geom['type'] == 'parallel3d_vec' or geom['type'] == 'cone_vec': -        s = (geom['DetectorRowCount'], geom[ -             'Vectors'].shape[0], geom['DetectorColCount']) - -    if dim != None: -        s = s[dim] - -    return s +    return pythonutils.geom_size(geom,dim)  def geom_2vec(proj_geom): diff --git a/python/astra/log.py b/python/astra/log.py new file mode 100644 index 0000000..3ec0df5 --- /dev/null +++ b/python/astra/log.py @@ -0,0 +1,153 @@ +#----------------------------------------------------------------------- +#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +#Author: Daniel M. Pelt +#Contact: D.M.Pelt@cwi.nl +#Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +#This file is part of the Python interface to the +#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- + +from . import log_c as l + +import inspect + +def debug(message): +    """Log a debug message. +     +    :param message: Message to log. +    :type message: :class:`string` +    """ +    prev_f = inspect.getframeinfo(inspect.currentframe().f_back) +    l.log_debug(prev_f.filename,prev_f.lineno,message) + +def info(message): +    """Log an info message. +     +    :param message: Message to log. +    :type message: :class:`string` +    """ +    prev_f = inspect.getframeinfo(inspect.currentframe().f_back) +    l.log_info(prev_f.filename,prev_f.lineno,message) + +def warn(message): +    """Log a warning message. +     +    :param message: Message to log. +    :type message: :class:`string` +    """ +    prev_f = inspect.getframeinfo(inspect.currentframe().f_back) +    l.log_warn(prev_f.filename,prev_f.lineno,message) + +def error(message): +    """Log an error message. +     +    :param message: Message to log. +    :type message: :class:`string` +    """ +    prev_f = inspect.getframeinfo(inspect.currentframe().f_back) +    l.log_error(prev_f.filename,prev_f.lineno,message) + +def enable(): +    """Enable logging to screen and file.""" +    l.log_enable() + +def enableScreen(): +    """Enable logging to screen.""" +    l.log_enableScreen() + +def enableFile(): +    """Enable logging to file (note that a file has to be set).""" +    l.log_enableFile() + +def disable(): +    """Disable all logging.""" +    l.log_disable() + +def disableScreen(): +    """Disable logging to screen.""" +    l.log_disableScreen() + +def disableFile(): +    """Disable logging to file.""" +    l.log_disableFile() + +def setFormatFile(fmt): +    """Set the format string for log messages.  Here are the substitutions you may use: +     +    %f: Source file name generating the log call. +    %n: Source line number where the log call was made. +    %m: The message text sent to the logger (after printf formatting). +    %d: The current date, formatted using the logger's date format. +    %t: The current time, formatted using the logger's time format. +    %l: The log level (one of "DEBUG", "INFO", "WARN", or "ERROR"). +    %%: A literal percent sign. +     +    The default format string is "%d %t %f(%n): %l: %m\n". +     +    :param fmt: Format to use, end with "\n". +    :type fmt: :class:`string` +    """ +    l.log_setFormatFile(fmt) + +def setFormatScreen(fmt): +    """Set the format string for log messages.  Here are the substitutions you may use: +     +    %f: Source file name generating the log call. +    %n: Source line number where the log call was made. +    %m: The message text sent to the logger (after printf formatting). +    %d: The current date, formatted using the logger's date format. +    %t: The current time, formatted using the logger's time format. +    %l: The log level (one of "DEBUG", "INFO", "WARN", or "ERROR"). +    %%: A literal percent sign. +     +    The default format string is "%d %t %f(%n): %l: %m\n". +     +    :param fmt: Format to use, end with "\n". +    :type fmt: :class:`string` +    """ +    l.log_setFormatScreen(fmt) + +STDOUT=1 +STDERR=2 + +DEBUG=0 +INFO=1 +WARN=2 +ERROR=3 + +def setOutputScreen(fd, level): +    """Set which screen to output to, and which level to use. +     +    :param fd: File descriptor of output screen (STDOUT or STDERR). +    :type fd: :class:`int` +    :param level: Logging level to use (DEBUG, INFO, WARN, or ERROR). +    :type level: :class:`int` +    """ +    l.log_setOutputScreen(fd, level) + +def setOutputFile(filename, level): +    """Set which file to output to, and which level to use. +     +    :param filename: File name of output file. +    :type filename: :class:`string` +    :param level: Logging level to use (DEBUG, INFO, WARN, or ERROR). +    :type level: :class:`int` +    """ +    l.log_setOutputFile(filename, level)
\ No newline at end of file diff --git a/python/astra/log_c.pyx b/python/astra/log_c.pyx new file mode 100644 index 0000000..f16329f --- /dev/null +++ b/python/astra/log_c.pyx @@ -0,0 +1,103 @@ +#----------------------------------------------------------------------- +#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +#Author: Daniel M. Pelt +#Contact: D.M.Pelt@cwi.nl +#Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +#This file is part of the Python interface to the +#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- +# distutils: language = c++ +# distutils: libraries = astra + +import six + +cdef extern from "astra/Logging.h" namespace "astra": +    cdef enum log_level: +        LOG_DEBUG +        LOG_INFO +        LOG_WARN +        LOG_ERROR + +cdef extern from "astra/Logging.h" namespace "astra::CLogger": +    void debug(const char *sfile, int sline, const char *fmt, ...) +    void info(const char *sfile, int sline, const char *fmt, ...) +    void warn(const char *sfile, int sline, const char *fmt, ...) +    void error(const char *sfile, int sline, const char *fmt, ...) +    void setOutputScreen(int fd, log_level m_eLevel) +    void setOutputFile(const char *filename, log_level m_eLevel) +    void enable() +    void enableScreen() +    void enableFile() +    void disable() +    void disableScreen() +    void disableFile() +    void setFormatFile(const char *fmt) +    void setFormatScreen(const char *fmt) + +def log_debug(sfile, sline, message): +    cstr = list(map(six.b,(sfile,message))) +    debug(cstr[0],sline,cstr[1]) + +def log_info(sfile, sline, message): +    cstr = list(map(six.b,(sfile,message))) +    info(cstr[0],sline,cstr[1]) + +def log_warn(sfile, sline, message): +    cstr = list(map(six.b,(sfile,message))) +    warn(cstr[0],sline,cstr[1]) + +def log_error(sfile, sline, message): +    cstr = list(map(six.b,(sfile,message))) +    error(cstr[0],sline,cstr[1]) + +def log_enable(): +    enable() + +def log_enableScreen(): +    enableScreen() + +def log_enableFile(): +    enableFile() + +def log_disable(): +    disable() + +def log_disableScreen(): +    disableScreen() + +def log_disableFile(): +    disableFile() + +def log_setFormatFile(fmt): +    cstr = six.b(fmt) +    setFormatFile(cstr) + +def log_setFormatScreen(fmt): +    cstr = six.b(fmt) +    setFormatScreen(cstr) + +enumList = [LOG_DEBUG,LOG_INFO,LOG_WARN,LOG_ERROR] + +def log_setOutputScreen(fd, level): +    setOutputScreen(fd, enumList[level]) + +def log_setOutputFile(filename, level): +    cstr = six.b(filename) +    setOutputFile(cstr, enumList[level]) diff --git a/python/astra/matrix_c.pyx b/python/astra/matrix_c.pyx index b0d8bc4..d099a75 100644 --- a/python/astra/matrix_c.pyx +++ b/python/astra/matrix_c.pyx @@ -27,7 +27,12 @@  # distutils: libraries = astra  import six -from six.moves import range +try: +    from six.moves import range +except ImportError: +    # six 1.3.0 +    from six.moves import xrange as range +  import numpy as np  import scipy.sparse as ss diff --git a/python/astra/optomo.py b/python/astra/optomo.py new file mode 100644 index 0000000..2937d9c --- /dev/null +++ b/python/astra/optomo.py @@ -0,0 +1,203 @@ +#----------------------------------------------------------------------- +#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +#Author: Daniel M. Pelt +#Contact: D.M.Pelt@cwi.nl +#Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +#This file is part of the Python interface to the +#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- + +from . import data2d +from . import data3d +from . import projector +from . import projector3d +from . import creators +from . import algorithm +from . import functions +import numpy as np +from six.moves import reduce +try: +    from six.moves import range +except ImportError: +    # six 1.3.0 +    from six.moves import xrange as range + +import operator +import scipy.sparse.linalg + +class OpTomo(scipy.sparse.linalg.LinearOperator): +    """Object that imitates a projection matrix with a given projector. + +    This object can do forward projection by using the ``*`` operator:: + +        W = astra.OpTomo(proj_id) +        fp = W*image +        bp = W.T*sinogram + +    It can also be used in minimization methods of the :mod:`scipy.sparse.linalg` module:: + +        W = astra.OpTomo(proj_id) +        output = scipy.sparse.linalg.lsqr(W,sinogram) + +    :param proj_id: ID to a projector. +    :type proj_id: :class:`int` +    """ + +    def __init__(self,proj_id): +        self.dtype = np.float32 +        try: +            self.vg = projector.volume_geometry(proj_id) +            self.pg = projector.projection_geometry(proj_id) +            self.data_mod = data2d +            self.appendString = "" +            if projector.is_cuda(proj_id): +                self.appendString += "_CUDA" +        except Exception: +            self.vg = projector3d.volume_geometry(proj_id) +            self.pg = projector3d.projection_geometry(proj_id) +            self.data_mod = data3d +            self.appendString = "3D" +            if projector3d.is_cuda(proj_id): +                self.appendString += "_CUDA" + +        self.vshape = functions.geom_size(self.vg) +        self.vsize = reduce(operator.mul,self.vshape) +        self.sshape = functions.geom_size(self.pg) +        self.ssize = reduce(operator.mul,self.sshape) + +        self.shape = (self.ssize, self.vsize) + +        self.proj_id = proj_id + +        self.T = OpTomoTranspose(self) + +    def __checkArray(self, arr, shp): +        if len(arr.shape)==1: +            arr = arr.reshape(shp) +        if arr.dtype != np.float32: +            arr = arr.astype(np.float32) +        if arr.flags['C_CONTIGUOUS']==False: +            arr = np.ascontiguousarray(arr) +        return arr + +    def _matvec(self,v): +        """Implements the forward operator. + +        :param v: Volume to forward project. +        :type v: :class:`numpy.ndarray` +        """ +        v = self.__checkArray(v, self.vshape) +        vid = self.data_mod.link('-vol',self.vg,v) +        s = np.zeros(self.sshape,dtype=np.float32) +        sid = self.data_mod.link('-sino',self.pg,s) + +        cfg = creators.astra_dict('FP'+self.appendString) +        cfg['ProjectionDataId'] = sid +        cfg['VolumeDataId'] = vid +        cfg['ProjectorId'] = self.proj_id +        fp_id = algorithm.create(cfg) +        algorithm.run(fp_id) + +        algorithm.delete(fp_id) +        self.data_mod.delete([vid,sid]) +        return s.flatten() + +    def rmatvec(self,s): +        """Implements the transpose operator. + +        :param s: The projection data. +        :type s: :class:`numpy.ndarray` +        """ +        s = self.__checkArray(s, self.sshape) +        sid = self.data_mod.link('-sino',self.pg,s) +        v = np.zeros(self.vshape,dtype=np.float32) +        vid = self.data_mod.link('-vol',self.vg,v) + +        cfg = creators.astra_dict('BP'+self.appendString) +        cfg['ProjectionDataId'] = sid +        cfg['ReconstructionDataId'] = vid +        cfg['ProjectorId'] = self.proj_id +        bp_id = algorithm.create(cfg) +        algorithm.run(bp_id) + +        algorithm.delete(bp_id) +        self.data_mod.delete([vid,sid]) +        return v.flatten() + +    def __mul__(self,v): +        """Provides easy forward operator by *. + +        :param v: Volume to forward project. +        :type v: :class:`numpy.ndarray` +        """ +        # Catch the case of a forward projection of a 2D/3D image +        if isinstance(v, np.ndarray) and v.shape==self.vshape: +            return self._matvec(v) +        return scipy.sparse.linalg.LinearOperator.__mul__(self, v) + +    def reconstruct(self, method, s, iterations=1, extraOptions = {}): +        """Reconstruct an object. + +        :param method: Method to use for reconstruction. +        :type method: :class:`string` +        :param s: The projection data. +        :type s: :class:`numpy.ndarray` +        :param iterations: Number of iterations to use. +        :type iterations: :class:`int` +        :param extraOptions: Extra options to use during reconstruction (i.e. for cfg['option']). +        :type extraOptions: :class:`dict` +        """ +        self.__checkArray(s, self.sshape) +        sid = self.data_mod.link('-sino',self.pg,s) +        v = np.zeros(self.vshape,dtype=np.float32) +        vid = self.data_mod.link('-vol',self.vg,v) +        cfg = creators.astra_dict(method) +        cfg['ProjectionDataId'] = sid +        cfg['ReconstructionDataId'] = vid +        cfg['ProjectorId'] = self.proj_id +        cfg['option'] = extraOptions +        alg_id = algorithm.create(cfg) +        algorithm.run(alg_id,iterations) +        algorithm.delete(alg_id) +        self.data_mod.delete([vid,sid]) +        return v + +class OpTomoTranspose(scipy.sparse.linalg.LinearOperator): +    """This object provides the transpose operation (``.T``) of the OpTomo object. + +    Do not use directly, since it can be accessed as member ``.T`` of +    an :class:`OpTomo` object. +    """ +    def __init__(self,parent): +        self.parent = parent +        self.dtype = np.float32 +        self.shape = (parent.shape[1], parent.shape[0]) + +    def _matvec(self, s): +        return self.parent.rmatvec(s) + +    def rmatvec(self, v): +        return self.parent.matvec(v) + +    def __mul__(self,s): +        # Catch the case of a backprojection of 2D/3D data +        if isinstance(s, np.ndarray) and s.shape==self.parent.sshape: +            return self._matvec(s) +        return scipy.sparse.linalg.LinearOperator.__mul__(self, s) diff --git a/python/astra/projector.py b/python/astra/projector.py index c916c52..e370e5a 100644 --- a/python/astra/projector.py +++ b/python/astra/projector.py @@ -27,21 +27,21 @@ from . import projector_c as p  def create(config):      """Create projector object. -     +      :param config: Projector options.      :type config: :class:`dict`      :returns: :class:`int` -- the ID of the constructed object. -     +      """      return p.create(config)  def delete(ids):      """Delete a projector object. -     +      :param ids: ID or list of ID's to delete.      :type ids: :class:`int` or :class:`list` -     +      """      return p.delete(ids) @@ -57,22 +57,22 @@ def info():  def projection_geometry(i):      """Get projection geometry of a projector. -     +      :param i: ID of projector.      :type i: :class:`int`      :returns: :class:`dict` -- projection geometry -     +      """      return p.projection_geometry(i)  def volume_geometry(i):      """Get volume geometry of a projector. -     +      :param i: ID of projector.      :type i: :class:`int`      :returns: :class:`dict` -- volume geometry -     +      """      return p.volume_geometry(i) @@ -88,13 +88,23 @@ def weights_projection(i, projection_index):  def splat(i, row, col):      return p.splat(i, row, col) +def is_cuda(i): +    """Check whether a projector is a CUDA projector. + +    :param i: ID of projector. +    :type i: :class:`int` +    :returns: :class:`bool` -- True if the projector is a CUDA projector. + +    """ +    return p.is_cuda(i) +  def matrix(i):      """Get sparse matrix of a projector. -     +      :param i: ID of projector.      :type i: :class:`int`      :returns: :class:`int` -- ID of sparse matrix. -     +      """      return p.matrix(i) diff --git a/python/astra/projector3d.py b/python/astra/projector3d.py new file mode 100644 index 0000000..d1086b9 --- /dev/null +++ b/python/astra/projector3d.py @@ -0,0 +1,100 @@ +#----------------------------------------------------------------------- +#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +#Author: Daniel M. Pelt +#Contact: D.M.Pelt@cwi.nl +#Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +#This file is part of the Python interface to the +#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- +from . import projector3d_c as p + +def create(config): +    """Create projector object. + +    :param config: Projector options. +    :type config: :class:`dict` +    :returns: :class:`int` -- the ID of the constructed object. + +    """ +    return p.create(config) + + +def delete(ids): +    """Delete a projector object. + +    :param ids: ID or list of ID's to delete. +    :type ids: :class:`int` or :class:`list` + +    """ +    return p.delete(ids) + + +def clear(): +    """Clear all projector objects.""" +    return p.clear() + + +def info(): +    """Print info on projector objects in memory.""" +    return p.info() + +def projection_geometry(i): +    """Get projection geometry of a projector. + +    :param i: ID of projector. +    :type i: :class:`int` +    :returns: :class:`dict` -- projection geometry + +    """ +    return p.projection_geometry(i) + + +def volume_geometry(i): +    """Get volume geometry of a projector. + +    :param i: ID of projector. +    :type i: :class:`int` +    :returns: :class:`dict` -- volume geometry + +    """ +    return p.volume_geometry(i) + + +def weights_single_ray(i, projection_index, detector_index): +    return p.weights_single_ray(i, projection_index, detector_index) + + +def weights_projection(i, projection_index): +    return p.weights_projection(i, projection_index) + + +def splat(i, row, col): +    return p.splat(i, row, col) + + +def is_cuda(i): +    """Check whether a projector is a CUDA projector. + +    :param i: ID of projector. +    :type i: :class:`int` +    :returns: :class:`bool` -- True if the projector is a CUDA projector. + +    """ +    return p.is_cuda(i) diff --git a/python/astra/projector3d_c.pyx b/python/astra/projector3d_c.pyx new file mode 100644 index 0000000..8b978d7 --- /dev/null +++ b/python/astra/projector3d_c.pyx @@ -0,0 +1,119 @@ +#----------------------------------------------------------------------- +#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +#Author: Daniel M. Pelt +#Contact: D.M.Pelt@cwi.nl +#Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +#This file is part of the Python interface to the +#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- +# distutils: language = c++ +# distutils: libraries = astra + +import six +from .PyIncludes cimport * + +cimport utils +from .utils import wrap_from_bytes + +cimport PyProjector3DFactory +from .PyProjector3DFactory cimport CProjector3DFactory + +cimport PyProjector3DManager +from .PyProjector3DManager cimport CProjector3DManager + +cimport PyXMLDocument +from .PyXMLDocument cimport XMLDocument + +cdef CProjector3DManager * manProj = <CProjector3DManager * >PyProjector3DManager.getSingletonPtr() + +include "config.pxi" + +IF HAVE_CUDA: +  cdef extern from *: +      CCudaProjector3D* dynamic_cast_cuda_projector "dynamic_cast<astra::CCudaProjector3D*>" (CProjector3D*) + + +def create(config): +    cdef Config * cfg = utils.dictToConfig(six.b('Projector3D'), config) +    cdef CProjector3D * proj +    proj = PyProjector3DFactory.getSingletonPtr().create(cfg[0]) +    if proj == NULL: +        del cfg +        raise Exception("Error creating Projector3D.") +    del cfg +    return manProj.store(proj) + + +def delete(ids): +    try: +        for i in ids: +            manProj.remove(i) +    except TypeError: +        manProj.remove(ids) + + +def clear(): +    manProj.clear() + + +def info(): +    six.print_(wrap_from_bytes(manProj.info())) + +cdef CProjector3D * getObject(i) except NULL: +    cdef CProjector3D * proj = manProj.get(i) +    if proj == NULL: +        raise Exception("Projector not initialized.") +    if not proj.isInitialized(): +        raise Exception("Projector not initialized.") +    return proj + + +def projection_geometry(i): +    cdef CProjector3D * proj = getObject(i) +    return utils.configToDict(proj.getProjectionGeometry().getConfiguration()) + + +def volume_geometry(i): +    cdef CProjector3D * proj = getObject(i) +    return utils.configToDict(proj.getVolumeGeometry().getConfiguration()) + + +def weights_single_ray(i, projection_index, detector_index): +    raise Exception("Not yet implemented") + + +def weights_projection(i, projection_index): +    raise Exception("Not yet implemented") + + +def splat(i, row, col): +    raise Exception("Not yet implemented") + +def is_cuda(i): +    cdef CProjector3D * proj = getObject(i) +    IF HAVE_CUDA==True: +      cdef CCudaProjector3D * cudaproj = NULL +      cudaproj = dynamic_cast_cuda_projector(proj) +      if cudaproj==NULL: +          return False +      else: +          return True +    ELSE: +        return False diff --git a/python/astra/projector_c.pyx b/python/astra/projector_c.pyx index f91a8dd..9aa868e 100644 --- a/python/astra/projector_c.pyx +++ b/python/astra/projector_c.pyx @@ -47,6 +47,12 @@ from .PyMatrixManager cimport CMatrixManager  cdef CProjector2DManager * manProj = <CProjector2DManager * >PyProjector2DManager.getSingletonPtr()  cdef CMatrixManager * manM = <CMatrixManager * >PyMatrixManager.getSingletonPtr() +include "config.pxi" + +IF HAVE_CUDA: +  cdef extern from *: +      CCudaProjector2D* dynamic_cast_cuda_projector "dynamic_cast<astra::CCudaProjector2D*>" (CProjector2D*) +  def create(config):      cdef Config * cfg = utils.dictToConfig(six.b('Projector2D'), config) @@ -104,6 +110,17 @@ def weights_projection(i, projection_index):  def splat(i, row, col):      raise Exception("Not yet implemented") +def is_cuda(i): +    cdef CProjector2D * proj = getObject(i) +    IF HAVE_CUDA==True: +      cdef CCudaProjector2D * cudaproj = NULL +      cudaproj = dynamic_cast_cuda_projector(proj) +      if cudaproj==NULL: +          return False +      else: +          return True +    ELSE: +        return False  def matrix(i):      cdef CProjector2D * proj = getObject(i) diff --git a/python/astra/pythonutils.py b/python/astra/pythonutils.py new file mode 100644 index 0000000..8ea4af5 --- /dev/null +++ b/python/astra/pythonutils.py @@ -0,0 +1,63 @@ +#----------------------------------------------------------------------- +# Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +# Author: Daniel M. Pelt +# Contact: D.M.Pelt@cwi.nl +# Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +# This file is part of the Python interface to the +# All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +# The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- +"""Additional purely Python functions for PyAstraToolbox. + +.. moduleauthor:: Daniel M. Pelt <D.M.Pelt@cwi.nl> + + +""" + +def geom_size(geom, dim=None): +    """Returns the size of a volume or sinogram, based on the projection or volume geometry. + +    :param geom: Geometry to calculate size from +    :type geometry: :class:`dict` +    :param dim: Optional axis index to return +    :type dim: :class:`int` +    """ + +    if 'GridSliceCount' in geom: +        # 3D Volume geometry? +        s = (geom['GridSliceCount'], geom[ +             'GridRowCount'], geom['GridColCount']) +    elif 'GridColCount' in geom: +        # 2D Volume geometry? +        s = (geom['GridRowCount'], geom['GridColCount']) +    elif geom['type'] == 'parallel' or geom['type'] == 'fanflat': +        s = (len(geom['ProjectionAngles']), geom['DetectorCount']) +    elif geom['type'] == 'parallel3d' or geom['type'] == 'cone': +        s = (geom['DetectorRowCount'], len( +            geom['ProjectionAngles']), geom['DetectorColCount']) +    elif geom['type'] == 'fanflat_vec': +        s = (geom['Vectors'].shape[0], geom['DetectorCount']) +    elif geom['type'] == 'parallel3d_vec' or geom['type'] == 'cone_vec': +        s = (geom['DetectorRowCount'], geom[ +             'Vectors'].shape[0], geom['DetectorColCount']) + +    if dim != None: +        s = s[dim] + +    return s diff --git a/python/astra/utils.pyx b/python/astra/utils.pyx index 0439f1b..ddb37aa 100644 --- a/python/astra/utils.pyx +++ b/python/astra/utils.pyx @@ -26,6 +26,7 @@  # distutils: language = c++  # distutils: libraries = astra +cimport numpy as np  import numpy as np  import six  from libcpp.string cimport string @@ -80,11 +81,12 @@ def wrap_from_bytes(value):      return s -cdef void readDict(XMLNode * root, _dc): -    cdef XMLNode * listbase -    cdef XMLNode * itm +cdef void readDict(XMLNode root, _dc): +    cdef XMLNode listbase +    cdef XMLNode itm      cdef int i      cdef int j +    cdef double* data      dc = convert_item(_dc)      for item in dc: @@ -93,45 +95,31 @@ cdef void readDict(XMLNode * root, _dc):              if val.size == 0:                  break              listbase = root.addChildNode(item) -            listbase.addAttribute(< string > six.b('listsize'), < float32 > val.size) -            index = 0 +            data = <double*>np.PyArray_DATA(np.ascontiguousarray(val,dtype=np.float64))               if val.ndim == 2: -                for i in range(val.shape[0]): -                    for j in range(val.shape[1]): -                        itm = listbase.addChildNode(six.b('ListItem')) -                        itm.addAttribute(< string > six.b('index'), < float32 > index) -                        itm.addAttribute( < string > six.b('value'), < float32 > val[i, j]) -                        index += 1 -                        del itm +                listbase.setContent(data, val.shape[1], val.shape[0], False)              elif val.ndim == 1: -                for i in range(val.shape[0]): -                    itm = listbase.addChildNode(six.b('ListItem')) -                    itm.addAttribute(< string > six.b('index'), < float32 > index) -                    itm.addAttribute(< string > six.b('value'), < float32 > val[i]) -                    index += 1 -                    del itm +                listbase.setContent(data, val.shape[0])              else:                  raise Exception("Only 1 or 2 dimensions are allowed") -            del listbase          elif isinstance(val, dict):              if item == six.b('option') or item == six.b('options') or item == six.b('Option') or item == six.b('Options'):                  readOptions(root, val)              else:                  itm = root.addChildNode(item)                  readDict(itm, val) -                del itm          else:              if item == six.b('type'):                  root.addAttribute(< string > six.b('type'), <string> wrap_to_bytes(val))              else:                  itm = root.addChildNode(item, wrap_to_bytes(val)) -                del itm -cdef void readOptions(XMLNode * node, dc): -    cdef XMLNode * listbase -    cdef XMLNode * itm +cdef void readOptions(XMLNode node, dc): +    cdef XMLNode listbase +    cdef XMLNode itm      cdef int i      cdef int j +    cdef double* data      for item in dc:          val = dc[item]          if node.hasOption(item): @@ -141,26 +129,13 @@ cdef void readOptions(XMLNode * node, dc):                  break              listbase = node.addChildNode(six.b('Option'))              listbase.addAttribute(< string > six.b('key'), < string > item) -            listbase.addAttribute(< string > six.b('listsize'), < float32 > val.size) -            index = 0 +            data = <double*>np.PyArray_DATA(np.ascontiguousarray(val,dtype=np.float64))               if val.ndim == 2: -                for i in range(val.shape[0]): -                    for j in range(val.shape[1]): -                        itm = listbase.addChildNode(six.b('ListItem')) -                        itm.addAttribute(< string > six.b('index'), < float32 > index) -                        itm.addAttribute( < string > six.b('value'), < float32 > val[i, j]) -                        index += 1 -                        del itm +                listbase.setContent(data, val.shape[1], val.shape[0], False)              elif val.ndim == 1: -                for i in range(val.shape[0]): -                    itm = listbase.addChildNode(six.b('ListItem')) -                    itm.addAttribute(< string > six.b('index'), < float32 > index) -                    itm.addAttribute(< string > six.b('value'), < float32 > val[i]) -                    index += 1 -                    del itm +                listbase.setContent(data, val.shape[0])              else:                  raise Exception("Only 1 or 2 dimensions are allowed") -            del listbase          else:              node.addOption(item, wrap_to_bytes(val)) @@ -214,10 +189,10 @@ def stringToPythonValue(inputIn):              return str(input) -cdef XMLNode2dict(XMLNode * node): -    cdef XMLNode * subnode -    cdef list[XMLNode * ] nodes -    cdef list[XMLNode * ].iterator it +cdef XMLNode2dict(XMLNode node): +    cdef XMLNode subnode +    cdef list[XMLNode] nodes +    cdef list[XMLNode].iterator it      dct = {}      opts = {}      if node.hasAttribute(six.b('type')): @@ -230,7 +205,6 @@ cdef XMLNode2dict(XMLNode * node):              opts[castString(subnode.getAttribute('key'))] = stringToPythonValue(subnode.getAttribute('value'))          else:              dct[castString(subnode.getName())] = stringToPythonValue(subnode.getContent()) -        del subnode          inc(it)      if len(opts)>0: dct['options'] = opts      return dct diff --git a/python/builder.py b/python/builder.py index ddca795..cfdb7d1 100644 --- a/python/builder.py +++ b/python/builder.py @@ -41,9 +41,22 @@ try:          usecuda=True  except KeyError:      pass -cfg = open('astra/config.pxi','w') -cfg.write('DEF HAVE_CUDA=' + str(usecuda) + "\n") -cfg.close() + +cfgToWrite = 'DEF HAVE_CUDA=' + str(usecuda) + "\n" +cfgHasToBeUpdated = True +try: +    cfg = open('astra/config.pxi','r') +    cfgIn = cfg.read() +    cfg.close() +    if cfgIn==cfgToWrite: +        cfgHasToBeUpdated = False +except IOError: +    pass + +if cfgHasToBeUpdated: +    cfg = open('astra/config.pxi','w') +    cfg.write(cfgToWrite) +    cfg.close()  cmdclass = { }  ext_modules = [ ] diff --git a/python/docSRC/index.rst b/python/docSRC/index.rst index 8d17a4a..b7cc6d6 100644 --- a/python/docSRC/index.rst +++ b/python/docSRC/index.rst @@ -18,7 +18,7 @@ Contents:     matrix     creators     functions -   ASTRAProjector +   operator     matlab     astra  .. astra diff --git a/python/docSRC/ASTRAProjector.rst b/python/docSRC/operator.rst index 1c267e3..f5369fa 100644 --- a/python/docSRC/ASTRAProjector.rst +++ b/python/docSRC/operator.rst @@ -1,7 +1,7 @@ -Helper class: the :mod:`ASTRAProjector` module +OpTomo class: the :mod:`operator` module  ============================================== -.. automodule:: astra.ASTRAProjector +.. automodule:: astra.operator      :members:      :undoc-members:      :show-inheritance: diff --git a/samples/matlab/s017_opTomo.m b/samples/matlab/s017_opTomo.m new file mode 100644 index 0000000..891a93d --- /dev/null +++ b/samples/matlab/s017_opTomo.m @@ -0,0 +1,62 @@ +% ----------------------------------------------------------------------- +% This file is part of the ASTRA Toolbox +%  +% Copyright: 2010-2015, iMinds-Vision Lab, University of Antwerp +%            2014-2015, CWI, Amsterdam +% License: Open Source under GPLv3 +% Contact: astra@uantwerpen.be +% Website: http://sf.net/projects/astra-toolbox +% ----------------------------------------------------------------------- + +% This sample illustrates the use of opTomo. +% +% opTomo is a wrapper around the FP and BP operations of the ASTRA Toolbox, +% to allow you to use them as you would a matrix. +% +% This class requires the Spot Linear-Operator Toolbox to be installed. +% You can download this at http://www.cs.ubc.ca/labs/scl/spot/ + +% load a phantom image +im = phantom(256); +% and flatten it to a vector +x = im(:); + +%% Setting up the geometry +% projection geometry +proj_geom = astra_create_proj_geom('parallel', 1, 256, linspace2(0,pi,180)); +% object dimensions +vol_geom  = astra_create_vol_geom(256,256); + +%% Generate projection data +% Create the Spot operator for ASTRA using the GPU. +W = opTomo('cuda', proj_geom, vol_geom); + +p = W*x; + +% reshape the vector into a sinogram +sinogram = reshape(p, W.proj_size); +imshow(sinogram, []); + + +%% Reconstruction +% We use a least squares solver lsqr from Matlab to solve the  +% equation W*x = p. +% Max number of iterations is 100, convergence tolerance of 1e-6. +y = lsqr(W, p, 1e-6, 100); + +% the output is a vector, so we reshape it into an image +reconstruction = reshape(y, W.vol_size); + +subplot(1,3,1); +imshow(reconstruction, []); +title('Reconstruction'); + +subplot(1,3,2); +imshow(im, []); +title('Ground truth'); + +% The transpose of the operator corresponds to the backprojection. +backProjection = W'*p; +subplot(1,3,3); +imshow(reshape(backProjection, W.vol_size), []); +title('Backprojection'); diff --git a/samples/python/s001_sinogram_par2d.py b/samples/python/s001_sinogram_par2d.py index 009d9b3..1d1b912 100644 --- a/samples/python/s001_sinogram_par2d.py +++ b/samples/python/s001_sinogram_par2d.py @@ -43,8 +43,8 @@ P = scipy.io.loadmat('phantom.mat')['phantom256']  # Create a sinogram using the GPU.  # Note that the first time the GPU is accessed, there may be a delay  # of up to 10 seconds for initialization. -proj_id = astra.create_projector('line',proj_geom,vol_geom) -sinogram_id, sinogram = astra.create_sino(P, proj_id,useCUDA=True) +proj_id = astra.create_projector('cuda',proj_geom,vol_geom) +sinogram_id, sinogram = astra.create_sino(P, proj_id)  import pylab  pylab.gray() diff --git a/samples/python/s003_gpu_reconstruction.py b/samples/python/s003_gpu_reconstruction.py index 4f6ec1f..07b38ef 100644 --- a/samples/python/s003_gpu_reconstruction.py +++ b/samples/python/s003_gpu_reconstruction.py @@ -33,8 +33,8 @@ proj_geom = astra.create_proj_geom('parallel', 1.0, 384, np.linspace(0,np.pi,180  # As before, create a sinogram from a phantom  import scipy.io  P = scipy.io.loadmat('phantom.mat')['phantom256'] -proj_id = astra.create_projector('line',proj_geom,vol_geom) -sinogram_id, sinogram = astra.create_sino(P, proj_id,useCUDA=True) +proj_id = astra.create_projector('cuda',proj_geom,vol_geom) +sinogram_id, sinogram = astra.create_sino(P, proj_id)  import pylab  pylab.gray() diff --git a/samples/python/s005_3d_geometry.py b/samples/python/s005_3d_geometry.py index f43fc7e..a7f7a3d 100644 --- a/samples/python/s005_3d_geometry.py +++ b/samples/python/s005_3d_geometry.py @@ -24,7 +24,11 @@  #  #----------------------------------------------------------------------- -from six.moves import range +try: +    from six.moves import range +except ImportError: +    # six 1.3.0 +    from six.moves import xrange as range  import astra  import numpy as np diff --git a/samples/python/s008_gpu_selection.py b/samples/python/s008_gpu_selection.py index c42e53b..a180802 100644 --- a/samples/python/s008_gpu_selection.py +++ b/samples/python/s008_gpu_selection.py @@ -32,10 +32,10 @@ proj_geom = astra.create_proj_geom('parallel', 1.0, 384, np.linspace(0,np.pi,180  import scipy.io  P = scipy.io.loadmat('phantom.mat')['phantom256'] -proj_id = astra.create_projector('line',proj_geom,vol_geom) +proj_id = astra.create_projector('cuda',proj_geom,vol_geom)  # Create a sinogram from a phantom, using GPU #1. (The default is #0) -sinogram_id, sinogram = astra.create_sino(P, proj_id, useCUDA=True, gpuIndex=1) +sinogram_id, sinogram = astra.create_sino(P, proj_id, gpuIndex=1)  # Set up the parameters for a reconstruction algorithm using the GPU diff --git a/samples/python/s012_masks.py b/samples/python/s012_masks.py index 441d11b..0f667b0 100644 --- a/samples/python/s012_masks.py +++ b/samples/python/s012_masks.py @@ -48,8 +48,8 @@ proj_geom = astra.create_proj_geom('parallel', 1.0, 384, np.linspace(0,np.pi,50,  # As before, create a sinogram from a phantom  import scipy.io  P = scipy.io.loadmat('phantom.mat')['phantom256'] -proj_id = astra.create_projector('line',proj_geom,vol_geom) -sinogram_id, sinogram = astra.create_sino(P, proj_id,useCUDA=True) +proj_id = astra.create_projector('cuda',proj_geom,vol_geom) +sinogram_id, sinogram = astra.create_sino(P, proj_id)  pylab.figure(2)  pylab.imshow(P) diff --git a/samples/python/s013_constraints.py b/samples/python/s013_constraints.py index 009360e..8b63d5e 100644 --- a/samples/python/s013_constraints.py +++ b/samples/python/s013_constraints.py @@ -36,8 +36,8 @@ proj_geom = astra.create_proj_geom('parallel', 1.0, 384, np.linspace(0,np.pi,50,  # As before, create a sinogram from a phantom  import scipy.io  P = scipy.io.loadmat('phantom.mat')['phantom256'] -proj_id = astra.create_projector('line',proj_geom,vol_geom) -sinogram_id, sinogram = astra.create_sino(P, proj_id,useCUDA=True) +proj_id = astra.create_projector('cuda',proj_geom,vol_geom) +sinogram_id, sinogram = astra.create_sino(P, proj_id)  import pylab  pylab.gray() diff --git a/samples/python/s014_FBP.py b/samples/python/s014_FBP.py index ef4afc2..2f8e388 100644 --- a/samples/python/s014_FBP.py +++ b/samples/python/s014_FBP.py @@ -33,8 +33,8 @@ proj_geom = astra.create_proj_geom('parallel', 1.0, 384, np.linspace(0,np.pi,180  # As before, create a sinogram from a phantom  import scipy.io  P = scipy.io.loadmat('phantom.mat')['phantom256'] -proj_id = astra.create_projector('line',proj_geom,vol_geom) -sinogram_id, sinogram = astra.create_sino(P, proj_id,useCUDA=True) +proj_id = astra.create_projector('cuda',proj_geom,vol_geom) +sinogram_id, sinogram = astra.create_sino(P, proj_id)  import pylab  pylab.gray() diff --git a/samples/python/s015_fp_bp.py b/samples/python/s015_fp_bp.py index 10c238d..fa0bf86 100644 --- a/samples/python/s015_fp_bp.py +++ b/samples/python/s015_fp_bp.py @@ -26,8 +26,8 @@  # This example demonstrates using the FP and BP primitives with Matlab's lsqr -# solver. Calls to FP (astra_create_sino_cuda) and -# BP (astra_create_backprojection_cuda) are wrapped in a function astra_wrap, +# solver. Calls to FP (astra.create_sino) and +# BP (astra.create_backprojection) are wrapped in a function astra_wrap,  # and a handle to this function is passed to lsqr.  # Because in this case the inputs/outputs of FP and BP have to be vectors @@ -39,17 +39,17 @@ import numpy as np  # FP/BP wrapper class  class astra_wrap(object):      def __init__(self,proj_geom,vol_geom): -        self.proj_id = astra.create_projector('line',proj_geom,vol_geom) +        self.proj_id = astra.create_projector('cuda',proj_geom,vol_geom)          self.shape = (proj_geom['DetectorCount']*len(proj_geom['ProjectionAngles']),vol_geom['GridColCount']*vol_geom['GridRowCount'])          self.dtype = np.float      def matvec(self,v): -        sid, s = astra.create_sino(np.reshape(v,(vol_geom['GridRowCount'],vol_geom['GridColCount'])),self.proj_id,useCUDA=True) +        sid, s = astra.create_sino(np.reshape(v,(vol_geom['GridRowCount'],vol_geom['GridColCount'])),self.proj_id)          astra.data2d.delete(sid)          return s.flatten()      def rmatvec(self,v): -        bid, b = astra.create_backprojection(np.reshape(v,(len(proj_geom['ProjectionAngles']),proj_geom['DetectorCount'],)),self.proj_id,useCUDA=True) +        bid, b = astra.create_backprojection(np.reshape(v,(len(proj_geom['ProjectionAngles']),proj_geom['DetectorCount'],)),self.proj_id)          astra.data2d.delete(bid)          return b.flatten() @@ -61,8 +61,8 @@ import scipy.io  P = scipy.io.loadmat('phantom.mat')['phantom256']  # Create a sinogram using the GPU. -proj_id = astra.create_projector('line',proj_geom,vol_geom) -sinogram_id, sinogram = astra.create_sino(P, proj_id,useCUDA=True) +proj_id = astra.create_projector('cuda',proj_geom,vol_geom) +sinogram_id, sinogram = astra.create_sino(P, proj_id)  # Reshape the sinogram into a vector  b = sinogram.flatten() diff --git a/samples/python/s016_plots.py b/samples/python/s016_plots.py index cd4d98c..8a8ba64 100644 --- a/samples/python/s016_plots.py +++ b/samples/python/s016_plots.py @@ -24,7 +24,11 @@  #  #----------------------------------------------------------------------- -from six.moves import range +try: +    from six.moves import range +except ImportError: +    # six 1.3.0 +    from six.moves import xrange as range  import astra  import numpy as np @@ -35,8 +39,8 @@ proj_geom = astra.create_proj_geom('parallel', 1.0, 384, np.linspace(0,np.pi,180  # As before, create a sinogram from a phantom  import scipy.io  P = scipy.io.loadmat('phantom.mat')['phantom256'] -proj_id = astra.create_projector('line',proj_geom,vol_geom) -sinogram_id, sinogram = astra.create_sino(P, proj_id,useCUDA=True) +proj_id = astra.create_projector('cuda',proj_geom,vol_geom) +sinogram_id, sinogram = astra.create_sino(P, proj_id)  import pylab  pylab.gray() diff --git a/samples/python/s017_OpTomo.py b/samples/python/s017_OpTomo.py new file mode 100644 index 0000000..967fa64 --- /dev/null +++ b/samples/python/s017_OpTomo.py @@ -0,0 +1,61 @@ +#----------------------------------------------------------------------- +#Copyright 2013 Centrum Wiskunde & Informatica, Amsterdam +# +#Author: Daniel M. Pelt +#Contact: D.M.Pelt@cwi.nl +#Website: http://dmpelt.github.io/pyastratoolbox/ +# +# +#This file is part of the Python interface to the +#All Scale Tomographic Reconstruction Antwerp Toolbox ("ASTRA Toolbox"). +# +#The Python interface to 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 Python interface to 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 Python interface to the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. +# +#----------------------------------------------------------------------- + +import astra +import numpy as np +import scipy.sparse.linalg + +vol_geom = astra.create_vol_geom(256, 256) +proj_geom = astra.create_proj_geom('parallel', 1.0, 384, np.linspace(0,np.pi,180,False)) + +# As before, create a sinogram from a phantom +import scipy.io +P = scipy.io.loadmat('phantom.mat')['phantom256'] +proj_id = astra.create_projector('cuda',proj_geom,vol_geom) + +# construct the OpTomo object +W = astra.OpTomo(proj_id) + +sinogram = W * P +sinogram = sinogram.reshape([180, 384]) + +import pylab +pylab.gray() +pylab.figure(1) +pylab.imshow(P) +pylab.figure(2) +pylab.imshow(sinogram) + +# Run the lsqr linear solver +output = scipy.sparse.linalg.lsqr(W, sinogram.flatten(), iter_lim=150) +rec = output[0].reshape([256, 256]) + +pylab.figure(3) +pylab.imshow(rec) +pylab.show() + +# Clean up. +astra.projector.delete(proj_id) diff --git a/src/ArtAlgorithm.cpp b/src/ArtAlgorithm.cpp index 8f058a3..6a699ec 100644 --- a/src/ArtAlgorithm.cpp +++ b/src/ArtAlgorithm.cpp @@ -132,7 +132,7 @@ bool CArtAlgorithm::initialize(const Config& _cfg)  	}  	// ray order -	string projOrder = _cfg.self->getOption("RayOrder", "sequential"); +	string projOrder = _cfg.self.getOption("RayOrder", "sequential");  	CC.markOptionParsed("RayOrder");  	m_iCurrentRay = 0;  	m_iRayCount = m_pProjector->getProjectionGeometry()->getProjectionAngleCount() *  @@ -145,7 +145,7 @@ bool CArtAlgorithm::initialize(const Config& _cfg)  			m_piDetectorOrder[i] = i % m_pProjector->getProjectionGeometry()->getDetectorCount();  		}  	} else if (projOrder == "custom") { -		vector<float32> rayOrderList = _cfg.self->getOptionNumericalArray("RayOrderList"); +		vector<float32> rayOrderList = _cfg.self.getOptionNumericalArray("RayOrderList");  		m_iRayCount = rayOrderList.size() / 2;  		m_piProjectionOrder = new int[m_iRayCount];  		m_piDetectorOrder = new int[m_iRayCount]; @@ -158,7 +158,7 @@ bool CArtAlgorithm::initialize(const Config& _cfg)  		return false;  	} -	m_fLambda = _cfg.self->getOptionNumerical("Lambda", 1.0f); +	m_fLambda = _cfg.self.getOptionNumerical("Lambda", 1.0f);  	CC.markOptionParsed("Lambda");  	// success diff --git a/src/ConeProjectionGeometry3D.cpp b/src/ConeProjectionGeometry3D.cpp index eb9adcf..dd22eba 100644 --- a/src/ConeProjectionGeometry3D.cpp +++ b/src/ConeProjectionGeometry3D.cpp @@ -28,6 +28,8 @@ $Id$  #include "astra/ConeProjectionGeometry3D.h" +#include "astra/Logging.h" +  #include <boost/lexical_cast.hpp>  #include <cstring> @@ -85,17 +87,15 @@ bool CConeProjectionGeometry3D::initialize(const Config& _cfg)  	CProjectionGeometry3D::initialize(_cfg);  	// Required: DistanceOriginDetector -	XMLNode* node = _cfg.self->getSingleNode("DistanceOriginDetector"); +	XMLNode node = _cfg.self.getSingleNode("DistanceOriginDetector");  	ASTRA_CONFIG_CHECK(node, "ConeProjectionGeometry3D", "No DistanceOriginDetector tag specified."); -	m_fOriginDetectorDistance = boost::lexical_cast<float32>(node->getContent()); -	ASTRA_DELETE(node); +	m_fOriginDetectorDistance = boost::lexical_cast<float32>(node.getContent());  	CC.markNodeParsed("DistanceOriginDetector");  	// Required: DetectorOriginSource -	node = _cfg.self->getSingleNode("DistanceOriginSource"); +	node = _cfg.self.getSingleNode("DistanceOriginSource");  	ASTRA_CONFIG_CHECK(node, "ConeProjectionGeometry3D", "No DistanceOriginSource tag specified."); -	m_fOriginSourceDistance = boost::lexical_cast<float32>(node->getContent()); -	ASTRA_DELETE(node); +	m_fOriginSourceDistance = boost::lexical_cast<float32>(node.getContent());  	CC.markNodeParsed("DistanceOriginSource");  	// success @@ -191,14 +191,14 @@ Config* CConeProjectionGeometry3D::getConfiguration() const  {  	Config* cfg = new Config();  	cfg->initialize("ProjectionGeometry3D"); -	cfg->self->addAttribute("type", "cone"); -	cfg->self->addChildNode("DetectorSpacingX", m_fDetectorSpacingX); -	cfg->self->addChildNode("DetectorSpacingY", m_fDetectorSpacingY); -	cfg->self->addChildNode("DetectorRowCount", m_iDetectorRowCount); -	cfg->self->addChildNode("DetectorColCount", m_iDetectorColCount); -	cfg->self->addChildNode("DistanceOriginDetector", m_fOriginDetectorDistance); -	cfg->self->addChildNode("DistanceOriginSource", m_fOriginSourceDistance); -	cfg->self->addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount); +	cfg->self.addAttribute("type", "cone"); +	cfg->self.addChildNode("DetectorSpacingX", m_fDetectorSpacingX); +	cfg->self.addChildNode("DetectorSpacingY", m_fDetectorSpacingY); +	cfg->self.addChildNode("DetectorRowCount", m_iDetectorRowCount); +	cfg->self.addChildNode("DetectorColCount", m_iDetectorColCount); +	cfg->self.addChildNode("DistanceOriginDetector", m_fOriginDetectorDistance); +	cfg->self.addChildNode("DistanceOriginSource", m_fOriginSourceDistance); +	cfg->self.addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount);  	return cfg;  } @@ -257,7 +257,7 @@ void CConeProjectionGeometry3D::projectPoint(float32 fX, float32 fY, float32 fZ,  	// Scale fS to detector plane  	fU = detectorOffsetXToColIndexFloat( (fS * (m_fOriginSourceDistance + m_fOriginDetectorDistance)) / fD ); -	fprintf(stderr, "alpha: %f, D: %f, V: %f, S: %f, U: %f\n", alpha, fD, fV, fS, fU); +	ASTRA_DEBUG("alpha: %f, D: %f, V: %f, S: %f, U: %f", alpha, fD, fV, fS, fU);  } diff --git a/src/ConeVecProjectionGeometry3D.cpp b/src/ConeVecProjectionGeometry3D.cpp index 9dc273d..47ed630 100644 --- a/src/ConeVecProjectionGeometry3D.cpp +++ b/src/ConeVecProjectionGeometry3D.cpp @@ -73,33 +73,30 @@ bool CConeVecProjectionGeometry3D::initialize(const Config& _cfg)  	ASTRA_ASSERT(_cfg.self);  	ConfigStackCheck<CProjectionGeometry3D> CC("ConeVecProjectionGeometry3D", this, _cfg);	 -	XMLNode* node; +	XMLNode node;  	// TODO: Fix up class hierarchy... this class doesn't fit very well.  	// initialization of parent class  	//CProjectionGeometry3D::initialize(_cfg);  	// Required: DetectorRowCount -	node = _cfg.self->getSingleNode("DetectorRowCount"); +	node = _cfg.self.getSingleNode("DetectorRowCount");  	ASTRA_CONFIG_CHECK(node, "ConeVecProjectionGeometry3D", "No DetectorRowCount tag specified."); -	m_iDetectorRowCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iDetectorRowCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("DetectorRowCount");  	// Required: DetectorColCount -	node = _cfg.self->getSingleNode("DetectorColCount"); +	node = _cfg.self.getSingleNode("DetectorColCount");  	ASTRA_CONFIG_CHECK(node, "ConeVecProjectionGeometry3D", "No DetectorColCount tag specified."); -	m_iDetectorColCount = boost::lexical_cast<int>(node->getContent()); +	m_iDetectorColCount = boost::lexical_cast<int>(node.getContent());  	m_iDetectorTotCount = m_iDetectorRowCount * m_iDetectorColCount; -	ASTRA_DELETE(node);  	CC.markNodeParsed("DetectorColCount");  	// Required: Vectors -	node = _cfg.self->getSingleNode("Vectors"); +	node = _cfg.self.getSingleNode("Vectors");  	ASTRA_CONFIG_CHECK(node, "ConeVecProjectionGeometry3D", "No Vectors tag specified."); -	vector<double> data = node->getContentNumericalArrayDouble(); +	vector<double> data = node.getContentNumericalArrayDouble();  	CC.markNodeParsed("Vectors"); -	ASTRA_DELETE(node);  	ASTRA_CONFIG_CHECK(data.size() % 12 == 0, "ConeVecProjectionGeometry3D", "Vectors doesn't consist of 12-tuples.");  	m_iProjectionAngleCount = data.size() / 12;  	m_pProjectionAngles = new SConeProjection[m_iProjectionAngleCount]; @@ -208,9 +205,9 @@ Config* CConeVecProjectionGeometry3D::getConfiguration() const  	Config* cfg = new Config();  	cfg->initialize("ProjectionGeometry3D"); -	cfg->self->addAttribute("type", "cone_vec"); -	cfg->self->addChildNode("DetectorRowCount", m_iDetectorRowCount); -	cfg->self->addChildNode("DetectorColCount", m_iDetectorColCount); +	cfg->self.addAttribute("type", "cone_vec"); +	cfg->self.addChildNode("DetectorRowCount", m_iDetectorRowCount); +	cfg->self.addChildNode("DetectorColCount", m_iDetectorColCount);  	std::string vectors = "";  	for (int i = 0; i < m_iProjectionAngleCount; ++i) { @@ -229,7 +226,7 @@ Config* CConeVecProjectionGeometry3D::getConfiguration() const  		vectors += boost::lexical_cast<string>(p.fDetVZ);  		if (i < m_iProjectionAngleCount-1) vectors += ';';  	} -	cfg->self->addChildNode("Vectors", vectors); +	cfg->self.addChildNode("Vectors", vectors);  	return cfg;  } diff --git a/src/Config.cpp b/src/Config.cpp index 653935e..395080b 100644 --- a/src/Config.cpp +++ b/src/Config.cpp @@ -37,36 +37,41 @@ $Id$  #include "astra/Projector2D.h"  #include "astra/Projector3D.h" +#include "astra/Logging.h" +#include <sstream> +  using namespace astra;  using namespace std;  //-----------------------------------------------------------------------------  // default constructor -Config::Config() +Config::Config() : self()  { -	self = 0; +	_doc = 0;  }  //-----------------------------------------------------------------------------  // not so default constructor -Config::Config(XMLNode* _self)  +Config::Config(XMLNode _self)  {  	self = _self; +	_doc = 0;  }  //-----------------------------------------------------------------------------  Config::~Config()  { -	delete self; -	self = 0; +	delete _doc; +	_doc = 0;  }  //-----------------------------------------------------------------------------  void Config::initialize(std::string rootname)  { -	if (self == 0) { +	if (!self) {  		XMLDocument* doc = XMLDocument::createDocument(rootname);  		self = doc->getRootNode();		 +		_doc = doc;  	}  } @@ -121,13 +126,13 @@ bool ConfigStackCheck<T>::stopParsing()  	std::string errors; -	std::list<XMLNode*> nodes = cfg->self->getNodes(); -	for (std::list<XMLNode*>::iterator i = nodes.begin(); i != nodes.end(); ++i) +	std::list<XMLNode> nodes = cfg->self.getNodes(); +	for (std::list<XMLNode>::iterator i = nodes.begin(); i != nodes.end(); ++i)  	{ -		std::string nodeName = (*i)->getName(); +		std::string nodeName = i->getName();  		if (nodeName == "Option") { -			nodeName = (*i)->getAttribute("key", ""); +			nodeName = i->getAttribute("key", "");  			if (object->configCheckData->parsedOptions.find(nodeName) == object->configCheckData->parsedOptions.end()) {  				if (!errors.empty()) errors += ", ";  				errors += nodeName; @@ -139,12 +144,12 @@ bool ConfigStackCheck<T>::stopParsing()  			}  		}  	} -	for (std::list<XMLNode*>::iterator i = nodes.begin(); i != nodes.end(); ++i) -		delete (*i);  	nodes.clear();  	if (!errors.empty()) { -		cout << "Warning: " << name << ": unused configuration options: " << errors << std::endl; +		ostringstream os; +		os << name << ": unused configuration options: " << errors; +		ASTRA_WARN(os.str().c_str());  		return false;  	} diff --git a/src/CudaBackProjectionAlgorithm3D.cpp b/src/CudaBackProjectionAlgorithm3D.cpp index abcf096..fbb8f28 100644 --- a/src/CudaBackProjectionAlgorithm3D.cpp +++ b/src/CudaBackProjectionAlgorithm3D.cpp @@ -102,9 +102,9 @@ bool CCudaBackProjectionAlgorithm3D::initialize(const Config& _cfg)  		return false;  	} -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1);  	CC.markOptionParsed("GPUindex"); -	m_iVoxelSuperSampling = (int)_cfg.self->getOptionNumerical("VoxelSuperSampling", 1); +	m_iVoxelSuperSampling = (int)_cfg.self.getOptionNumerical("VoxelSuperSampling", 1);  	CC.markOptionParsed("VoxelSuperSampling");  	CFloat32ProjectionData3DMemory* pSinoMem = dynamic_cast<CFloat32ProjectionData3DMemory*>(m_pSinogram); @@ -114,7 +114,7 @@ const CParallelProjectionGeometry3D* par3dgeom = dynamic_cast<const CParallelPro  	const CParallelVecProjectionGeometry3D* parvec3dgeom = dynamic_cast<const CParallelVecProjectionGeometry3D*>(projgeom);  	if (parvec3dgeom || par3dgeom) {  		// This option is only supported for Par3D currently -		m_bSIRTWeighting = _cfg.self->getOptionBool("SIRTWeighting", false); +		m_bSIRTWeighting = _cfg.self.getOptionBool("SIRTWeighting", false);  		CC.markOptionParsed("SIRTWeighting");  	} diff --git a/src/CudaCglsAlgorithm3D.cpp b/src/CudaCglsAlgorithm3D.cpp index a5500d6..3457b81 100644 --- a/src/CudaCglsAlgorithm3D.cpp +++ b/src/CudaCglsAlgorithm3D.cpp @@ -106,11 +106,11 @@ bool CCudaCglsAlgorithm3D::initialize(const Config& _cfg)  		return false;  	} -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1);  	CC.markOptionParsed("GPUindex"); -	m_iDetectorSuperSampling = (int)_cfg.self->getOptionNumerical("DetectorSuperSampling", 1); +	m_iDetectorSuperSampling = (int)_cfg.self.getOptionNumerical("DetectorSuperSampling", 1);  	CC.markOptionParsed("DetectorSuperSampling"); -	m_iVoxelSuperSampling = (int)_cfg.self->getOptionNumerical("VoxelSuperSampling", 1); +	m_iVoxelSuperSampling = (int)_cfg.self.getOptionNumerical("VoxelSuperSampling", 1);  	CC.markOptionParsed("VoxelSuperSampling");  	m_pCgls = new AstraCGLS3d(); diff --git a/src/CudaDartMaskAlgorithm.cpp b/src/CudaDartMaskAlgorithm.cpp index dcdefcc..950b428 100644 --- a/src/CudaDartMaskAlgorithm.cpp +++ b/src/CudaDartMaskAlgorithm.cpp @@ -65,38 +65,36 @@ bool CCudaDartMaskAlgorithm::initialize(const Config& _cfg)  	ConfigStackCheck<CAlgorithm> CC("CudaDartMaskAlgorithm", this, _cfg);  	// reconstruction data -	XMLNode* node = _cfg.self->getSingleNode("SegmentationDataId"); +	XMLNode node = _cfg.self.getSingleNode("SegmentationDataId");  	ASTRA_CONFIG_CHECK(node, "CudaDartMask", "No SegmentationDataId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pSegmentation = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("SegmentationDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("MaskDataId"); +	node = _cfg.self.getSingleNode("MaskDataId");  	ASTRA_CONFIG_CHECK(node, "CudaDartMask", "No MaskDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pMask = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("MaskDataId");  	// Option: GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUIndex", m_iGPUIndex); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUIndex", m_iGPUIndex);  	CC.markOptionParsed("GPUindex"); -	if (!_cfg.self->hasOption("GPUindex")) +	if (!_cfg.self.hasOption("GPUindex"))  		CC.markOptionParsed("GPUIndex");      // Option: Connectivity -	m_iConn = (unsigned int)_cfg.self->getOptionNumerical("Connectivity", 8); +	m_iConn = (unsigned int)_cfg.self.getOptionNumerical("Connectivity", 8);  	CC.markOptionParsed("Connectivity");  	// Option: Threshold -	m_iThreshold = (unsigned int)_cfg.self->getOptionNumerical("Threshold", 1); +	m_iThreshold = (unsigned int)_cfg.self.getOptionNumerical("Threshold", 1);  	CC.markOptionParsed("Threshold");  	// Option: Radius -	m_iRadius = (unsigned int)_cfg.self->getOptionNumerical("Radius", 1); +	m_iRadius = (unsigned int)_cfg.self.getOptionNumerical("Radius", 1);  	CC.markOptionParsed("Radius");  	_check(); diff --git a/src/CudaDartMaskAlgorithm3D.cpp b/src/CudaDartMaskAlgorithm3D.cpp index f3500b9..b0dfc5b 100644 --- a/src/CudaDartMaskAlgorithm3D.cpp +++ b/src/CudaDartMaskAlgorithm3D.cpp @@ -65,38 +65,36 @@ bool CCudaDartMaskAlgorithm3D::initialize(const Config& _cfg)  	ConfigStackCheck<CAlgorithm> CC("CudaDartMaskAlgorithm", this, _cfg);  	// reconstruction data -	XMLNode* node = _cfg.self->getSingleNode("SegmentationDataId"); +	XMLNode node = _cfg.self.getSingleNode("SegmentationDataId");  	ASTRA_CONFIG_CHECK(node, "CudaDartMask", "No SegmentationDataId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pSegmentation = dynamic_cast<CFloat32VolumeData3DMemory*>(CData3DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("SegmentationDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("MaskDataId"); +	node = _cfg.self.getSingleNode("MaskDataId");  	ASTRA_CONFIG_CHECK(node, "CudaDartMask", "No MaskDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pMask = dynamic_cast<CFloat32VolumeData3DMemory*>(CData3DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("MaskDataId");  	// Option: GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUIndex", m_iGPUIndex); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUIndex", m_iGPUIndex);  	CC.markOptionParsed("GPUindex"); -	if (!_cfg.self->hasOption("GPUindex")) +	if (!_cfg.self.hasOption("GPUindex"))  		CC.markOptionParsed("GPUIndex");      // Option: Connectivity -	m_iConn = (unsigned int)_cfg.self->getOptionNumerical("Connectivity", 8); +	m_iConn = (unsigned int)_cfg.self.getOptionNumerical("Connectivity", 8);  	CC.markOptionParsed("Connectivity");  	// Option: Threshold -	m_iThreshold = (unsigned int)_cfg.self->getOptionNumerical("Threshold", 1); +	m_iThreshold = (unsigned int)_cfg.self.getOptionNumerical("Threshold", 1);  	CC.markOptionParsed("Threshold");  	// Option: Radius -	m_iRadius = (unsigned int)_cfg.self->getOptionNumerical("Radius", 1); +	m_iRadius = (unsigned int)_cfg.self.getOptionNumerical("Radius", 1);  	CC.markOptionParsed("Radius");  	_check(); diff --git a/src/CudaDartSmoothingAlgorithm.cpp b/src/CudaDartSmoothingAlgorithm.cpp index 2f2103f..7e22809 100644 --- a/src/CudaDartSmoothingAlgorithm.cpp +++ b/src/CudaDartSmoothingAlgorithm.cpp @@ -65,34 +65,32 @@ bool CCudaDartSmoothingAlgorithm::initialize(const Config& _cfg)  	ConfigStackCheck<CAlgorithm> CC("CudaDartSmoothingAlgorithm", this, _cfg);  	// reconstruction data -	XMLNode* node = _cfg.self->getSingleNode("InDataId"); +	XMLNode node = _cfg.self.getSingleNode("InDataId");  	ASTRA_CONFIG_CHECK(node, "CudaDartMask", "No InDataId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pIn = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("InDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("OutDataId"); +	node = _cfg.self.getSingleNode("OutDataId");  	ASTRA_CONFIG_CHECK(node, "CudaDartMask", "No OutDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pOut = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("OutDataId");  	// Option: GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUIndex", m_iGPUIndex); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUIndex", m_iGPUIndex);  	CC.markOptionParsed("GPUindex"); -	if (!_cfg.self->hasOption("GPUindex")) +	if (!_cfg.self.hasOption("GPUindex"))  		CC.markOptionParsed("GPUIndex");  	// Option: Radius -	m_fB = (float)_cfg.self->getOptionNumerical("Intensity", 0.3f); +	m_fB = (float)_cfg.self.getOptionNumerical("Intensity", 0.3f);  	CC.markOptionParsed("Intensity");  	// Option: Radius -	m_iRadius = (unsigned int)_cfg.self->getOptionNumerical("Radius", 1); +	m_iRadius = (unsigned int)_cfg.self.getOptionNumerical("Radius", 1);  	CC.markOptionParsed("Radius"); diff --git a/src/CudaDartSmoothingAlgorithm3D.cpp b/src/CudaDartSmoothingAlgorithm3D.cpp index f3cf015..9c4437a 100644 --- a/src/CudaDartSmoothingAlgorithm3D.cpp +++ b/src/CudaDartSmoothingAlgorithm3D.cpp @@ -65,34 +65,32 @@ bool CCudaDartSmoothingAlgorithm3D::initialize(const Config& _cfg)  	ConfigStackCheck<CAlgorithm> CC("CudaDartSmoothingAlgorithm", this, _cfg);  	// reconstruction data -	XMLNode* node = _cfg.self->getSingleNode("InDataId"); +	XMLNode node = _cfg.self.getSingleNode("InDataId");  	ASTRA_CONFIG_CHECK(node, "CudaDartMask", "No InDataId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pIn = dynamic_cast<CFloat32VolumeData3DMemory*>(CData3DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("InDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("OutDataId"); +	node = _cfg.self.getSingleNode("OutDataId");  	ASTRA_CONFIG_CHECK(node, "CudaDartMask", "No OutDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pOut = dynamic_cast<CFloat32VolumeData3DMemory*>(CData3DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("OutDataId");  	// Option: GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUIndex", m_iGPUIndex); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUIndex", m_iGPUIndex);  	CC.markOptionParsed("GPUindex"); -	if (!_cfg.self->hasOption("GPUindex")) +	if (!_cfg.self.hasOption("GPUindex"))  		CC.markOptionParsed("GPUIndex");  	// Option: Intensity -	m_fB = (float)_cfg.self->getOptionNumerical("Intensity", 0.3f); +	m_fB = (float)_cfg.self.getOptionNumerical("Intensity", 0.3f);  	CC.markOptionParsed("Intensity");  	// Option: Radius -	m_iRadius = (unsigned int)_cfg.self->getOptionNumerical("Radius", 1); +	m_iRadius = (unsigned int)_cfg.self.getOptionNumerical("Radius", 1);  	CC.markOptionParsed("Radius");  	_check(); diff --git a/src/CudaDataOperationAlgorithm.cpp b/src/CudaDataOperationAlgorithm.cpp index 79a9d7f..ae133c2 100644 --- a/src/CudaDataOperationAlgorithm.cpp +++ b/src/CudaDataOperationAlgorithm.cpp @@ -67,40 +67,37 @@ bool CCudaDataOperationAlgorithm::initialize(const Config& _cfg)  	ConfigStackCheck<CAlgorithm> CC("CCudaDataOperationAlgorithm", this, _cfg);  	// operation -	XMLNode* node = _cfg.self->getSingleNode("Operation"); +	XMLNode node = _cfg.self.getSingleNode("Operation");  	ASTRA_CONFIG_CHECK(node, "CCudaDataOperationAlgorithm", "No Operation tag specified."); -	m_sOperation = node->getContent(); +	m_sOperation = node.getContent();  	m_sOperation.erase(std::remove(m_sOperation.begin(), m_sOperation.end(), ' '), m_sOperation.end()); -	ASTRA_DELETE(node);  	CC.markNodeParsed("Operation");  	// data -	node = _cfg.self->getSingleNode("DataId"); +	node = _cfg.self.getSingleNode("DataId");  	ASTRA_CONFIG_CHECK(node, "CCudaDataOperationAlgorithm", "No DataId tag specified."); -	vector<string> data = node->getContentArray(); +	vector<string> data = node.getContentArray();  	for (vector<string>::iterator it = data.begin(); it != data.end(); it++){  		int id = boost::lexical_cast<int>(*it);  		m_pData.push_back(dynamic_cast<CFloat32Data2D*>(CData2DManager::getSingleton().get(id)));  	} -	ASTRA_DELETE(node);  	CC.markNodeParsed("DataId");  	// scalar -	node = _cfg.self->getSingleNode("Scalar"); +	node = _cfg.self.getSingleNode("Scalar");  	ASTRA_CONFIG_CHECK(node, "CCudaDataOperationAlgorithm", "No Scalar tag specified."); -	m_fScalar = node->getContentNumericalArray(); -	ASTRA_DELETE(node); +	m_fScalar = node.getContentNumericalArray();  	CC.markNodeParsed("Scalar");  	// Option: GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUIndex", m_iGPUIndex); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUIndex", m_iGPUIndex);  	CC.markOptionParsed("GPUindex"); -	if (!_cfg.self->hasOption("GPUindex")) +	if (!_cfg.self.hasOption("GPUindex"))  		CC.markOptionParsed("GPUIndex"); -	if (_cfg.self->hasOption("MaskId")) { -		int id = boost::lexical_cast<int>(_cfg.self->getOption("MaskId")); +	if (_cfg.self.hasOption("MaskId")) { +		int id = boost::lexical_cast<int>(_cfg.self.getOption("MaskId"));  		m_pMask = dynamic_cast<CFloat32Data2D*>(CData2DManager::getSingleton().get(id));  	}  	CC.markOptionParsed("MaskId"); diff --git a/src/CudaFDKAlgorithm3D.cpp b/src/CudaFDKAlgorithm3D.cpp index 7638696..467e641 100644 --- a/src/CudaFDKAlgorithm3D.cpp +++ b/src/CudaFDKAlgorithm3D.cpp @@ -100,12 +100,12 @@ bool CCudaFDKAlgorithm3D::initialize(const Config& _cfg)  		return false;  	} -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1);  	CC.markOptionParsed("GPUindex"); -	m_iVoxelSuperSampling = (int)_cfg.self->getOptionNumerical("VoxelSuperSampling", 1); +	m_iVoxelSuperSampling = (int)_cfg.self.getOptionNumerical("VoxelSuperSampling", 1);  	CC.markOptionParsed("VoxelSuperSampling"); -	m_bShortScan = _cfg.self->getOptionBool("ShortScan", false); +	m_bShortScan = _cfg.self.getOptionBool("ShortScan", false);  	CC.markOptionParsed("ShortScan");  	// success diff --git a/src/CudaFilteredBackProjectionAlgorithm.cpp b/src/CudaFilteredBackProjectionAlgorithm.cpp index fcdf860..5d6c166 100644 --- a/src/CudaFilteredBackProjectionAlgorithm.cpp +++ b/src/CudaFilteredBackProjectionAlgorithm.cpp @@ -34,7 +34,7 @@ $Id$  #include "astra/AstraObjectManager.h"  #include "../cuda/2d/astra.h" -#include <astra/Logger.h> +#include "astra/Logging.h"  using namespace std;  using namespace astra; @@ -78,39 +78,36 @@ bool CCudaFilteredBackProjectionAlgorithm::initialize(const Config& _cfg)  	}  	// sinogram data -	XMLNode* node = _cfg.self->getSingleNode("ProjectionDataId"); +	XMLNode node = _cfg.self.getSingleNode("ProjectionDataId");  	ASTRA_CONFIG_CHECK(node, "CudaFBP", "No ProjectionDataId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pSinogram = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectionDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("ReconstructionDataId"); +	node = _cfg.self.getSingleNode("ReconstructionDataId");  	ASTRA_CONFIG_CHECK(node, "CudaFBP", "No ReconstructionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pReconstruction = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ReconstructionDataId");  	// filter type -	node = _cfg.self->getSingleNode("FilterType"); -	if(node != NULL) +	node = _cfg.self.getSingleNode("FilterType"); +	if (node)  	{ -		m_eFilter = _convertStringToFilter(node->getContent().c_str()); +		m_eFilter = _convertStringToFilter(node.getContent().c_str());  	}  	else  	{  		m_eFilter = FILTER_RAMLAK;  	}  	CC.markNodeParsed("FilterType"); -	ASTRA_DELETE(node); -	 +  	// filter -	node = _cfg.self->getSingleNode("FilterSinogramId"); -	if(node != NULL) +	node = _cfg.self.getSingleNode("FilterSinogramId"); +	if (node)  	{ -		id = boost::lexical_cast<int>(node->getContent()); +		id = boost::lexical_cast<int>(node.getContent());  		const CFloat32ProjectionData2D * pFilterData = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id));  		m_iFilterWidth = pFilterData->getGeometry()->getDetectorCount();  		int iFilterProjectionCount = pFilterData->getGeometry()->getProjectionAngleCount(); @@ -124,13 +121,12 @@ bool CCudaFilteredBackProjectionAlgorithm::initialize(const Config& _cfg)  		m_pfFilter = NULL;  	}  	CC.markNodeParsed("FilterSinogramId"); // TODO: Only for some types! -	ASTRA_DELETE(node);  	// filter parameter -	node = _cfg.self->getSingleNode("FilterParameter"); -	if(node != NULL) +	node = _cfg.self.getSingleNode("FilterParameter"); +	if (node)  	{ -		float fParameter = boost::lexical_cast<float>(node->getContent()); +		float fParameter = boost::lexical_cast<float>(node.getContent());  		m_fFilterParameter = fParameter;  	}  	else @@ -138,13 +134,12 @@ bool CCudaFilteredBackProjectionAlgorithm::initialize(const Config& _cfg)  		m_fFilterParameter = -1.0f;  	}  	CC.markNodeParsed("FilterParameter"); // TODO: Only for some types! -	ASTRA_DELETE(node);  	// D value -	node = _cfg.self->getSingleNode("FilterD"); -	if(node != NULL) +	node = _cfg.self.getSingleNode("FilterD"); +	if (node)  	{ -		float fD = boost::lexical_cast<float>(node->getContent()); +		float fD = boost::lexical_cast<float>(node.getContent());  		m_fFilterD = fD;  	}  	else @@ -152,23 +147,22 @@ bool CCudaFilteredBackProjectionAlgorithm::initialize(const Config& _cfg)  		m_fFilterD = 1.0f;  	}  	CC.markNodeParsed("FilterD"); // TODO: Only for some types! -	ASTRA_DELETE(node);  	// GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1);  	CC.markOptionParsed("GPUindex");  	// Pixel supersampling factor -	m_iPixelSuperSampling = (int)_cfg.self->getOptionNumerical("PixelSuperSampling", 1); +	m_iPixelSuperSampling = (int)_cfg.self.getOptionNumerical("PixelSuperSampling", 1);  	CC.markOptionParsed("PixelSuperSampling");  	// Fan beam short scan mode  	if (m_pSinogram && dynamic_cast<CFanFlatProjectionGeometry2D*>(m_pSinogram->getGeometry())) { -		m_bShortScan = (int)_cfg.self->getOptionBool("ShortScan", false); +		m_bShortScan = (int)_cfg.self.getOptionBool("ShortScan", false);  		CC.markOptionParsed("ShortScan");  	} -	 +  	m_pFBP = new AstraFBP; @@ -186,7 +180,7 @@ bool CCudaFilteredBackProjectionAlgorithm::initialize(CFloat32ProjectionData2D *  	{  		clear();  	} -	 +  	// required classes  	m_pSinogram = _pSinogram;  	m_pReconstruction = _pReconstruction; @@ -326,7 +320,7 @@ void CCudaFilteredBackProjectionAlgorithm::run(int _iNrIterations /* = 0 */)  	const CVolumeGeometry2D& volgeom = *m_pReconstruction->getGeometry();  	ok &= m_pFBP->getReconstruction(m_pReconstruction->getData(), volgeom.getGridColCount()); -	 +  	ASTRA_ASSERT(ok);  } @@ -335,7 +329,7 @@ bool CCudaFilteredBackProjectionAlgorithm::check()  	// check pointers  	ASTRA_CONFIG_CHECK(m_pSinogram, "FBP_CUDA", "Invalid Projection Data Object.");  	ASTRA_CONFIG_CHECK(m_pReconstruction, "FBP_CUDA", "Invalid Reconstruction Data Object."); -	 +  	if((m_eFilter == FILTER_PROJECTION) || (m_eFilter == FILTER_SINOGRAM) || (m_eFilter == FILTER_RPROJECTION) || (m_eFilter == FILTER_RSINOGRAM))  	{  		ASTRA_CONFIG_CHECK(m_pfFilter, "FBP_CUDA", "Invalid filter pointer."); @@ -387,7 +381,7 @@ static bool stringCompareLowerCase(const char * _stringA, const char * _stringB)  #else  	iCmpReturn = strcasecmp(_stringA, _stringB);  #endif -	 +  	return (iCmpReturn == 0);  } @@ -485,7 +479,7 @@ E_FBPFILTER CCudaFilteredBackProjectionAlgorithm::_convertStringToFilter(const c  	}  	else  	{ -		cerr << "Failed to convert \"" << _filterType << "\" into a filter." << endl; +		ASTRA_ERROR("Failed to convert \"%s\" into a filter.",_filterType);  	}  	return output; diff --git a/src/CudaForwardProjectionAlgorithm.cpp b/src/CudaForwardProjectionAlgorithm.cpp index ab0d643..0f97d59 100644 --- a/src/CudaForwardProjectionAlgorithm.cpp +++ b/src/CudaForwardProjectionAlgorithm.cpp @@ -42,6 +42,8 @@ $Id$  #include "astra/FanFlatVecProjectionGeometry2D.h"  #include "astra/CudaProjector2D.h" +#include "astra/Logging.h" +  using namespace std;  namespace astra { @@ -71,42 +73,39 @@ bool CCudaForwardProjectionAlgorithm::initialize(const Config& _cfg)  	ConfigStackCheck<CAlgorithm> CC("CudaForwardProjectionAlgorithm", this, _cfg);  	// sinogram data -	XMLNode* node = _cfg.self->getSingleNode("ProjectionDataId"); +	XMLNode node = _cfg.self.getSingleNode("ProjectionDataId");  	ASTRA_CONFIG_CHECK(node, "FP_CUDA", "No ProjectionDataId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pSinogram = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectionDataId");  	// volume data -	node = _cfg.self->getSingleNode("VolumeDataId"); +	node = _cfg.self.getSingleNode("VolumeDataId");  	ASTRA_CONFIG_CHECK(node, "FP_CUDA", "No VolumeDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pVolume = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("VolumeDataId");  	// GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUIndex", m_iGPUIndex); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUIndex", m_iGPUIndex);  	CC.markOptionParsed("GPUindex"); -	if (!_cfg.self->hasOption("GPUindex")) +	if (!_cfg.self.hasOption("GPUindex"))  		CC.markOptionParsed("GPUIndex");  	// Detector supersampling factor -	m_iDetectorSuperSampling = (int)_cfg.self->getOptionNumerical("DetectorSuperSampling", 1); +	m_iDetectorSuperSampling = (int)_cfg.self.getOptionNumerical("DetectorSuperSampling", 1);  	CC.markOptionParsed("DetectorSuperSampling");  	// This isn't used yet, but passing it is not something to warn about -	node = _cfg.self->getSingleNode("ProjectorId"); +	node = _cfg.self.getSingleNode("ProjectorId");  	if (node) { -		id = boost::lexical_cast<int>(node->getContent()); +		id = boost::lexical_cast<int>(node.getContent());  		CProjector2D *projector = CProjector2DManager::getSingleton().get(id);  		if (!dynamic_cast<CCudaProjector2D*>(projector)) { -			cout << "Warning: non-CUDA Projector2D passed to FP_CUDA" << std::endl; +			ASTRA_WARN("non-CUDA Projector2D passed to FP_CUDA");  		} -		delete node;  	}  	CC.markNodeParsed("ProjectorId"); diff --git a/src/CudaForwardProjectionAlgorithm3D.cpp b/src/CudaForwardProjectionAlgorithm3D.cpp index bb122e0..e29b5a9 100644 --- a/src/CudaForwardProjectionAlgorithm3D.cpp +++ b/src/CudaForwardProjectionAlgorithm3D.cpp @@ -40,6 +40,8 @@ $Id$  #include "astra/ParallelVecProjectionGeometry3D.h"  #include "astra/ConeVecProjectionGeometry3D.h" +#include "astra/Logging.h" +  #include "../cuda/3d/astra3d.h"  using namespace std; @@ -76,40 +78,37 @@ bool CCudaForwardProjectionAlgorithm3D::initialize(const Config& _cfg)  	ASTRA_ASSERT(_cfg.self);  	ConfigStackCheck<CAlgorithm> CC("CudaForwardProjectionAlgorithm3D", this, _cfg);	 -	XMLNode* node; +	XMLNode node;  	int id;  	// sinogram data -	node = _cfg.self->getSingleNode("ProjectionDataId"); +	node = _cfg.self.getSingleNode("ProjectionDataId");  	ASTRA_CONFIG_CHECK(node, "CudaForwardProjection3D", "No ProjectionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pProjections = dynamic_cast<CFloat32ProjectionData3DMemory*>(CData3DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectionDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("VolumeDataId"); +	node = _cfg.self.getSingleNode("VolumeDataId");  	ASTRA_CONFIG_CHECK(node, "CudaForwardProjection3D", "No VolumeDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pVolume = dynamic_cast<CFloat32VolumeData3DMemory*>(CData3DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("VolumeDataId");  	// optional: projector -	node = _cfg.self->getSingleNode("ProjectorId"); +	node = _cfg.self.getSingleNode("ProjectorId");  	if (node) { -		id = boost::lexical_cast<int>(node->getContent()); +		id = boost::lexical_cast<int>(node.getContent());  		m_pProjector = CProjector3DManager::getSingleton().get(id); -		ASTRA_DELETE(node);  	} else {  		m_pProjector = 0; // TODO: or manually construct default projector?  	}  	CC.markNodeParsed("ProjectorId");  	// GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1);  	CC.markOptionParsed("GPUindex"); -	m_iDetectorSuperSampling = (int)_cfg.self->getOptionNumerical("DetectorSuperSampling", 1); +	m_iDetectorSuperSampling = (int)_cfg.self.getOptionNumerical("DetectorSuperSampling", 1);  	CC.markOptionParsed("DetectorSuperSampling");  	// success @@ -265,7 +264,7 @@ void CCudaForwardProjectionAlgorithm3D::run(int)  		for (int k = 0; k < 2; ++k) {  			float fU, fV;  			projgeom->projectPoint(fX[i], fY[j], fZ[k], a, fU, fV); -			fprintf(stderr, "%3d %c1,%c1,%c1 -> %12f %12f\n", a, i ? ' ' : '-', j ? ' ' : '-', k ? ' ' : '-', fU, fV); +			ASTRA_DEBUG("%3d %c1,%c1,%c1 -> %12f %12f", a, i ? ' ' : '-', j ? ' ' : '-', k ? ' ' : '-', fU, fV);  		}  	}  #endif diff --git a/src/CudaProjector2D.cpp b/src/CudaProjector2D.cpp index 056ea3b..fa024c8 100644 --- a/src/CudaProjector2D.cpp +++ b/src/CudaProjector2D.cpp @@ -104,10 +104,10 @@ bool CCudaProjector2D::initialize(const Config& _cfg)  	// TODO: Check the projection geometry is a supported type -	XMLNode* node = _cfg.self->getSingleNode("ProjectionKernel"); +	XMLNode node = _cfg.self.getSingleNode("ProjectionKernel");  	m_projectionKernel = ker2d_default;  	if (node) { -		std::string sProjKernel = node->getContent(); +		std::string sProjKernel = node.getContent();  		if (sProjKernel == "default") { @@ -115,7 +115,6 @@ bool CCudaProjector2D::initialize(const Config& _cfg)  			return false;  		}  	} -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectionKernel");  	m_bIsInitialized = _check(); diff --git a/src/CudaProjector3D.cpp b/src/CudaProjector3D.cpp index 2f4c799..41529a5 100644 --- a/src/CudaProjector3D.cpp +++ b/src/CudaProjector3D.cpp @@ -105,10 +105,10 @@ bool CCudaProjector3D::initialize(const Config& _cfg)  		return false;  	} -	XMLNode* node = _cfg.self->getSingleNode("ProjectionKernel"); +	XMLNode node = _cfg.self.getSingleNode("ProjectionKernel");  	m_projectionKernel = ker3d_default;  	if (node) { -		std::string sProjKernel = node->getContent(); +		std::string sProjKernel = node.getContent();  		if (sProjKernel == "default") { @@ -118,7 +118,6 @@ bool CCudaProjector3D::initialize(const Config& _cfg)  			return false;  		}  	} -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectionKernel");  	m_bIsInitialized = _check(); diff --git a/src/CudaReconstructionAlgorithm2D.cpp b/src/CudaReconstructionAlgorithm2D.cpp index d3dedc5..db99d42 100644 --- a/src/CudaReconstructionAlgorithm2D.cpp +++ b/src/CudaReconstructionAlgorithm2D.cpp @@ -37,6 +37,8 @@ $Id$  #include "astra/FanFlatVecProjectionGeometry2D.h"  #include "astra/CudaProjector2D.h" +#include "astra/Logging.h" +  #include "../cuda/2d/algo.h"  #include <ctime> @@ -94,91 +96,88 @@ bool CCudaReconstructionAlgorithm2D::initialize(const Config& _cfg)  	}  	// sinogram data -	XMLNode* node = _cfg.self->getSingleNode("ProjectionDataId"); +	XMLNode node = _cfg.self.getSingleNode("ProjectionDataId");  	ASTRA_CONFIG_CHECK(node, "CudaSirt2", "No ProjectionDataId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pSinogram = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectionDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("ReconstructionDataId"); +	node = _cfg.self.getSingleNode("ReconstructionDataId");  	ASTRA_CONFIG_CHECK(node, "CudaSirt2", "No ReconstructionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pReconstruction = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ReconstructionDataId");  	// fixed mask -	if (_cfg.self->hasOption("ReconstructionMaskId")) { +	if (_cfg.self.hasOption("ReconstructionMaskId")) {  		m_bUseReconstructionMask = true; -		id = boost::lexical_cast<int>(_cfg.self->getOption("ReconstructionMaskId")); +		id = boost::lexical_cast<int>(_cfg.self.getOption("ReconstructionMaskId"));  		m_pReconstructionMask = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id));  		ASTRA_CONFIG_CHECK(m_pReconstructionMask, "CudaReconstruction2D", "Invalid ReconstructionMaskId.");  	}  	CC.markOptionParsed("ReconstructionMaskId");  	// fixed mask -	if (_cfg.self->hasOption("SinogramMaskId")) { +	if (_cfg.self.hasOption("SinogramMaskId")) {  		m_bUseSinogramMask = true; -		id = boost::lexical_cast<int>(_cfg.self->getOption("SinogramMaskId")); +		id = boost::lexical_cast<int>(_cfg.self.getOption("SinogramMaskId"));  		m_pSinogramMask = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id));  		ASTRA_CONFIG_CHECK(m_pSinogramMask, "CudaReconstruction2D", "Invalid SinogramMaskId.");  	}  	CC.markOptionParsed("SinogramMaskId");  	// Constraints - NEW -	if (_cfg.self->hasOption("MinConstraint")) { +	if (_cfg.self.hasOption("MinConstraint")) {  		m_bUseMinConstraint = true; -		m_fMinValue = _cfg.self->getOptionNumerical("MinConstraint", 0.0f); +		m_fMinValue = _cfg.self.getOptionNumerical("MinConstraint", 0.0f);  		CC.markOptionParsed("MinConstraint");  	} else {  		// Constraint - OLD -		m_bUseMinConstraint = _cfg.self->getOptionBool("UseMinConstraint", false); +		m_bUseMinConstraint = _cfg.self.getOptionBool("UseMinConstraint", false);  		CC.markOptionParsed("UseMinConstraint");  		if (m_bUseMinConstraint) { -			m_fMinValue = _cfg.self->getOptionNumerical("MinConstraintValue", 0.0f); +			m_fMinValue = _cfg.self.getOptionNumerical("MinConstraintValue", 0.0f);  			CC.markOptionParsed("MinConstraintValue");  		}  	} -	if (_cfg.self->hasOption("MaxConstraint")) { +	if (_cfg.self.hasOption("MaxConstraint")) {  		m_bUseMaxConstraint = true; -		m_fMaxValue = _cfg.self->getOptionNumerical("MaxConstraint", 255.0f); +		m_fMaxValue = _cfg.self.getOptionNumerical("MaxConstraint", 255.0f);  		CC.markOptionParsed("MaxConstraint");  	} else {  		// Constraint - OLD -		m_bUseMaxConstraint = _cfg.self->getOptionBool("UseMaxConstraint", false); +		m_bUseMaxConstraint = _cfg.self.getOptionBool("UseMaxConstraint", false);  		CC.markOptionParsed("UseMaxConstraint");  		if (m_bUseMaxConstraint) { -			m_fMaxValue = _cfg.self->getOptionNumerical("MaxConstraintValue", 0.0f); +			m_fMaxValue = _cfg.self.getOptionNumerical("MaxConstraintValue", 0.0f);  			CC.markOptionParsed("MaxConstraintValue");  		}  	}  	// GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUIndex", m_iGPUIndex); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUIndex", m_iGPUIndex);  	CC.markOptionParsed("GPUindex"); -	if (!_cfg.self->hasOption("GPUindex")) +	if (!_cfg.self.hasOption("GPUindex"))  		CC.markOptionParsed("GPUIndex");  	// Detector supersampling factor -	m_iDetectorSuperSampling = (int)_cfg.self->getOptionNumerical("DetectorSuperSampling", 1); +	m_iDetectorSuperSampling = (int)_cfg.self.getOptionNumerical("DetectorSuperSampling", 1);  	CC.markOptionParsed("DetectorSuperSampling");  	// Pixel supersampling factor -	m_iPixelSuperSampling = (int)_cfg.self->getOptionNumerical("PixelSuperSampling", 1); +	m_iPixelSuperSampling = (int)_cfg.self.getOptionNumerical("PixelSuperSampling", 1);  	CC.markOptionParsed("PixelSuperSampling");  	// This isn't used yet, but passing it is not something to warn about -	node = _cfg.self->getSingleNode("ProjectorId"); +	node = _cfg.self.getSingleNode("ProjectorId");  	if (node) { -		id = boost::lexical_cast<int>(node->getContent()); +		id = boost::lexical_cast<int>(node.getContent());  		CProjector2D *projector = CProjector2DManager::getSingleton().get(id);  		if (!dynamic_cast<CCudaProjector2D*>(projector)) { -			cout << "Warning: non-CUDA Projector2D passed" << std::endl; +			ASTRA_WARN("non-CUDA Projector2D passed");  		} -		delete node;  	}  	CC.markNodeParsed("ProjectorId"); diff --git a/src/CudaRoiSelectAlgorithm.cpp b/src/CudaRoiSelectAlgorithm.cpp index bfccb3a..7635c69 100644 --- a/src/CudaRoiSelectAlgorithm.cpp +++ b/src/CudaRoiSelectAlgorithm.cpp @@ -66,22 +66,21 @@ bool CCudaRoiSelectAlgorithm::initialize(const Config& _cfg)  	ConfigStackCheck<CAlgorithm> CC("CudaDartMaskAlgorithm", this, _cfg);  	// reconstruction data -	XMLNode* node = _cfg.self->getSingleNode("DataId"); +	XMLNode node = _cfg.self.getSingleNode("DataId");  	ASTRA_CONFIG_CHECK(node, "CudaRoiSelect", "No DataId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pData = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("DataId");  	// Option: GPU number -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUIndex", m_iGPUIndex); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUIndex", m_iGPUIndex);  	CC.markOptionParsed("GPUindex"); -	if (!_cfg.self->hasOption("GPUindex")) +	if (!_cfg.self.hasOption("GPUindex"))  		CC.markOptionParsed("GPUIndex");  	// Option: Radius -	m_fRadius = (unsigned int)_cfg.self->getOptionNumerical("Radius", 0.0f); +	m_fRadius = (unsigned int)_cfg.self.getOptionNumerical("Radius", 0.0f);  	CC.markOptionParsed("Radius");  	_check(); diff --git a/src/CudaSartAlgorithm.cpp b/src/CudaSartAlgorithm.cpp index 8e22c59..8c0c6d7 100644 --- a/src/CudaSartAlgorithm.cpp +++ b/src/CudaSartAlgorithm.cpp @@ -74,7 +74,7 @@ bool CCudaSartAlgorithm::initialize(const Config& _cfg)  	// projection order  	int projectionCount = m_pSinogram->getGeometry()->getProjectionAngleCount();  	int* projectionOrder = NULL; -	string projOrder = _cfg.self->getOption("ProjectionOrder", "random"); +	string projOrder = _cfg.self.getOption("ProjectionOrder", "random");  	CC.markOptionParsed("ProjectionOrder");  	if (projOrder == "sequential") {  		projectionOrder = new int[projectionCount]; @@ -97,7 +97,7 @@ bool CCudaSartAlgorithm::initialize(const Config& _cfg)  		sart->setProjectionOrder(projectionOrder, projectionCount);  		delete[] projectionOrder;  	} else if (projOrder == "custom") { -		vector<float32> projOrderList = _cfg.self->getOptionNumericalArray("ProjectionOrderList"); +		vector<float32> projOrderList = _cfg.self.getOptionNumericalArray("ProjectionOrderList");  		projectionOrder = new int[projOrderList.size()];  		for (int i = 0; i < projOrderList.size(); i++) {  			projectionOrder[i] = static_cast<int>(projOrderList[i]); diff --git a/src/CudaSirtAlgorithm.cpp b/src/CudaSirtAlgorithm.cpp index f6eb79a..d424915 100644 --- a/src/CudaSirtAlgorithm.cpp +++ b/src/CudaSirtAlgorithm.cpp @@ -76,13 +76,13 @@ bool CCudaSirtAlgorithm::initialize(const Config& _cfg)  		return false;  	// min/max masks -	if (_cfg.self->hasOption("MinMaskId")) { -		int id = boost::lexical_cast<int>(_cfg.self->getOption("MinMaskId")); +	if (_cfg.self.hasOption("MinMaskId")) { +		int id = boost::lexical_cast<int>(_cfg.self.getOption("MinMaskId"));  		m_pMinMask = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id));  	}  	CC.markOptionParsed("MinMaskId"); -	if (_cfg.self->hasOption("MaxMaskId")) { -		int id = boost::lexical_cast<int>(_cfg.self->getOption("MaxMaskId")); +	if (_cfg.self.hasOption("MaxMaskId")) { +		int id = boost::lexical_cast<int>(_cfg.self.getOption("MaxMaskId"));  		m_pMaxMask = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id));  	}  	CC.markOptionParsed("MaxMaskId"); diff --git a/src/CudaSirtAlgorithm3D.cpp b/src/CudaSirtAlgorithm3D.cpp index da83c7e..5ad131b 100644 --- a/src/CudaSirtAlgorithm3D.cpp +++ b/src/CudaSirtAlgorithm3D.cpp @@ -107,11 +107,11 @@ bool CCudaSirtAlgorithm3D::initialize(const Config& _cfg)  		return false;  	} -	m_iGPUIndex = (int)_cfg.self->getOptionNumerical("GPUindex", -1); +	m_iGPUIndex = (int)_cfg.self.getOptionNumerical("GPUindex", -1);  	CC.markOptionParsed("GPUindex"); -	m_iDetectorSuperSampling = (int)_cfg.self->getOptionNumerical("DetectorSuperSampling", 1); +	m_iDetectorSuperSampling = (int)_cfg.self.getOptionNumerical("DetectorSuperSampling", 1);  	CC.markOptionParsed("DetectorSuperSampling"); -	m_iVoxelSuperSampling = (int)_cfg.self->getOptionNumerical("VoxelSuperSampling", 1); +	m_iVoxelSuperSampling = (int)_cfg.self.getOptionNumerical("VoxelSuperSampling", 1);  	CC.markOptionParsed("VoxelSuperSampling");  	m_pSirt = new AstraSIRT3d(); diff --git a/src/FanFlatProjectionGeometry2D.cpp b/src/FanFlatProjectionGeometry2D.cpp index 9851d40..91b9578 100644 --- a/src/FanFlatProjectionGeometry2D.cpp +++ b/src/FanFlatProjectionGeometry2D.cpp @@ -134,17 +134,15 @@ bool CFanFlatProjectionGeometry2D::initialize(const Config& _cfg)  	CProjectionGeometry2D::initialize(_cfg);  	// Required: DistanceOriginDetector -	XMLNode* node = _cfg.self->getSingleNode("DistanceOriginDetector"); +	XMLNode node = _cfg.self.getSingleNode("DistanceOriginDetector");  	ASTRA_CONFIG_CHECK(node, "FanFlatProjectionGeometry2D", "No DistanceOriginDetector tag specified."); -	m_fOriginDetectorDistance = boost::lexical_cast<float32>(node->getContent()); -	ASTRA_DELETE(node); +	m_fOriginDetectorDistance = boost::lexical_cast<float32>(node.getContent());  	CC.markNodeParsed("DistanceOriginDetector");  	// Required: DetectorOriginSource -	node = _cfg.self->getSingleNode("DistanceOriginSource"); +	node = _cfg.self.getSingleNode("DistanceOriginSource");  	ASTRA_CONFIG_CHECK(node, "FanFlatProjectionGeometry2D", "No DistanceOriginSource tag specified."); -	m_fOriginSourceDistance = boost::lexical_cast<float32>(node->getContent()); -	ASTRA_DELETE(node); +	m_fOriginSourceDistance = boost::lexical_cast<float32>(node.getContent());  	CC.markNodeParsed("DistanceOriginSource");  	// success @@ -209,12 +207,12 @@ Config* CFanFlatProjectionGeometry2D::getConfiguration() const  {  	Config* cfg = new Config();  	cfg->initialize("ProjectionGeometry2D"); -	cfg->self->addAttribute("type", "fanflat"); -	cfg->self->addChildNode("DetectorCount", getDetectorCount()); -	cfg->self->addChildNode("DetectorWidth", getDetectorWidth()); -	cfg->self->addChildNode("DistanceOriginSource", getOriginSourceDistance()); -	cfg->self->addChildNode("DistanceOriginDetector", getOriginDetectorDistance()); -	cfg->self->addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount); +	cfg->self.addAttribute("type", "fanflat"); +	cfg->self.addChildNode("DetectorCount", getDetectorCount()); +	cfg->self.addChildNode("DetectorWidth", getDetectorWidth()); +	cfg->self.addChildNode("DistanceOriginSource", getOriginSourceDistance()); +	cfg->self.addChildNode("DistanceOriginDetector", getOriginDetectorDistance()); +	cfg->self.addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount);  	return cfg;  } diff --git a/src/FanFlatVecProjectionGeometry2D.cpp b/src/FanFlatVecProjectionGeometry2D.cpp index 9c7b596..4104379 100644 --- a/src/FanFlatVecProjectionGeometry2D.cpp +++ b/src/FanFlatVecProjectionGeometry2D.cpp @@ -116,25 +116,23 @@ bool CFanFlatVecProjectionGeometry2D::initialize(const Config& _cfg)  	ASTRA_ASSERT(_cfg.self);  	ConfigStackCheck<CProjectionGeometry2D> CC("FanFlatVecProjectionGeometry2D", this, _cfg);	 -	XMLNode* node; +	XMLNode node;  	// TODO: Fix up class hierarchy... this class doesn't fit very well.  	// initialization of parent class  	//CProjectionGeometry2D::initialize(_cfg);  	// Required: DetectorCount -	node = _cfg.self->getSingleNode("DetectorCount"); +	node = _cfg.self.getSingleNode("DetectorCount");  	ASTRA_CONFIG_CHECK(node, "FanFlatVecProjectionGeometry3D", "No DetectorRowCount tag specified."); -	m_iDetectorCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iDetectorCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("DetectorCount");  	// Required: Vectors -	node = _cfg.self->getSingleNode("Vectors"); +	node = _cfg.self.getSingleNode("Vectors");  	ASTRA_CONFIG_CHECK(node, "FanFlatVecProjectionGeometry3D", "No Vectors tag specified."); -	vector<float32> data = node->getContentNumericalArray(); +	vector<float32> data = node.getContentNumericalArray();  	CC.markNodeParsed("Vectors"); -	ASTRA_DELETE(node);  	ASTRA_CONFIG_CHECK(data.size() % 6 == 0, "FanFlatVecProjectionGeometry3D", "Vectors doesn't consist of 6-tuples.");  	m_iProjectionAngleCount = data.size() / 6;  	m_pProjectionAngles = new SFanProjection[m_iProjectionAngleCount]; @@ -232,8 +230,8 @@ Config* CFanFlatVecProjectionGeometry2D::getConfiguration() const  {  	Config* cfg = new Config();  	cfg->initialize("ProjectionGeometry2D"); -	cfg->self->addAttribute("type", "fanflat_vec"); -	cfg->self->addChildNode("DetectorCount", getDetectorCount()); +	cfg->self.addAttribute("type", "fanflat_vec"); +	cfg->self.addChildNode("DetectorCount", getDetectorCount());  	std::string vectors = "";  	for (int i = 0; i < m_iProjectionAngleCount; ++i) {  		SFanProjection& p = m_pProjectionAngles[i]; @@ -245,7 +243,7 @@ Config* CFanFlatVecProjectionGeometry2D::getConfiguration() const  		vectors += boost::lexical_cast<string>(p.fDetUY);  		if (i < m_iProjectionAngleCount-1) vectors += ';';  	} -	cfg->self->addChildNode("Vectors", vectors); +	cfg->self.addChildNode("Vectors", vectors);  	return cfg;  }  //---------------------------------------------------------------------------------------- diff --git a/src/FilteredBackProjectionAlgorithm.cpp b/src/FilteredBackProjectionAlgorithm.cpp index 50cf939..f494d22 100644 --- a/src/FilteredBackProjectionAlgorithm.cpp +++ b/src/FilteredBackProjectionAlgorithm.cpp @@ -39,6 +39,8 @@ $Id$  #include "astra/Fourier.h"  #include "astra/DataProjector.h" +#include "astra/Logging.h" +  using namespace std;  namespace astra { @@ -92,30 +94,27 @@ bool CFilteredBackProjectionAlgorithm::initialize(const Config& _cfg)  	ASTRA_ASSERT(_cfg.self);  	// projector -	XMLNode* node = _cfg.self->getSingleNode("ProjectorId"); +	XMLNode node = _cfg.self.getSingleNode("ProjectorId");  	ASTRA_CONFIG_CHECK(node, "FilteredBackProjection", "No ProjectorId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pProjector = CProjector2DManager::getSingleton().get(id); -	ASTRA_DELETE(node);  	// sinogram data -	node = _cfg.self->getSingleNode("ProjectionDataId"); +	node = _cfg.self.getSingleNode("ProjectionDataId");  	ASTRA_CONFIG_CHECK(node, "FilteredBackProjection", "No ProjectionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pSinogram = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	// volume data -	node = _cfg.self->getSingleNode("ReconstructionDataId"); +	node = _cfg.self.getSingleNode("ReconstructionDataId");  	ASTRA_CONFIG_CHECK(node, "FilteredBackProjection", "No ReconstructionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pReconstruction = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node); -	node = _cfg.self->getSingleNode("ProjectionIndex"); +	node = _cfg.self.getSingleNode("ProjectionIndex");  	if (node)   	{ -		vector<float32> projectionIndex = node->getContentNumericalArray(); +		vector<float32> projectionIndex = node.getContentNumericalArray();  		int angleCount = projectionIndex.size();  		int detectorCount = m_pProjector->getProjectionGeometry()->getDetectorCount(); @@ -133,7 +132,7 @@ bool CFilteredBackProjectionAlgorithm::initialize(const Config& _cfg)  		for (int i = 0; i < angleCount; i ++) {  			if (projectionIndex[i] > m_pProjector->getProjectionGeometry()->getProjectionAngleCount() -1 )  			{ -				cout << "Invalid Projection Index" << endl; +				ASTRA_ERROR("Invalid Projection Index");  				return false;  			} else {  				int orgIndex = (int)projectionIndex[i]; @@ -152,7 +151,6 @@ bool CFilteredBackProjectionAlgorithm::initialize(const Config& _cfg)  		m_pProjector = new CParallelBeamLineKernelProjector2D(pg,m_pReconstruction->getGeometry());  		m_pSinogram = new CFloat32ProjectionData2D(pg, sinogramData2D);  	} -	ASTRA_DELETE(node);  	// TODO: check that the angles are linearly spaced between 0 and pi diff --git a/src/Float32ProjectionData2D.cpp b/src/Float32ProjectionData2D.cpp index 85e0cdd..f7f83e3 100644 --- a/src/Float32ProjectionData2D.cpp +++ b/src/Float32ProjectionData2D.cpp @@ -75,6 +75,16 @@ CFloat32ProjectionData2D::CFloat32ProjectionData2D(const CFloat32ProjectionData2  	m_bInitialized = true;  } +//---------------------------------------------------------------------------------------- +// Create an instance of the CFloat32ProjectionData2D class with pre-allocated data +CFloat32ProjectionData2D::CFloat32ProjectionData2D(CProjectionGeometry2D* _pGeometry, CFloat32CustomMemory* _pCustomMemory) +{ +	m_bInitialized = false; +	m_bInitialized = initialize(_pGeometry, _pCustomMemory); +} +  + +  // Assignment operator  CFloat32ProjectionData2D& CFloat32ProjectionData2D::operator=(const CFloat32ProjectionData2D& _other) @@ -119,6 +129,15 @@ bool CFloat32ProjectionData2D::initialize(CProjectionGeometry2D* _pGeometry, flo  }  //---------------------------------------------------------------------------------------- +// Initialization +bool CFloat32ProjectionData2D::initialize(CProjectionGeometry2D* _pGeometry, CFloat32CustomMemory* _pCustomMemory)  +{ +	m_pGeometry = _pGeometry->clone(); +	m_bInitialized = _initialize(m_pGeometry->getDetectorCount(), m_pGeometry->getProjectionAngleCount(), _pCustomMemory); +	return m_bInitialized; +} + +//----------------------------------------------------------------------------------------  // Destructor  CFloat32ProjectionData2D::~CFloat32ProjectionData2D()   { diff --git a/src/Float32ProjectionData3D.cpp b/src/Float32ProjectionData3D.cpp index d039c83..2bd0447 100644 --- a/src/Float32ProjectionData3D.cpp +++ b/src/Float32ProjectionData3D.cpp @@ -270,4 +270,13 @@ CFloat32ProjectionData3D& CFloat32ProjectionData3D::operator-=(const float32& _f  	return *this;  } +void CFloat32ProjectionData3D::changeGeometry(CProjectionGeometry3D* _pGeometry) +{ +	if (!m_bInitialized) return; + +	delete m_pGeometry; +	m_pGeometry = _pGeometry->clone(); +} + +  } // end namespace astra diff --git a/src/Float32VolumeData2D.cpp b/src/Float32VolumeData2D.cpp index e11c4e4..c903c66 100644 --- a/src/Float32VolumeData2D.cpp +++ b/src/Float32VolumeData2D.cpp @@ -72,6 +72,15 @@ CFloat32VolumeData2D::CFloat32VolumeData2D(const CFloat32VolumeData2D& _other) :  	m_bInitialized = true;  } +//---------------------------------------------------------------------------------------- +// Create an instance of the CFloat32VolumeData2D class with pre-allocated data +CFloat32VolumeData2D::CFloat32VolumeData2D(CVolumeGeometry2D* _pGeometry, CFloat32CustomMemory* _pCustomMemory) +{ +	m_bInitialized = false; +	m_bInitialized = initialize(_pGeometry, _pCustomMemory); +} + +  // Assignment operator  CFloat32VolumeData2D& CFloat32VolumeData2D::operator=(const CFloat32VolumeData2D& _other) @@ -122,6 +131,17 @@ bool CFloat32VolumeData2D::initialize(CVolumeGeometry2D* _pGeometry, float32 _fS  	m_bInitialized = _initialize(m_pGeometry->getGridColCount(), m_pGeometry->getGridRowCount(), _fScalar);  	return m_bInitialized;  } + +//---------------------------------------------------------------------------------------- +// Initialization +bool CFloat32VolumeData2D::initialize(CVolumeGeometry2D* _pGeometry, CFloat32CustomMemory* _pCustomMemory)  +{ +	m_pGeometry = _pGeometry->clone(); +	m_bInitialized = _initialize(m_pGeometry->getGridColCount(), m_pGeometry->getGridRowCount(), _pCustomMemory); +	return m_bInitialized; +} + +  //----------------------------------------------------------------------------------------  void CFloat32VolumeData2D::changeGeometry(CVolumeGeometry2D* _pGeometry)  { diff --git a/src/Float32VolumeData3D.cpp b/src/Float32VolumeData3D.cpp index ce00a10..bd78001 100644 --- a/src/Float32VolumeData3D.cpp +++ b/src/Float32VolumeData3D.cpp @@ -266,4 +266,13 @@ CFloat32VolumeData3D& CFloat32VolumeData3D::operator-=(const float32& _fScalar)  	return *this;  } +void CFloat32VolumeData3D::changeGeometry(CVolumeGeometry3D* _pGeometry) +{ +	if (!m_bInitialized) return; + +	delete m_pGeometry; +	m_pGeometry = _pGeometry->clone(); +} + +  } // end namespace astra diff --git a/src/ForwardProjectionAlgorithm.cpp b/src/ForwardProjectionAlgorithm.cpp index b530491..f356824 100644 --- a/src/ForwardProjectionAlgorithm.cpp +++ b/src/ForwardProjectionAlgorithm.cpp @@ -126,37 +126,34 @@ bool CForwardProjectionAlgorithm::initialize(const Config& _cfg)  	}  	// projector -	XMLNode* node = _cfg.self->getSingleNode("ProjectorId"); +	XMLNode node = _cfg.self.getSingleNode("ProjectorId");  	ASTRA_CONFIG_CHECK(node, "ForwardProjection", "No ProjectorId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pProjector = CProjector2DManager::getSingleton().get(id); -	ASTRA_DELETE(node);  	// sinogram data -	node = _cfg.self->getSingleNode("ProjectionDataId"); +	node = _cfg.self.getSingleNode("ProjectionDataId");  	ASTRA_CONFIG_CHECK(node, "ForwardProjection", "No ProjectionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pSinogram = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	// volume data -	node = _cfg.self->getSingleNode("VolumeDataId"); +	node = _cfg.self.getSingleNode("VolumeDataId");  	ASTRA_CONFIG_CHECK(node, "ForwardProjection", "No VolumeDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pVolume = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	// volume mask -	if (_cfg.self->hasOption("VolumeMaskId")) { +	if (_cfg.self.hasOption("VolumeMaskId")) {  		m_bUseVolumeMask = true; -		id = boost::lexical_cast<int>(_cfg.self->getOption("VolumeMaskId")); +		id = boost::lexical_cast<int>(_cfg.self.getOption("VolumeMaskId"));  		m_pVolumeMask = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id));  	}  	// sino mask -	if (_cfg.self->hasOption("SinogramMaskId")) { +	if (_cfg.self.hasOption("SinogramMaskId")) {  		m_bUseSinogramMask = true; -		id = boost::lexical_cast<int>(_cfg.self->getOption("SinogramMaskId")); +		id = boost::lexical_cast<int>(_cfg.self.getOption("SinogramMaskId"));  		m_pSinogramMask = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id));  	} diff --git a/src/Logger.cpp b/src/Logger.cpp deleted file mode 100644 index 148e18c..0000000 --- a/src/Logger.cpp +++ /dev/null @@ -1,77 +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 <astra/Logger.h> - -using namespace astra; - -const char * g_loggerFileName = "astra_logger.txt"; - -void CLogger::_assureIsInitialized() -{ -	if(!m_bInitialized) -	{ -		m_pOutFile = fopen(g_loggerFileName, "r"); -		if(m_pOutFile != NULL) -		{ -			// file exists, users wants to log -			fclose(m_pOutFile); -			m_pOutFile = fopen(g_loggerFileName, "w"); -		} - -		m_bInitialized = true; -	} -} - -void CLogger::writeLine(const char * _text) -{ -	_assureIsInitialized(); - -	if(m_pOutFile != NULL) -	{ -		fprintf(m_pOutFile, "%s\n", _text); -		fflush(m_pOutFile); -	} -} - -void CLogger::writeTerminalCUDAError(const char * _fileName, int _iLine, const char * _errString) -{ -	char buffer[256]; - -	sprintf(buffer, "Cuda error in file '%s' in line %i : %s.", _fileName, _iLine, _errString); - -	writeLine(buffer); -} - -CLogger::CLogger() -{ -	; -} - -FILE * CLogger::m_pOutFile = NULL; -bool CLogger::m_bInitialized = false; diff --git a/src/Logging.cpp b/src/Logging.cpp new file mode 100644 index 0000000..8290ca0 --- /dev/null +++ b/src/Logging.cpp @@ -0,0 +1,184 @@ +/* +----------------------------------------------------------------------- +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$ +*/ + +#define CLOG_MAIN +#include <astra/clog.h> + +#include <astra/Logging.h> + +#include <cstdio> + +using namespace astra; + +void CLogger::enableScreen() +{ +	m_bEnabledScreen = true; +} + +void CLogger::enableFile() +{ +	m_bEnabledFile = true; +} + +void CLogger::enable() +{ +	enableScreen(); +	enableFile(); +} + +void CLogger::disableScreen() +{ +	m_bEnabledScreen = false; +} + +void CLogger::disableFile() +{ +	m_bEnabledFile = false; +} + +void CLogger::disable() +{ +	disableScreen(); +	disableFile(); +} + +void CLogger::debug(const char *sfile, int sline, const char *fmt, ...) +{ +	_assureIsInitialized(); +	va_list ap; +	va_start(ap, fmt); +	if(m_bEnabledScreen) clog_debug(sfile,sline,0,fmt,ap); +	if(m_bEnabledFile && m_bFileProvided) clog_debug(sfile,sline,1,fmt,ap); +} + +void CLogger::info(const char *sfile, int sline, const char *fmt, ...) +{ +	_assureIsInitialized(); +	va_list ap; +	va_start(ap, fmt); +	if(m_bEnabledScreen) clog_info(sfile,sline,0,fmt,ap); +	if(m_bEnabledFile && m_bFileProvided) clog_info(sfile,sline,1,fmt,ap); +} + +void CLogger::warn(const char *sfile, int sline, const char *fmt, ...) +{ +	_assureIsInitialized(); +	va_list ap; +	va_start(ap, fmt); +	if(m_bEnabledScreen) clog_warn(sfile,sline,0,fmt,ap); +	if(m_bEnabledFile && m_bFileProvided) clog_warn(sfile,sline,1,fmt,ap); +} + +void CLogger::error(const char *sfile, int sline, const char *fmt, ...) +{ +	_assureIsInitialized(); +	va_list ap; +	va_start(ap, fmt); +	if(m_bEnabledScreen) clog_error(sfile,sline,0,fmt,ap); +	if(m_bEnabledFile && m_bFileProvided) clog_error(sfile,sline,1,fmt,ap); +} + +void CLogger::_setLevel(int id, log_level m_eLevel) +{ +	switch(m_eLevel){ +		case LOG_DEBUG: +			clog_set_level(id,CLOG_DEBUG); +			break; +		case LOG_INFO: +			clog_set_level(id,CLOG_INFO); +			break; +		case LOG_WARN: +			clog_set_level(id,CLOG_WARN); +			break; +		case LOG_ERROR: +			clog_set_level(id,CLOG_ERROR); +			break; +	} +} + +void CLogger::setOutputScreen(int fd, log_level m_eLevel) +{ +	_assureIsInitialized(); +	if(fd==1||fd==2){ +		clog_set_fd(0, fd); +	}else{ +		error(__FILE__,__LINE__,"Invalid file descriptor"); +	} +	_setLevel(0,m_eLevel); +} + +void CLogger::setOutputFile(const char *filename, log_level m_eLevel) +{ +	if(m_bFileProvided){ +		clog_free(1); +		m_bFileProvided=false; +	} +	if(!clog_init_path(1,filename)){ +		m_bFileProvided=true; +		_setLevel(1,m_eLevel); +	} +} + +void CLogger::_assureIsInitialized() +{ +	if(!m_bInitialized) +	{ +		clog_init_fd(0, 2); +		clog_set_level(0, CLOG_INFO); +		clog_set_fmt(0, "%l: %m\n"); +		m_bInitialized = true; +	} +} + +void CLogger::setFormatFile(const char *fmt) +{ +	if(m_bFileProvided){ +		clog_set_fmt(1,fmt); +	}else{ +		error(__FILE__,__LINE__,"No log file specified"); +	} +} +void CLogger::setFormatScreen(const char *fmt) +{ +	clog_set_fmt(0,fmt); +} + +CLogger::CLogger() +{ +	; +} + +bool CLogger::setCallbackScreen(void (*cb)(const char *msg, size_t len)){ +	_assureIsInitialized(); +	return clog_set_cb(0,cb)==0; +} + +bool CLogger::m_bEnabledScreen = true; +bool CLogger::m_bEnabledFile = true; +bool CLogger::m_bFileProvided = false; +bool CLogger::m_bInitialized = false; diff --git a/src/ParallelBeamBlobKernelProjector2D.cpp b/src/ParallelBeamBlobKernelProjector2D.cpp index d030576..1e6312f 100644 --- a/src/ParallelBeamBlobKernelProjector2D.cpp +++ b/src/ParallelBeamBlobKernelProjector2D.cpp @@ -128,34 +128,33 @@ bool CParallelBeamBlobKernelProjector2D::initialize(const Config& _cfg)  	}  	// required: Kernel -	XMLNode* node = _cfg.self->getSingleNode("Kernel"); +	XMLNode node = _cfg.self.getSingleNode("Kernel");  	ASTRA_CONFIG_CHECK(node, "BlobProjector", "No Kernel tag specified.");  	{  		// Required: KernelSize -		XMLNode* node2 = node->getSingleNode("KernelSize"); +		XMLNode node2 = node.getSingleNode("KernelSize");  		ASTRA_CONFIG_CHECK(node2, "BlobProjector", "No Kernel/KernelSize tag specified."); -		m_fBlobSize = boost::lexical_cast<float32>(node2->getContent()); +		m_fBlobSize = boost::lexical_cast<float32>(node2.getContent());  		// Required: SampleRate -		node2 = node->getSingleNode("SampleRate"); +		node2 = node.getSingleNode("SampleRate");  		ASTRA_CONFIG_CHECK(node2, "BlobProjector", "No Kernel/SampleRate tag specified."); -		m_fBlobSampleRate = boost::lexical_cast<float32>(node2->getContent()); +		m_fBlobSampleRate = boost::lexical_cast<float32>(node2.getContent());  		// Required: SampleCount -		node2 = node->getSingleNode("SampleCount"); +		node2 = node.getSingleNode("SampleCount");  		ASTRA_CONFIG_CHECK(node2, "BlobProjector", "No Kernel/SampleCount tag specified."); -		m_iBlobSampleCount = boost::lexical_cast<int>(node2->getContent()); +		m_iBlobSampleCount = boost::lexical_cast<int>(node2.getContent());  		// Required: KernelValues -		node2 = node->getSingleNode("KernelValues"); +		node2 = node.getSingleNode("KernelValues");  		ASTRA_CONFIG_CHECK(node2, "BlobProjector", "No Kernel/KernelValues tag specified."); -		vector<float32> values = node2->getContentNumericalArray(); +		vector<float32> values = node2.getContentNumericalArray();  		ASTRA_CONFIG_CHECK(values.size() == (unsigned int)m_iBlobSampleCount, "BlobProjector", "Number of specified values doesn't match SampleCount.");  		m_pfBlobValues = new float32[m_iBlobSampleCount];  		for (int i = 0; i < m_iBlobSampleCount; i++) {  			m_pfBlobValues[i] = values[i];  		} -  	}  	// success diff --git a/src/ParallelProjectionGeometry2D.cpp b/src/ParallelProjectionGeometry2D.cpp index 42ed0a0..8632b17 100644 --- a/src/ParallelProjectionGeometry2D.cpp +++ b/src/ParallelProjectionGeometry2D.cpp @@ -175,10 +175,10 @@ Config* CParallelProjectionGeometry2D::getConfiguration() const  {  	Config* cfg = new Config();  	cfg->initialize("ProjectionGeometry2D"); -	cfg->self->addAttribute("type", "parallel"); -	cfg->self->addChildNode("DetectorCount", getDetectorCount()); -	cfg->self->addChildNode("DetectorWidth", getDetectorWidth()); -	cfg->self->addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount); +	cfg->self.addAttribute("type", "parallel"); +	cfg->self.addChildNode("DetectorCount", getDetectorCount()); +	cfg->self.addChildNode("DetectorWidth", getDetectorWidth()); +	cfg->self.addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount);  	return cfg;  } diff --git a/src/ParallelProjectionGeometry3D.cpp b/src/ParallelProjectionGeometry3D.cpp index eb200f9..1c87157 100644 --- a/src/ParallelProjectionGeometry3D.cpp +++ b/src/ParallelProjectionGeometry3D.cpp @@ -164,12 +164,12 @@ Config* CParallelProjectionGeometry3D::getConfiguration() const  {  	Config* cfg = new Config();  	cfg->initialize("ProjectionGeometry3D"); -	cfg->self->addAttribute("type", "parallel3d"); -	cfg->self->addChildNode("DetectorRowCount", m_iDetectorRowCount); -	cfg->self->addChildNode("DetectorColCount", m_iDetectorColCount); -	cfg->self->addChildNode("DetectorSpacingX", m_fDetectorSpacingX); -	cfg->self->addChildNode("DetectorSpacingY", m_fDetectorSpacingY); -	cfg->self->addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount); +	cfg->self.addAttribute("type", "parallel3d"); +	cfg->self.addChildNode("DetectorRowCount", m_iDetectorRowCount); +	cfg->self.addChildNode("DetectorColCount", m_iDetectorColCount); +	cfg->self.addChildNode("DetectorSpacingX", m_fDetectorSpacingX); +	cfg->self.addChildNode("DetectorSpacingY", m_fDetectorSpacingY); +	cfg->self.addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount);  	return cfg;  }  //---------------------------------------------------------------------------------------- diff --git a/src/ParallelVecProjectionGeometry3D.cpp b/src/ParallelVecProjectionGeometry3D.cpp index dc325e9..ffad6d0 100644 --- a/src/ParallelVecProjectionGeometry3D.cpp +++ b/src/ParallelVecProjectionGeometry3D.cpp @@ -73,33 +73,30 @@ bool CParallelVecProjectionGeometry3D::initialize(const Config& _cfg)  	ASTRA_ASSERT(_cfg.self);  	ConfigStackCheck<CProjectionGeometry3D> CC("ParallelVecProjectionGeometry3D", this, _cfg);	 -	XMLNode* node; +	XMLNode node;  	// TODO: Fix up class hierarchy... this class doesn't fit very well.  	// initialization of parent class  	//CProjectionGeometry3D::initialize(_cfg);  	// Required: DetectorRowCount -	node = _cfg.self->getSingleNode("DetectorRowCount"); +	node = _cfg.self.getSingleNode("DetectorRowCount");  	ASTRA_CONFIG_CHECK(node, "ParallelVecProjectionGeometry3D", "No DetectorRowCount tag specified."); -	m_iDetectorRowCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iDetectorRowCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("DetectorRowCount");  	// Required: DetectorCount -	node = _cfg.self->getSingleNode("DetectorColCount"); +	node = _cfg.self.getSingleNode("DetectorColCount");  	ASTRA_CONFIG_CHECK(node, "", "No DetectorColCount tag specified."); -	m_iDetectorColCount = boost::lexical_cast<int>(node->getContent()); +	m_iDetectorColCount = boost::lexical_cast<int>(node.getContent());  	m_iDetectorTotCount = m_iDetectorRowCount * m_iDetectorColCount; -	ASTRA_DELETE(node);  	CC.markNodeParsed("DetectorColCount");  	// Required: Vectors -	node = _cfg.self->getSingleNode("Vectors"); +	node = _cfg.self.getSingleNode("Vectors");  	ASTRA_CONFIG_CHECK(node, "ParallelVecProjectionGeometry3D", "No Vectors tag specified."); -	vector<double> data = node->getContentNumericalArrayDouble(); +	vector<double> data = node.getContentNumericalArrayDouble();  	CC.markNodeParsed("Vectors"); -	ASTRA_DELETE(node);  	ASTRA_CONFIG_CHECK(data.size() % 12 == 0, "ParallelVecProjectionGeometry3D", "Vectors doesn't consist of 12-tuples.");  	m_iProjectionAngleCount = data.size() / 12;  	m_pProjectionAngles = new SPar3DProjection[m_iProjectionAngleCount]; @@ -208,9 +205,9 @@ Config* CParallelVecProjectionGeometry3D::getConfiguration() const  	Config* cfg = new Config();  	cfg->initialize("ProjectionGeometry3D"); -	cfg->self->addAttribute("type", "parallel3d_vec"); -	cfg->self->addChildNode("DetectorRowCount", m_iDetectorRowCount); -	cfg->self->addChildNode("DetectorColCount", m_iDetectorColCount); +	cfg->self.addAttribute("type", "parallel3d_vec"); +	cfg->self.addChildNode("DetectorRowCount", m_iDetectorRowCount); +	cfg->self.addChildNode("DetectorColCount", m_iDetectorColCount);  	std::string vectors = "";  	for (int i = 0; i < m_iProjectionAngleCount; ++i) { @@ -229,7 +226,7 @@ Config* CParallelVecProjectionGeometry3D::getConfiguration() const  		vectors += boost::lexical_cast<string>(p.fDetVZ);  		if (i < m_iProjectionAngleCount-1) vectors += ';';  	} -	cfg->self->addChildNode("Vectors", vectors); +	cfg->self.addChildNode("Vectors", vectors);  	return cfg;  } diff --git a/src/ProjectionGeometry2D.cpp b/src/ProjectionGeometry2D.cpp index a51d86b..da93b9c 100644 --- a/src/ProjectionGeometry2D.cpp +++ b/src/ProjectionGeometry2D.cpp @@ -121,24 +121,21 @@ bool CProjectionGeometry2D::initialize(const Config& _cfg)  	}  	// Required: DetectorWidth -	XMLNode* node = _cfg.self->getSingleNode("DetectorWidth"); +	XMLNode node = _cfg.self.getSingleNode("DetectorWidth");  	ASTRA_CONFIG_CHECK(node, "ProjectionGeometry2D", "No DetectorWidth tag specified."); -	m_fDetectorWidth = boost::lexical_cast<float32>(node->getContent()); -	ASTRA_DELETE(node); +	m_fDetectorWidth = boost::lexical_cast<float32>(node.getContent());  	CC.markNodeParsed("DetectorWidth");  	// Required: DetectorCount -	node = _cfg.self->getSingleNode("DetectorCount"); +	node = _cfg.self.getSingleNode("DetectorCount");  	ASTRA_CONFIG_CHECK(node, "ProjectionGeometry2D", "No DetectorCount tag specified."); -	m_iDetectorCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iDetectorCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("DetectorCount");  	// Required: ProjectionAngles -	node = _cfg.self->getSingleNode("ProjectionAngles"); +	node = _cfg.self.getSingleNode("ProjectionAngles");  	ASTRA_CONFIG_CHECK(node, "ProjectionGeometry2D", "No ProjectionAngles tag specified."); -	vector<float32> angles = node->getContentNumericalArray(); -	delete node; +	vector<float32> angles = node.getContentNumericalArray();  	m_iProjectionAngleCount = angles.size();  	ASTRA_CONFIG_CHECK(m_iProjectionAngleCount > 0, "ProjectionGeometry2D", "Not enough ProjectionAngles specified.");  	m_pfProjectionAngles = new float32[m_iProjectionAngleCount]; diff --git a/src/ProjectionGeometry3D.cpp b/src/ProjectionGeometry3D.cpp index 5b77767..ef0246c 100644 --- a/src/ProjectionGeometry3D.cpp +++ b/src/ProjectionGeometry3D.cpp @@ -149,38 +149,34 @@ bool CProjectionGeometry3D::initialize(const Config& _cfg)  	ASTRA_ASSERT(_cfg.self);  	// Required: DetectorWidth -	XMLNode* node = _cfg.self->getSingleNode("DetectorSpacingX"); +	XMLNode node = _cfg.self.getSingleNode("DetectorSpacingX");  	ASTRA_CONFIG_CHECK(node, "ProjectionGeometry3D", "No DetectorSpacingX tag specified."); -	m_fDetectorSpacingX = boost::lexical_cast<float32>(node->getContent()); -	ASTRA_DELETE(node); +	m_fDetectorSpacingX = boost::lexical_cast<float32>(node.getContent());  	CC.markNodeParsed("DetectorSpacingX");  	// Required: DetectorHeight -	node = _cfg.self->getSingleNode("DetectorSpacingY"); +	node = _cfg.self.getSingleNode("DetectorSpacingY");  	ASTRA_CONFIG_CHECK(node, "ProjectionGeometry3D", "No DetectorSpacingY tag specified."); -	m_fDetectorSpacingY = boost::lexical_cast<float32>(node->getContent()); -	ASTRA_DELETE(node); +	m_fDetectorSpacingY = boost::lexical_cast<float32>(node.getContent());  	CC.markNodeParsed("DetectorSpacingY");  	// Required: DetectorRowCount -	node = _cfg.self->getSingleNode("DetectorRowCount"); +	node = _cfg.self.getSingleNode("DetectorRowCount");  	ASTRA_CONFIG_CHECK(node, "ProjectionGeometry3D", "No DetectorRowCount tag specified."); -	m_iDetectorRowCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iDetectorRowCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("DetectorRowCount");  	// Required: DetectorCount -	node = _cfg.self->getSingleNode("DetectorColCount"); +	node = _cfg.self.getSingleNode("DetectorColCount");  	ASTRA_CONFIG_CHECK(node, "ProjectionGeometry3D", "No DetectorColCount tag specified."); -	m_iDetectorColCount = boost::lexical_cast<int>(node->getContent()); +	m_iDetectorColCount = boost::lexical_cast<int>(node.getContent());  	m_iDetectorTotCount = m_iDetectorRowCount * m_iDetectorColCount; -	ASTRA_DELETE(node);  	CC.markNodeParsed("DetectorColCount");  	// Required: ProjectionAngles -	node = _cfg.self->getSingleNode("ProjectionAngles"); +	node = _cfg.self.getSingleNode("ProjectionAngles");  	ASTRA_CONFIG_CHECK(node, "ProjectionGeometry3D", "No ProjectionAngles tag specified."); -	vector<float32> angles = node->getContentNumericalArray(); +	vector<float32> angles = node.getContentNumericalArray();  	m_iProjectionAngleCount = angles.size();  	ASTRA_CONFIG_CHECK(m_iProjectionAngleCount > 0, "ProjectionGeometry3D", "Not enough ProjectionAngles specified.");  	m_pfProjectionAngles = new float32[m_iProjectionAngleCount]; @@ -188,7 +184,6 @@ bool CProjectionGeometry3D::initialize(const Config& _cfg)  		m_pfProjectionAngles[i] = angles[i];  	}  	CC.markNodeParsed("ProjectionAngles"); -	ASTRA_DELETE(node);  	// Interface class, so don't return true  	return false; diff --git a/src/Projector2D.cpp b/src/Projector2D.cpp index b0ace92..c8743b5 100644 --- a/src/Projector2D.cpp +++ b/src/Projector2D.cpp @@ -115,12 +115,12 @@ bool CProjector2D::initialize(const Config& _cfg)  	}  	// required: ProjectionGeometry -	XMLNode* node = _cfg.self->getSingleNode("ProjectionGeometry"); +	XMLNode node = _cfg.self.getSingleNode("ProjectionGeometry");  	ASTRA_CONFIG_CHECK(node, "Projector2D", "No ProjectionGeometry tag specified.");  	// FIXME: Change how the base class is created. (This is duplicated  	// in astra_mex_data2d.cpp.) -	std::string type = node->getAttribute("type"); +	std::string type = node.getAttribute("type");  	if (type == "sparse_matrix") {  		m_pProjectionGeometry = new CSparseMatrixProjectionGeometry2D();  		m_pProjectionGeometry->initialize(Config(node)); @@ -146,7 +146,7 @@ bool CProjector2D::initialize(const Config& _cfg)  	// required: VolumeGeometry -	node = _cfg.self->getSingleNode("VolumeGeometry"); +	node = _cfg.self.getSingleNode("VolumeGeometry");  	ASTRA_CONFIG_CHECK(node, "Projector2D", "No VolumeGeometry tag specified.");  	m_pVolumeGeometry = new CVolumeGeometry2D();  	m_pVolumeGeometry->initialize(Config(node)); diff --git a/src/Projector3D.cpp b/src/Projector3D.cpp index b546ee9..5e22105 100644 --- a/src/Projector3D.cpp +++ b/src/Projector3D.cpp @@ -92,11 +92,11 @@ bool CProjector3D::initialize(const Config& _cfg)  	assert(_cfg.self);  	ConfigStackCheck<CProjector3D> CC("Projector3D", this, _cfg); -	XMLNode* node; +	XMLNode node; -	node = _cfg.self->getSingleNode("ProjectionGeometry"); +	node = _cfg.self.getSingleNode("ProjectionGeometry");  	ASTRA_CONFIG_CHECK(node, "Projector3D", "No ProjectionGeometry tag specified."); -	std::string type = node->getAttribute("type"); +	std::string type = node.getAttribute("type");  	CProjectionGeometry3D* pProjGeometry = 0;  	if (type == "parallel3d") {  		pProjGeometry = new CParallelProjectionGeometry3D(); @@ -108,18 +108,19 @@ bool CProjector3D::initialize(const Config& _cfg)  		pProjGeometry = new CConeVecProjectionGeometry3D();  	} else {  		// Invalid geometry type +		ASTRA_CONFIG_CHECK(false, "Projector3D", "Invalid projection geometry type specified.");  	}  	pProjGeometry->initialize(Config(node)); // this deletes node  	m_pProjectionGeometry = pProjGeometry;  	ASTRA_CONFIG_CHECK(m_pProjectionGeometry->isInitialized(), "Projector3D", "ProjectionGeometry not initialized.");  	CC.markNodeParsed("ProjectionGeometry"); -	node = _cfg.self->getSingleNode("VolumeGeometry"); +	node = _cfg.self.getSingleNode("VolumeGeometry");  	ASTRA_CONFIG_CHECK(node, "Projector3D", "No VolumeGeometry tag specified.");  	CVolumeGeometry3D* pVolGeometry = new CVolumeGeometry3D();  	pVolGeometry->initialize(Config(node)); // this deletes node  	m_pVolumeGeometry = pVolGeometry; -	ASTRA_CONFIG_CHECK(m_pVolumeGeometry->isInitialized(), "Projector2D", "VolumeGeometry not initialized."); +	ASTRA_CONFIG_CHECK(m_pVolumeGeometry->isInitialized(), "Projector3D", "VolumeGeometry not initialized.");  	CC.markNodeParsed("VolumeGeometry");  	return true; diff --git a/src/ReconstructionAlgorithm2D.cpp b/src/ReconstructionAlgorithm2D.cpp index e089fac..767efe6 100644 --- a/src/ReconstructionAlgorithm2D.cpp +++ b/src/ReconstructionAlgorithm2D.cpp @@ -84,71 +84,68 @@ bool CReconstructionAlgorithm2D::initialize(const Config& _cfg)  	ConfigStackCheck<CAlgorithm> CC("ReconstructionAlgorithm2D", this, _cfg);  	// projector -	XMLNode* node = _cfg.self->getSingleNode("ProjectorId"); +	XMLNode node = _cfg.self.getSingleNode("ProjectorId");  	ASTRA_CONFIG_CHECK(node, "Reconstruction2D", "No ProjectorId tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pProjector = CProjector2DManager::getSingleton().get(id); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectorId");  	// sinogram data -	node = _cfg.self->getSingleNode("ProjectionDataId"); +	node = _cfg.self.getSingleNode("ProjectionDataId");  	ASTRA_CONFIG_CHECK(node, "Reconstruction2D", "No ProjectionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pSinogram = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectionDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("ReconstructionDataId"); +	node = _cfg.self.getSingleNode("ReconstructionDataId");  	ASTRA_CONFIG_CHECK(node, "Reconstruction2D", "No ReconstructionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pReconstruction = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ReconstructionDataId");  	// fixed mask -	if (_cfg.self->hasOption("ReconstructionMaskId")) { +	if (_cfg.self.hasOption("ReconstructionMaskId")) {  		m_bUseReconstructionMask = true; -		id = boost::lexical_cast<int>(_cfg.self->getOption("ReconstructionMaskId")); +		id = boost::lexical_cast<int>(_cfg.self.getOption("ReconstructionMaskId"));  		m_pReconstructionMask = dynamic_cast<CFloat32VolumeData2D*>(CData2DManager::getSingleton().get(id));  		ASTRA_CONFIG_CHECK(m_pReconstructionMask, "Reconstruction2D", "Invalid ReconstructionMaskId.");  	}  	CC.markOptionParsed("ReconstructionMaskId");  	// fixed mask -	if (_cfg.self->hasOption("SinogramMaskId")) { +	if (_cfg.self.hasOption("SinogramMaskId")) {  		m_bUseSinogramMask = true; -		id = boost::lexical_cast<int>(_cfg.self->getOption("SinogramMaskId")); +		id = boost::lexical_cast<int>(_cfg.self.getOption("SinogramMaskId"));  		m_pSinogramMask = dynamic_cast<CFloat32ProjectionData2D*>(CData2DManager::getSingleton().get(id));  		ASTRA_CONFIG_CHECK(m_pSinogramMask, "Reconstruction2D", "Invalid SinogramMaskId.");  	}  	CC.markOptionParsed("SinogramMaskId");  	// Constraints - NEW -	if (_cfg.self->hasOption("MinConstraint")) { +	if (_cfg.self.hasOption("MinConstraint")) {  		m_bUseMinConstraint = true; -		m_fMinValue = _cfg.self->getOptionNumerical("MinConstraint", 0.0f); +		m_fMinValue = _cfg.self.getOptionNumerical("MinConstraint", 0.0f);  		CC.markOptionParsed("MinConstraint");  	} else {  		// Constraint - OLD -		m_bUseMinConstraint = _cfg.self->getOptionBool("UseMinConstraint", false); +		m_bUseMinConstraint = _cfg.self.getOptionBool("UseMinConstraint", false);  		CC.markOptionParsed("UseMinConstraint");  		if (m_bUseMinConstraint) { -			m_fMinValue = _cfg.self->getOptionNumerical("MinConstraintValue", 0.0f); +			m_fMinValue = _cfg.self.getOptionNumerical("MinConstraintValue", 0.0f);  			CC.markOptionParsed("MinConstraintValue");  		}  	} -	if (_cfg.self->hasOption("MaxConstraint")) { +	if (_cfg.self.hasOption("MaxConstraint")) {  		m_bUseMaxConstraint = true; -		m_fMaxValue = _cfg.self->getOptionNumerical("MaxConstraint", 255.0f); +		m_fMaxValue = _cfg.self.getOptionNumerical("MaxConstraint", 255.0f);  		CC.markOptionParsed("MaxConstraint");  	} else {  		// Constraint - OLD -		m_bUseMaxConstraint = _cfg.self->getOptionBool("UseMaxConstraint", false); +		m_bUseMaxConstraint = _cfg.self.getOptionBool("UseMaxConstraint", false);  		CC.markOptionParsed("UseMaxConstraint");  		if (m_bUseMaxConstraint) { -			m_fMaxValue = _cfg.self->getOptionNumerical("MaxConstraintValue", 0.0f); +			m_fMaxValue = _cfg.self.getOptionNumerical("MaxConstraintValue", 0.0f);  			CC.markOptionParsed("MaxConstraintValue");  		}  	} diff --git a/src/ReconstructionAlgorithm3D.cpp b/src/ReconstructionAlgorithm3D.cpp index 13d069d..86b8ab2 100644 --- a/src/ReconstructionAlgorithm3D.cpp +++ b/src/ReconstructionAlgorithm3D.cpp @@ -104,7 +104,7 @@ bool CReconstructionAlgorithm3D::initialize(const Config& _cfg)  	ASTRA_ASSERT(_cfg.self);  	ConfigStackCheck<CAlgorithm> CC("ReconstructionAlgorithm3D", this, _cfg); -	XMLNode* node; +	XMLNode node;  	int id;  #if 0  	// projector @@ -116,60 +116,58 @@ bool CReconstructionAlgorithm3D::initialize(const Config& _cfg)  #endif  	// sinogram data -	node = _cfg.self->getSingleNode("ProjectionDataId"); +	node = _cfg.self.getSingleNode("ProjectionDataId");  	ASTRA_CONFIG_CHECK(node, "Reconstruction3D", "No ProjectionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pSinogram = dynamic_cast<CFloat32ProjectionData3D*>(CData3DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ProjectionDataId");  	// reconstruction data -	node = _cfg.self->getSingleNode("ReconstructionDataId"); +	node = _cfg.self.getSingleNode("ReconstructionDataId");  	ASTRA_CONFIG_CHECK(node, "Reconstruction3D", "No ReconstructionDataId tag specified."); -	id = boost::lexical_cast<int>(node->getContent()); +	id = boost::lexical_cast<int>(node.getContent());  	m_pReconstruction = dynamic_cast<CFloat32VolumeData3D*>(CData3DManager::getSingleton().get(id)); -	ASTRA_DELETE(node);  	CC.markNodeParsed("ReconstructionDataId");  	// fixed mask -	if (_cfg.self->hasOption("ReconstructionMaskId")) { +	if (_cfg.self.hasOption("ReconstructionMaskId")) {  		m_bUseReconstructionMask = true; -		id = boost::lexical_cast<int>(_cfg.self->getOption("ReconstructionMaskId")); +		id = boost::lexical_cast<int>(_cfg.self.getOption("ReconstructionMaskId"));  		m_pReconstructionMask = dynamic_cast<CFloat32VolumeData3D*>(CData3DManager::getSingleton().get(id));  	}  	CC.markOptionParsed("ReconstructionMaskId");  	// fixed mask -	if (_cfg.self->hasOption("SinogramMaskId")) { +	if (_cfg.self.hasOption("SinogramMaskId")) {  		m_bUseSinogramMask = true; -		id = boost::lexical_cast<int>(_cfg.self->getOption("SinogramMaskId")); +		id = boost::lexical_cast<int>(_cfg.self.getOption("SinogramMaskId"));  		m_pSinogramMask = dynamic_cast<CFloat32ProjectionData3D*>(CData3DManager::getSingleton().get(id));  	}  	// Constraints - NEW -	if (_cfg.self->hasOption("MinConstraint")) { +	if (_cfg.self.hasOption("MinConstraint")) {  		m_bUseMinConstraint = true; -		m_fMinValue = _cfg.self->getOptionNumerical("MinConstraint", 0.0f); +		m_fMinValue = _cfg.self.getOptionNumerical("MinConstraint", 0.0f);  		CC.markOptionParsed("MinConstraint");  	} else {  		// Constraint - OLD -		m_bUseMinConstraint = _cfg.self->getOptionBool("UseMinConstraint", false); +		m_bUseMinConstraint = _cfg.self.getOptionBool("UseMinConstraint", false);  		CC.markOptionParsed("UseMinConstraint");  		if (m_bUseMinConstraint) { -			m_fMinValue = _cfg.self->getOptionNumerical("MinConstraintValue", 0.0f); +			m_fMinValue = _cfg.self.getOptionNumerical("MinConstraintValue", 0.0f);  			CC.markOptionParsed("MinConstraintValue");  		}  	} -	if (_cfg.self->hasOption("MaxConstraint")) { +	if (_cfg.self.hasOption("MaxConstraint")) {  		m_bUseMaxConstraint = true; -		m_fMaxValue = _cfg.self->getOptionNumerical("MaxConstraint", 255.0f); +		m_fMaxValue = _cfg.self.getOptionNumerical("MaxConstraint", 255.0f);  		CC.markOptionParsed("MaxConstraint");  	} else {  		// Constraint - OLD -		m_bUseMaxConstraint = _cfg.self->getOptionBool("UseMaxConstraint", false); +		m_bUseMaxConstraint = _cfg.self.getOptionBool("UseMaxConstraint", false);  		CC.markOptionParsed("UseMaxConstraint");  		if (m_bUseMaxConstraint) { -			m_fMaxValue = _cfg.self->getOptionNumerical("MaxConstraintValue", 0.0f); +			m_fMaxValue = _cfg.self.getOptionNumerical("MaxConstraintValue", 0.0f);  			CC.markOptionParsed("MaxConstraintValue");  		}  	} diff --git a/src/SartAlgorithm.cpp b/src/SartAlgorithm.cpp index f7a1677..e4dc5c7 100644 --- a/src/SartAlgorithm.cpp +++ b/src/SartAlgorithm.cpp @@ -126,7 +126,7 @@ bool CSartAlgorithm::initialize(const Config& _cfg)  	// projection order  	m_iCurrentProjection = 0;  	m_iProjectionCount = m_pProjector->getProjectionGeometry()->getProjectionAngleCount(); -	string projOrder = _cfg.self->getOption("ProjectionOrder", "sequential"); +	string projOrder = _cfg.self.getOption("ProjectionOrder", "sequential");  	CC.markOptionParsed("ProjectionOrder");  	if (projOrder == "sequential") {  		m_piProjectionOrder = new int[m_iProjectionCount]; @@ -145,7 +145,7 @@ bool CSartAlgorithm::initialize(const Config& _cfg)  			m_piProjectionOrder[i + k] = t;  		}  	} else if (projOrder == "custom") { -		vector<float32> projOrderList = _cfg.self->getOptionNumericalArray("ProjectionOrderList"); +		vector<float32> projOrderList = _cfg.self.getOptionNumericalArray("ProjectionOrderList");  		m_piProjectionOrder = new int[projOrderList.size()];  		for (int i = 0; i < m_iProjectionCount; i++) {  			m_piProjectionOrder[i] = static_cast<int>(projOrderList[i]); diff --git a/src/SparseMatrixProjectionGeometry2D.cpp b/src/SparseMatrixProjectionGeometry2D.cpp index 86357d2..073720f 100644 --- a/src/SparseMatrixProjectionGeometry2D.cpp +++ b/src/SparseMatrixProjectionGeometry2D.cpp @@ -98,11 +98,10 @@ bool CSparseMatrixProjectionGeometry2D::initialize(const Config& _cfg)  	CProjectionGeometry2D::initialize(_cfg);  	// get matrix -	XMLNode* node = _cfg.self->getSingleNode("MatrixID"); +	XMLNode node = _cfg.self.getSingleNode("MatrixID");  	ASTRA_CONFIG_CHECK(node, "SparseMatrixProjectionGeometry2D", "No MatrixID tag specified."); -	int id = boost::lexical_cast<int>(node->getContent()); +	int id = boost::lexical_cast<int>(node.getContent());  	m_pMatrix = CMatrixManager::getSingleton().get(id); -	ASTRA_DELETE(node);  	CC.markNodeParsed("MatrixID");  	// success @@ -194,11 +193,11 @@ Config* CSparseMatrixProjectionGeometry2D::getConfiguration() const  {  	Config* cfg = new Config();  	cfg->initialize("ProjectionGeometry2D"); -	cfg->self->addAttribute("type", "sparse matrix"); -	cfg->self->addChildNode("DetectorCount", getDetectorCount()); -	cfg->self->addChildNode("DetectorWidth", getDetectorWidth()); -	cfg->self->addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount); -	cfg->self->addChildNode("MatrixID", CMatrixManager::getSingleton().getIndex(m_pMatrix)); +	cfg->self.addAttribute("type", "sparse matrix"); +	cfg->self.addChildNode("DetectorCount", getDetectorCount()); +	cfg->self.addChildNode("DetectorWidth", getDetectorWidth()); +	cfg->self.addChildNode("ProjectionAngles", m_pfProjectionAngles, m_iProjectionAngleCount); +	cfg->self.addChildNode("MatrixID", CMatrixManager::getSingleton().getIndex(m_pMatrix));  	return cfg;  } diff --git a/src/VolumeGeometry2D.cpp b/src/VolumeGeometry2D.cpp index d412914..6eea1b2 100644 --- a/src/VolumeGeometry2D.cpp +++ b/src/VolumeGeometry2D.cpp @@ -164,24 +164,22 @@ bool CVolumeGeometry2D::initialize(const Config& _cfg)  	}  	// Required: GridColCount -	XMLNode* node = _cfg.self->getSingleNode("GridColCount"); +	XMLNode node = _cfg.self.getSingleNode("GridColCount");  	ASTRA_CONFIG_CHECK(node, "ReconstructionGeometry2D", "No GridColCount tag specified."); -	m_iGridColCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iGridColCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("GridColCount");  	// Required: GridRowCount -	node = _cfg.self->getSingleNode("GridRowCount"); +	node = _cfg.self.getSingleNode("GridRowCount");  	ASTRA_CONFIG_CHECK(node, "ReconstructionGeometry2D", "No GridRowCount tag specified."); -	m_iGridRowCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iGridRowCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("GridRowCount");  	// Optional: Window minima and maxima -	m_fWindowMinX = _cfg.self->getOptionNumerical("WindowMinX", -m_iGridColCount/2.0f); -	m_fWindowMaxX = _cfg.self->getOptionNumerical("WindowMaxX", m_iGridColCount/2.0f); -	m_fWindowMinY = _cfg.self->getOptionNumerical("WindowMinY", -m_iGridRowCount/2.0f); -	m_fWindowMaxY = _cfg.self->getOptionNumerical("WindowMaxY", m_iGridRowCount/2.0f); +	m_fWindowMinX = _cfg.self.getOptionNumerical("WindowMinX", -m_iGridColCount/2.0f); +	m_fWindowMaxX = _cfg.self.getOptionNumerical("WindowMaxX", m_iGridColCount/2.0f); +	m_fWindowMinY = _cfg.self.getOptionNumerical("WindowMinY", -m_iGridRowCount/2.0f); +	m_fWindowMaxY = _cfg.self.getOptionNumerical("WindowMaxY", m_iGridRowCount/2.0f);  	CC.markOptionParsed("WindowMinX");  	CC.markOptionParsed("WindowMaxX");  	CC.markOptionParsed("WindowMinY"); @@ -285,13 +283,13 @@ Config* CVolumeGeometry2D::getConfiguration() const  	Config* cfg = new Config();  	cfg->initialize("VolumeGeometry2D"); -	cfg->self->addChildNode("GridColCount", m_iGridColCount); -	cfg->self->addChildNode("GridRowCount", m_iGridRowCount); +	cfg->self.addChildNode("GridColCount", m_iGridColCount); +	cfg->self.addChildNode("GridRowCount", m_iGridRowCount); -	cfg->self->addOption("WindowMinX", m_fWindowMinX); -	cfg->self->addOption("WindowMaxX", m_fWindowMaxX); -	cfg->self->addOption("WindowMinY", m_fWindowMinY); -	cfg->self->addOption("WindowMaxY", m_fWindowMaxY); +	cfg->self.addOption("WindowMinX", m_fWindowMinX); +	cfg->self.addOption("WindowMaxX", m_fWindowMaxX); +	cfg->self.addOption("WindowMinY", m_fWindowMinY); +	cfg->self.addOption("WindowMaxY", m_fWindowMaxY);  	return cfg;  } diff --git a/src/VolumeGeometry3D.cpp b/src/VolumeGeometry3D.cpp index 66e6f0c..a1cf424 100644 --- a/src/VolumeGeometry3D.cpp +++ b/src/VolumeGeometry3D.cpp @@ -192,33 +192,30 @@ bool CVolumeGeometry3D::initialize(const Config& _cfg)  	}  	// Required: GridColCount -	XMLNode* node = _cfg.self->getSingleNode("GridColCount"); +	XMLNode node = _cfg.self.getSingleNode("GridColCount");  	ASTRA_CONFIG_CHECK(node, "ReconstructionGeometry2D", "No GridColCount tag specified."); -	m_iGridColCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iGridColCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("GridColCount");  	// Required: GridRowCount -	node = _cfg.self->getSingleNode("GridRowCount"); +	node = _cfg.self.getSingleNode("GridRowCount");  	ASTRA_CONFIG_CHECK(node, "ReconstructionGeometry2D", "No GridRowCount tag specified."); -	m_iGridRowCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iGridRowCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("GridRowCount");  	// Required: GridRowCount -	node = _cfg.self->getSingleNode("GridSliceCount"); +	node = _cfg.self.getSingleNode("GridSliceCount");  	ASTRA_CONFIG_CHECK(node, "ReconstructionGeometry2D", "No GridSliceCount tag specified."); -	m_iGridSliceCount = boost::lexical_cast<int>(node->getContent()); -	ASTRA_DELETE(node); +	m_iGridSliceCount = boost::lexical_cast<int>(node.getContent());  	CC.markNodeParsed("GridSliceCount");  	// Optional: Window minima and maxima -	m_fWindowMinX = _cfg.self->getOptionNumerical("WindowMinX", -m_iGridColCount/2.0f); -	m_fWindowMaxX = _cfg.self->getOptionNumerical("WindowMaxX", m_iGridColCount/2.0f); -	m_fWindowMinY = _cfg.self->getOptionNumerical("WindowMinY", -m_iGridRowCount/2.0f); -	m_fWindowMaxY = _cfg.self->getOptionNumerical("WindowMaxY", m_iGridRowCount/2.0f); -	m_fWindowMinZ = _cfg.self->getOptionNumerical("WindowMinZ", -m_iGridSliceCount/2.0f); -	m_fWindowMaxZ = _cfg.self->getOptionNumerical("WindowMaxZ", m_iGridSliceCount/2.0f); +	m_fWindowMinX = _cfg.self.getOptionNumerical("WindowMinX", -m_iGridColCount/2.0f); +	m_fWindowMaxX = _cfg.self.getOptionNumerical("WindowMaxX", m_iGridColCount/2.0f); +	m_fWindowMinY = _cfg.self.getOptionNumerical("WindowMinY", -m_iGridRowCount/2.0f); +	m_fWindowMaxY = _cfg.self.getOptionNumerical("WindowMaxY", m_iGridRowCount/2.0f); +	m_fWindowMinZ = _cfg.self.getOptionNumerical("WindowMinZ", -m_iGridSliceCount/2.0f); +	m_fWindowMaxZ = _cfg.self.getOptionNumerical("WindowMaxZ", m_iGridSliceCount/2.0f);  	CC.markOptionParsed("WindowMinX");  	CC.markOptionParsed("WindowMaxX");  	CC.markOptionParsed("WindowMinY"); @@ -386,16 +383,16 @@ Config* CVolumeGeometry3D::getConfiguration() const  	Config* cfg = new Config();  	cfg->initialize("VolumeGeometry3D"); -	cfg->self->addChildNode("GridColCount", m_iGridColCount); -	cfg->self->addChildNode("GridRowCount", m_iGridRowCount); -	cfg->self->addChildNode("GridSliceCount", m_iGridSliceCount); +	cfg->self.addChildNode("GridColCount", m_iGridColCount); +	cfg->self.addChildNode("GridRowCount", m_iGridRowCount); +	cfg->self.addChildNode("GridSliceCount", m_iGridSliceCount); -	cfg->self->addOption("WindowMinX", m_fWindowMinX); -	cfg->self->addOption("WindowMaxX", m_fWindowMaxX); -	cfg->self->addOption("WindowMinY", m_fWindowMinY); -	cfg->self->addOption("WindowMaxY", m_fWindowMaxY); -	cfg->self->addOption("WindowMinZ", m_fWindowMinZ); -	cfg->self->addOption("WindowMaxZ", m_fWindowMaxZ); +	cfg->self.addOption("WindowMinX", m_fWindowMinX); +	cfg->self.addOption("WindowMaxX", m_fWindowMaxX); +	cfg->self.addOption("WindowMinY", m_fWindowMinY); +	cfg->self.addOption("WindowMaxY", m_fWindowMaxY); +	cfg->self.addOption("WindowMinZ", m_fWindowMinZ); +	cfg->self.addOption("WindowMaxZ", m_fWindowMaxZ);  	return cfg;  } diff --git a/src/XMLDocument.cpp b/src/XMLDocument.cpp index 406564f..716ed9e 100644 --- a/src/XMLDocument.cpp +++ b/src/XMLDocument.cpp @@ -32,13 +32,8 @@ $Id$  #include <iostream>  #include <sstream> -#ifdef _MSC_VER  #include "rapidxml/rapidxml.hpp"  #include "rapidxml/rapidxml_print.hpp" -#else -#include "rapidxml.hpp" -#include "rapidxml_print.hpp" -#endif  using namespace rapidxml;  using namespace astra; @@ -94,10 +89,9 @@ XMLDocument* XMLDocument::createDocument(string sRootName)  }  //----------------------------------------------------------------------------- -XMLNode* XMLDocument::getRootNode()  +XMLNode XMLDocument::getRootNode()   { -	// TODO: clean up: this 'new' requires callers to do memory management -	return new XMLNode(fDOMDocument->first_node()); +	return XMLNode(fDOMDocument->first_node());  }  //----------------------------------------------------------------------------- diff --git a/src/XMLNode.cpp b/src/XMLNode.cpp index 4b2bdf4..0ec701f 100644 --- a/src/XMLNode.cpp +++ b/src/XMLNode.cpp @@ -28,15 +28,15 @@ $Id$  #include "astra/XMLNode.h" -#ifdef _MSC_VER  #include "rapidxml/rapidxml.hpp"  #include "rapidxml/rapidxml_print.hpp" -#else -#include "rapidxml.hpp" -#include "rapidxml_print.hpp" -#endif  #include <boost/lexical_cast.hpp> +#include <boost/algorithm/string.hpp> +#include <boost/algorithm/string/split.hpp> +#include <boost/algorithm/string/classification.hpp> + +  using namespace rapidxml;  using namespace astra; @@ -44,21 +44,10 @@ using namespace std;  //----------------------------------------------------------------------------- -// Utility function to delete a list of nodes -static void deleteNodes(list<XMLNode*>& nodes) -{ -	for (list<XMLNode*>::iterator i = nodes.begin(); i != nodes.end(); ++i) -		delete (*i); - -	nodes.clear(); -} - - -//-----------------------------------------------------------------------------  // default constructor  XMLNode::XMLNode()   { - +	fDOMElement = 0;  }  //-----------------------------------------------------------------------------	 @@ -84,14 +73,14 @@ void XMLNode::setDOMNode(xml_node<>* n)  //-----------------------------------------------------------------------------	  // print XML Node -void XMLNode::print() +void XMLNode::print() const  {  	std::cout << fDOMElement;  }  //-----------------------------------------------------------------------------	  // print XML Node -std::string XMLNode::toString() +std::string XMLNode::toString() const  {  	std::string s;  	::print(std::back_inserter(s), *fDOMElement, 0); @@ -100,64 +89,61 @@ std::string XMLNode::toString()  //-----------------------------------------------------------------------------	  // Get single node -XMLNode* XMLNode::getSingleNode(string name)  +XMLNode XMLNode::getSingleNode(string name) const  {  	xml_node<> *node = fDOMElement->first_node(name.c_str()); -	if (node) -		return new XMLNode(node); -	else -		return 0; +	return XMLNode(node);  }  //-----------------------------------------------------------------------------	  // Get list of nodes -list<XMLNode*> XMLNode::getNodes(string name)  +list<XMLNode> XMLNode::getNodes(string name) const  {	 -	list<XMLNode*> result; +	list<XMLNode> result;  	xml_node<> *iter;  	for (iter = fDOMElement->first_node(name.c_str()); iter; iter = iter->next_sibling(name.c_str())) { -		result.push_back(new XMLNode(iter)); +		result.push_back(XMLNode(iter));  	}  	return result;  }  //-----------------------------------------------------------------------------	  // Get list of nodes -list<XMLNode*> XMLNode::getNodes()  +list<XMLNode> XMLNode::getNodes() const  {	 -	list<XMLNode*> result; +	list<XMLNode> result;  	xml_node<> *iter;  	for (iter = fDOMElement->first_node(); iter; iter = iter->next_sibling()) { -		result.push_back(new XMLNode(iter)); +		result.push_back(XMLNode(iter));  	}  	return result;  }  //-----------------------------------------------------------------------------	  // Get name of this node -std::string XMLNode::getName() +std::string XMLNode::getName() const  {  	return fDOMElement->name();  }  //-----------------------------------------------------------------------------	  // Get node content - STRING -string XMLNode::getContent()  +string XMLNode::getContent() const  {  	return fDOMElement->value();  }  //-----------------------------------------------------------------------------	  // Get node content - NUMERICAL -float32 XMLNode::getContentNumerical()  +float32 XMLNode::getContentNumerical() const  {  	return boost::lexical_cast<float32>(getContent());  }  //-----------------------------------------------------------------------------	  // Get node content - BOOLEAN -bool XMLNode::getContentBool()  +bool XMLNode::getContentBool() const  {  	string res = getContent();  	return ((res == "1") || (res == "yes") || (res == "true") || (res == "on")); @@ -165,21 +151,20 @@ bool XMLNode::getContentBool()  //-----------------------------------------------------------------------------	  // Get node content - STRING LIST -vector<string> XMLNode::getContentArray() +vector<string> XMLNode::getContentArray() const  {  	// get listsize  	int iSize = boost::lexical_cast<int>(getAttribute("listsize"));  	// create result array  	vector<string> res(iSize);  	// loop all list item nodes -	list<XMLNode*> nodes = getNodes("ListItem"); -	for (list<XMLNode*>::iterator it = nodes.begin(); it != nodes.end(); it++) { -		int iIndex = (*it)->getAttributeNumerical("index"); -		string sValue = (*it)->getAttribute("value"); +	list<XMLNode> nodes = getNodes("ListItem"); +	for (list<XMLNode>::iterator it = nodes.begin(); it != nodes.end(); it++) { +		int iIndex = it->getAttributeNumerical("index"); +		string sValue = it->getAttribute("value");  		ASTRA_ASSERT(iIndex < iSize);  		res[iIndex] = sValue;  	} -	deleteNodes(nodes);  	// return   	return res; @@ -187,85 +172,48 @@ vector<string> XMLNode::getContentArray()  //-----------------------------------------------------------------------------	  // Get node content - NUMERICAL LIST -vector<float32> XMLNode::getContentNumericalArray() +// NB: A 2D matrix is returned as a linear list +vector<float32> XMLNode::getContentNumericalArray() const  { -	// is scalar -	if (!hasAttribute("listsize")) { -		vector<float32> res(1); -		res[0] = getContentNumerical(); -		return res; -	} +	string input = getContent(); -	int iSize = boost::lexical_cast<int>(getAttribute("listsize")); -	// create result array -	vector<float32> res(iSize); -	// loop all list item nodes -	list<XMLNode*> nodes = getNodes("ListItem"); -	for (list<XMLNode*>::iterator it = nodes.begin(); it != nodes.end(); it++) { -		int iIndex = (*it)->getAttributeNumerical("index"); -		float32 fValue = (*it)->getAttributeNumerical("value"); -		ASTRA_ASSERT(iIndex < iSize); -		res[iIndex] = fValue; -	} -	deleteNodes(nodes); -	// return  -	return res; -} +	// split +	std::vector<std::string> items; +	boost::split(items, input, boost::is_any_of(",;")); -vector<double> XMLNode::getContentNumericalArrayDouble() -{ -	// is scalar -	if (!hasAttribute("listsize")) { -		vector<double> res(1); -		res[0] = getContentNumerical(); -		return res; -	} +	// init list +	vector<float32> out; +	out.resize(items.size()); -	int iSize = boost::lexical_cast<int>(getAttribute("listsize")); -	// create result array -	vector<double> res(iSize); -	// loop all list item nodes -	list<XMLNode*> nodes = getNodes("ListItem"); -	for (list<XMLNode*>::iterator it = nodes.begin(); it != nodes.end(); it++) { -		int iIndex = (*it)->getAttributeNumerical("index"); -		double fValue = (*it)->getAttributeNumericalDouble("value"); -		ASTRA_ASSERT(iIndex < iSize); -		res[iIndex] = fValue; +	// loop elements +	for (unsigned int i = 0; i < items.size(); i++) { +		out[i] = boost::lexical_cast<float32>(items[i]);  	} -	deleteNodes(nodes); -	// return  -	return res; +	return out;  } -//-----------------------------------------------------------------------------	 -// Get node content - NUMERICAL LIST 2 -void XMLNode::getContentNumericalArray(float32*& _pfData, int& _iSize) +vector<double> XMLNode::getContentNumericalArrayDouble() const  { -	// is scalar -	if (!hasAttribute("listsize")) { -		_iSize = 1; -		_pfData = new float32[_iSize]; -		_pfData[0] = getContentNumerical(); -		return; -	} -	// get listsize -	_iSize = boost::lexical_cast<int>(getAttribute("listsize")); -	// create result array -	_pfData = new float32[_iSize]; -	// loop all list item nodes -	list<XMLNode*> nodes = getNodes("ListItem"); -	for (list<XMLNode*>::iterator it = nodes.begin(); it != nodes.end(); it++) { -		int iIndex = (*it)->getAttributeNumerical("index"); -		float32 fValue = (*it)->getAttributeNumerical("value"); -		ASTRA_ASSERT(iIndex < _iSize); -		_pfData[iIndex] = fValue; +	string input = getContent(); + +	// split +	std::vector<std::string> items; +	boost::split(items, input, boost::is_any_of(",;")); + +	// init list +	vector<double> out; +	out.resize(items.size()); + +	// loop elements +	for (unsigned int i = 0; i < items.size(); i++) { +		out[i] = boost::lexical_cast<double>(items[i]);  	} -	deleteNodes(nodes); +	return out;  }  //-----------------------------------------------------------------------------	  // Is attribute? -bool XMLNode::hasAttribute(string _sName) +bool XMLNode::hasAttribute(string _sName) const  {  	xml_attribute<> *attr = fDOMElement->first_attribute(_sName.c_str());  	return (attr != 0); @@ -273,7 +221,7 @@ bool XMLNode::hasAttribute(string _sName)  //-----------------------------------------------------------------------------	  // Get attribute - STRING -string XMLNode::getAttribute(string _sName, string _sDefaultValue) +string XMLNode::getAttribute(string _sName, string _sDefaultValue) const  {  	xml_attribute<> *attr = fDOMElement->first_attribute(_sName.c_str()); @@ -284,12 +232,12 @@ string XMLNode::getAttribute(string _sName, string _sDefaultValue)  //-----------------------------------------------------------------------------	  // Get attribute - NUMERICAL -float32 XMLNode::getAttributeNumerical(string _sName, float32 _fDefaultValue) +float32 XMLNode::getAttributeNumerical(string _sName, float32 _fDefaultValue) const  {  	if (!hasAttribute(_sName)) return _fDefaultValue;  	return boost::lexical_cast<float32>(getAttribute(_sName));  } -double XMLNode::getAttributeNumericalDouble(string _sName, double _fDefaultValue) +double XMLNode::getAttributeNumericalDouble(string _sName, double _fDefaultValue) const  {  	if (!hasAttribute(_sName)) return _fDefaultValue;  	return boost::lexical_cast<double>(getAttribute(_sName)); @@ -297,7 +245,7 @@ double XMLNode::getAttributeNumericalDouble(string _sName, double _fDefaultValue  //-----------------------------------------------------------------------------	  // Get attribute - BOOLEAN -bool XMLNode::getAttributeBool(string _sName, bool _bDefaultValue) +bool XMLNode::getAttributeBool(string _sName, bool _bDefaultValue) const  {  	if (!hasAttribute(_sName)) return _bDefaultValue;  	string res = getAttribute(_sName); @@ -306,7 +254,7 @@ bool XMLNode::getAttributeBool(string _sName, bool _bDefaultValue)  //-----------------------------------------------------------------------------	  // Has option? -bool XMLNode::hasOption(string _sKey)  +bool XMLNode::hasOption(string _sKey) const  {  	xml_node<> *iter;  	for (iter = fDOMElement->first_node("Option"); iter; iter = iter->next_sibling("Option")) { @@ -319,7 +267,7 @@ bool XMLNode::hasOption(string _sKey)  //-----------------------------------------------------------------------------	  // Get option - STRING -string XMLNode::getOption(string _sKey, string _sDefaultValue)  +string XMLNode::getOption(string _sKey, string _sDefaultValue) const  {  	xml_node<> *iter;  	for (iter = fDOMElement->first_node("Option"); iter; iter = iter->next_sibling("Option")) { @@ -336,7 +284,7 @@ string XMLNode::getOption(string _sKey, string _sDefaultValue)  //-----------------------------------------------------------------------------	  // Get option - NUMERICAL -float32 XMLNode::getOptionNumerical(string _sKey, float32 _fDefaultValue)  +float32 XMLNode::getOptionNumerical(string _sKey, float32 _fDefaultValue) const  {  	if (!hasOption(_sKey)) return _fDefaultValue;  	return boost::lexical_cast<float32>(getOption(_sKey)); @@ -344,7 +292,7 @@ float32 XMLNode::getOptionNumerical(string _sKey, float32 _fDefaultValue)  //-----------------------------------------------------------------------------	  // Get option - BOOL -bool XMLNode::getOptionBool(string _sKey, bool _bDefaultValue) +bool XMLNode::getOptionBool(string _sKey, bool _bDefaultValue) const  {  	bool bHasOption = hasOption(_sKey);  	if (!bHasOption) return _bDefaultValue; @@ -354,20 +302,18 @@ bool XMLNode::getOptionBool(string _sKey, bool _bDefaultValue)  //-----------------------------------------------------------------------------	  // Get option - NUMERICAL ARRAY -vector<float32> XMLNode::getOptionNumericalArray(string _sKey) +vector<float32> XMLNode::getOptionNumericalArray(string _sKey) const  {  	if (!hasOption(_sKey)) return vector<float32>(); -	list<XMLNode*> nodes = getNodes("Option"); -	for (list<XMLNode*>::iterator it = nodes.begin(); it != nodes.end(); it++) { -		if ((*it)->getAttribute("key") == _sKey) { -			vector<float32> vals = (*it)->getContentNumericalArray(); -			deleteNodes(nodes); +	list<XMLNode> nodes = getNodes("Option"); +	for (list<XMLNode>::iterator it = nodes.begin(); it != nodes.end(); it++) { +		if (it->getAttribute("key") == _sKey) { +			vector<float32> vals = it->getContentNumericalArray();  			return vals;  		}  	} -	deleteNodes(nodes);  	return vector<float32>();  } @@ -390,41 +336,40 @@ vector<float32> XMLNode::getOptionNumericalArray(string _sKey)  //-----------------------------------------------------------------------------  // Add child node - EMPTY -XMLNode* XMLNode::addChildNode(string _sNodeName)  +XMLNode XMLNode::addChildNode(string _sNodeName)   {  	xml_document<> *doc = fDOMElement->document();  	char *node_name = doc->allocate_string(_sNodeName.c_str());  	xml_node<> *node = doc->allocate_node(node_element, node_name);  	fDOMElement->append_node(node); -	// TODO: clean up: this 'new' requires callers to do memory management -	return new XMLNode(node); +	return XMLNode(node);  }  //-----------------------------------------------------------------------------  // Add child node - STRING -XMLNode* XMLNode::addChildNode(string _sNodeName, string _sText)  +XMLNode XMLNode::addChildNode(string _sNodeName, string _sText)   { -	XMLNode* res = addChildNode(_sNodeName); -	res->setContent(_sText); +	XMLNode res = addChildNode(_sNodeName); +	res.setContent(_sText);  	return res;  }  //-----------------------------------------------------------------------------  // Add child node - FLOAT -XMLNode* XMLNode::addChildNode(string _sNodeName, float32 _fValue)  +XMLNode XMLNode::addChildNode(string _sNodeName, float32 _fValue)   { -	XMLNode* res = addChildNode(_sNodeName); -	res->setContent(_fValue); +	XMLNode res = addChildNode(_sNodeName); +	res.setContent(_fValue);  	return res;  }  //-----------------------------------------------------------------------------  // Add child node - LIST -XMLNode* XMLNode::addChildNode(string _sNodeName, float32* _pfList, int _iSize)  +XMLNode XMLNode::addChildNode(string _sNodeName, float32* _pfList, int _iSize)   { -	XMLNode* res = addChildNode(_sNodeName); -	res->setContent(_pfList, _iSize); +	XMLNode res = addChildNode(_sNodeName); +	res.setContent(_pfList, _iSize);  	return res;  } @@ -446,15 +391,68 @@ void XMLNode::setContent(float32 _fValue)  //-----------------------------------------------------------------------------	  // Set content - LIST -void XMLNode::setContent(float32* pfList, int _iSize)  -{ + +template<typename T> +static std::string setContentList_internal(T* pfList, int _iSize) {  	std::string str = (_iSize > 0) ? boost::lexical_cast<std::string>(pfList[0]) : "";  	for (int i = 1; i < _iSize; i++) {  		str += "," + boost::lexical_cast<std::string>(pfList[i]);  	} -	setContent(str); +	return str; +} + +void XMLNode::setContent(float32* pfList, int _iSize) +{ +	setContent(setContentList_internal<float32>(pfList, _iSize)); +} + +void XMLNode::setContent(double* pfList, int _iSize) +{ +	setContent(setContentList_internal<double>(pfList, _iSize)); +} + +//-----------------------------------------------------------------------------	 +// Set content - MATRIX + +template<typename T> +static std::string setContentMatrix_internal(T* _pfMatrix, int _iWidth, int _iHeight, bool transposed) +{ +	std::string str = ""; + +	int s1,s2; + +	if (!transposed) { +		s1 = 1; +		s2 = _iWidth; +	} else { +		s1 = _iHeight; +		s2 = 1; +	} + +	for (int y = 0; y < _iHeight; ++y) { +		if (_iWidth > 0) +			str += boost::lexical_cast<std::string>(_pfMatrix[0*s1 + y*s2]); +			for (int x = 1; x < _iWidth; x++) +				str += "," + boost::lexical_cast<std::string>(_pfMatrix[x*s1 + y*s2]); + +		if (y != _iHeight-1) +			str += ";"; +	} + +	return str;  } +void XMLNode::setContent(float32* _pfMatrix, int _iWidth, int _iHeight, bool transposed) +{ +	setContent(setContentMatrix_internal<float32>(_pfMatrix, _iWidth, _iHeight, transposed)); +} + +void XMLNode::setContent(double* _pfMatrix, int _iWidth, int _iHeight, bool transposed) +{ +	setContent(setContentMatrix_internal<double>(_pfMatrix, _iWidth, _iHeight, transposed)); +} + +  //-----------------------------------------------------------------------------	  // Add attribute - STRING  void XMLNode::addAttribute(string _sName, string _sText)  @@ -477,20 +475,18 @@ void XMLNode::addAttribute(string _sName, float32 _fValue)  // Add option - STRING  void XMLNode::addOption(string _sName, string _sText)   { -	XMLNode* node = addChildNode("Option"); -	node->addAttribute("key", _sName); -	node->addAttribute("value", _sText); -	delete node; +	XMLNode node = addChildNode("Option"); +	node.addAttribute("key", _sName); +	node.addAttribute("value", _sText);  }  //-----------------------------------------------------------------------------	  // Add option - FLOAT  void XMLNode::addOption(string _sName, float32 _sText)   { -	XMLNode* node = addChildNode("Option"); -	node->addAttribute("key", _sName); -	node->addAttribute("value", _sText); -	delete node; +	XMLNode node = addChildNode("Option"); +	node.addAttribute("key", _sName); +	node.addAttribute("value", _sText);  }  //-----------------------------------------------------------------------------	 diff --git a/tests/test_Fourier.cpp b/tests/test_Fourier.cpp index 2602edb..ef12747 100644 --- a/tests/test_Fourier.cpp +++ b/tests/test_Fourier.cpp @@ -105,8 +105,8 @@ BOOST_AUTO_TEST_CASE( testFourier_FFT_1D_1 )  {  	astra::float32 inR[8] = { 1.0f, 1.0f, 1.0f, 0.0f, 0.0f, 0.0f, 1.0f, 1.0f };  	astra::float32 inI[8] = { 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f }; -	astra::float32 outR[5]; -	astra::float32 outI[5]; +	astra::float32 outR[8]; +	astra::float32 outI[8];  	astra::fastTwoPowerFourierTransform1D(8, inR, inI, outR, outI, 1, 1, false); diff --git a/tests/test_ParallelBeamLineKernelProjector2D.cpp b/tests/test_ParallelBeamLineKernelProjector2D.cpp index 86bc54f..c56ff37 100644 --- a/tests/test_ParallelBeamLineKernelProjector2D.cpp +++ b/tests/test_ParallelBeamLineKernelProjector2D.cpp @@ -77,6 +77,8 @@ BOOST_FIXTURE_TEST_CASE( testParallelBeamLineKernelProjector2D_Rectangle, TestPa  		fWeight += pPix[i].m_fWeight;  	BOOST_CHECK_SMALL(fWeight - 7.13037f, 0.00001f); + +	delete[] pPix;  } diff --git a/tests/test_XMLDocument.cpp b/tests/test_XMLDocument.cpp index adabdd6..95429cb 100644 --- a/tests/test_XMLDocument.cpp +++ b/tests/test_XMLDocument.cpp @@ -32,18 +32,22 @@ $Id$  #include <boost/test/auto_unit_test.hpp>  #include "astra/XMLDocument.h" +#include "astra/Config.h"  BOOST_AUTO_TEST_CASE( testXMLDocument_Constructor1 )  {  	astra::XMLDocument *doc = astra::XMLDocument::createDocument("test");  	BOOST_REQUIRE(doc); -	astra::XMLNode *root = doc->getRootNode(); +	astra::XMLNode root = doc->getRootNode();  	BOOST_REQUIRE(root); -	BOOST_CHECK(root->getName() == "test"); -	BOOST_CHECK(root->getContent().empty()); +	BOOST_CHECK(root.getName() == "test"); +	BOOST_CHECK(root.getContent().empty()); + +	delete doc; +  }  BOOST_AUTO_TEST_CASE( testXMLDocument_FileIO ) @@ -53,12 +57,15 @@ BOOST_AUTO_TEST_CASE( testXMLDocument_FileIO )  	doc->saveToFile("test.xml");  	astra::XMLDocument *doc2 = astra::XMLDocument::readFromFile("test.xml"); -	astra::XMLNode *root = doc2->getRootNode(); +	astra::XMLNode root = doc2->getRootNode();  	BOOST_REQUIRE(root); -	BOOST_CHECK(root->getName() == "test"); -	BOOST_CHECK(root->getContent().empty()); +	BOOST_CHECK(root.getName() == "test"); +	BOOST_CHECK(root.getContent().empty()); + +	delete doc2; +	delete doc;  } @@ -67,32 +74,28 @@ BOOST_AUTO_TEST_CASE( testXMLDocument_CreateNodes )  	astra::XMLDocument *doc = astra::XMLDocument::createDocument("test");  	BOOST_REQUIRE(doc); -	astra::XMLNode *root = doc->getRootNode(); +	astra::XMLNode root = doc->getRootNode();  	BOOST_REQUIRE(root); -	astra::XMLNode *node = root->addChildNode("child"); +	astra::XMLNode node = root.addChildNode("child");  	BOOST_REQUIRE(node); -	node->addAttribute("attr", "val"); +	node.addAttribute("attr", "val");  	doc->saveToFile("test2.xml"); -	delete node; -	delete root;  	delete doc;  	doc = astra::XMLDocument::readFromFile("test2.xml");  	BOOST_REQUIRE(doc);  	root = doc->getRootNode();  	BOOST_REQUIRE(node); -	node = root->getSingleNode("child"); +	node = root.getSingleNode("child");  	BOOST_REQUIRE(node); -	BOOST_CHECK(node->hasAttribute("attr")); -	BOOST_CHECK(node->getAttribute("attr") == "val"); +	BOOST_CHECK(node.hasAttribute("attr")); +	BOOST_CHECK(node.getAttribute("attr") == "val"); -	delete node; -	delete root;  	delete doc;  } @@ -101,16 +104,18 @@ BOOST_AUTO_TEST_CASE( testXMLDocument_Options )  	astra::XMLDocument *doc = astra::XMLDocument::createDocument("test");  	BOOST_REQUIRE(doc); -	astra::XMLNode *root = doc->getRootNode(); +	astra::XMLNode root = doc->getRootNode();  	BOOST_REQUIRE(root); -	BOOST_CHECK(!root->hasOption("opt")); +	BOOST_CHECK(!root.hasOption("opt")); + +	root.addOption("opt", "val"); -	root->addOption("opt", "val"); +	BOOST_CHECK(root.hasOption("opt")); -	BOOST_CHECK(root->hasOption("opt")); +	BOOST_CHECK(root.getOption("opt") == "val"); -	BOOST_CHECK(root->getOption("opt") == "val"); +	delete doc;  } @@ -119,40 +124,51 @@ BOOST_AUTO_TEST_CASE( testXMLDocument_List )  	astra::XMLDocument *doc = astra::XMLDocument::createDocument("test");  	BOOST_REQUIRE(doc); -	astra::XMLNode *root = doc->getRootNode(); +	astra::XMLNode root = doc->getRootNode();  	BOOST_REQUIRE(root); -	astra::XMLNode *node = root->addChildNode("child"); +	astra::XMLNode node = root.addChildNode("child");  	BOOST_REQUIRE(node);  	float fl[] = { 1.0, 3.5, 2.0, 4.75 }; -	node->setContent(fl, sizeof(fl)/sizeof(fl[0])); +	node.setContent(fl, sizeof(fl)/sizeof(fl[0]));  	doc->saveToFile("test3.xml"); -	delete node; -	delete root;  	delete doc;  	doc = astra::XMLDocument::readFromFile("test3.xml");  	BOOST_REQUIRE(doc);  	root = doc->getRootNode();  	BOOST_REQUIRE(root); -	node = root->getSingleNode("child"); +	node = root.getSingleNode("child");  	BOOST_REQUIRE(node); -	std::vector<astra::float32> f = node->getContentNumericalArray(); +	std::vector<astra::float32> f = node.getContentNumericalArray();  	BOOST_CHECK(f[0] == fl[0]);  	BOOST_CHECK(f[1] == fl[1]);  	BOOST_CHECK(f[2] == fl[2]);  	BOOST_CHECK(f[3] == fl[3]); -	delete node; -	delete root;  	delete doc;  } +BOOST_AUTO_TEST_CASE( testXMLDocument_Config ) +{ +	astra::Config* cfg = new astra::Config(); +	cfg->initialize("VolumeGeometry2D"); + +	cfg->self.addChildNode("GridColCount", 1); +	cfg->self.addChildNode("GridRowCount", 2); + +	cfg->self.addOption("WindowMinX", 3); +	cfg->self.addOption("WindowMaxX", 4); +	cfg->self.addOption("WindowMinY", 5); +	cfg->self.addOption("WindowMaxY", 6); + +	delete cfg; +}  | 
