** This is part of the CTSim program
** Copyright (C) 1983-2000 Kevin Rosenberg
**
-** $Id: backprojectors.cpp,v 1.18 2000/12/06 15:17:51 kevin Exp $
+** $Id: backprojectors.cpp,v 1.21 2001/01/01 10:14:34 kevin Exp $
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License (version 2) as
{
{"Nearest"},
{"Linear"},
- {"Frequency Preinterpolationj"},
+ {"Frequency Preinterpolation"},
#if HAVE_BSPLINE_INTERP
{"B-Spline"},
{"B-Spline 1st Order"},
nDet = proj.nDet();
iDetCenter = (nDet - 1) / 2; // index refering to L=0 projection
rotScale = proj.rotInc();
- rotScale /= (proj.nView() * proj.rotInc() / PI); // scale by number of PI rotations
+
+ if (proj.geometry() == Scanner::GEOMETRY_PARALLEL)\r
+ rotScale /= (proj.nView() * proj.rotInc() / PI); // scale by number of PI rotations\r
+ else if (proj.geometry() == Scanner::GEOMETRY_EQUIANGULAR || proj.geometry() == Scanner::GEOMETRY_EQUILINEAR)\r
+ rotScale /= (proj.nView() * proj.rotInc() / (2 * PI)); // scale by number of 2PI rotations\r
+ else\r
+ sys_error (ERR_SEVERE, "Invalid geometry type %d [Backproject::Backproject]", proj.geometry());\r
v = im.getArray();
nx = im.nx();
void Backproject::errorIndexOutsideDetector (int ix, int iy, double theta, double L, int iDetPos)
{\r
#if 1
- ostringstream os;
+ std::ostringstream os;
os << "ix=" << ix << ", iy=" << iy << ", theta=" << theta << ", L=" << L << ", detinc=" << detInc << "\n";
os << "ndet=" << nDet << ", detInc=" << detInc << ", iDetCenter=" << iDetCenter << "\n";
os << "xMin=" << xMin << ", xMax=" << xMax << ", xInc=" << xInc << "\n";