X-Git-Url: http://git.kpe.io/?p=ctsim.git;a=blobdiff_plain;f=libctsim%2Fphantom.cpp;h=467c8e90d5f4eab03f48533433240384ebda42f2;hp=b74e531930a067cbc295b0b36a7075e29b77d9f8;hb=c00c639073653fac7463a88f2b000f263236550d;hpb=23b7ef994fc5d95fcca6d4ae69abbd5971101262 diff --git a/libctsim/phantom.cpp b/libctsim/phantom.cpp index b74e531..467c8e9 100644 --- a/libctsim/phantom.cpp +++ b/libctsim/phantom.cpp @@ -9,7 +9,7 @@ ** This is part of the CTSim program ** Copyright (C) 1983-2000 Kevin Rosenberg ** -** $Id: phantom.cpp,v 1.25 2001/01/02 07:47:36 kevin Exp $ +** $Id: phantom.cpp,v 1.26 2001/01/02 16:02:13 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 @@ -27,8 +27,8 @@ #include "ct.h" -const int PhantomElement::POINTS_PER_CIRCLE = 360; -const double PhantomElement::SCALE_PELEM_EXTENT=0.005; // increase pelem limits by 0.5% +const int PhantomElement::POINTS_PER_CIRCLE = 360; +const double PhantomElement::SCALE_PELEM_EXTENT=0.005; // increase pelem limits by 0.5% const int Phantom::PHM_INVALID = -1; const int Phantom::PHM_HERMAN = 0; @@ -226,15 +226,15 @@ Phantom::createFromFile (const char* const fname) return (bGoodFile); } -bool -Phantom::fileWrite (const char* const fname) -{ - fstream file (fname, ios::out); - - if (! file.fail()) - printDefinitions (file); - return ! file.fail(); -} +bool +Phantom::fileWrite (const char* const fname) +{ + fstream file (fname, ios::out); + + if (! file.fail()) + printDefinitions (file); + return ! file.fail(); +} /* NAME * addPElem Add pelem @@ -288,12 +288,12 @@ Phantom::print (std::ostream& os) const os << "Number of PElements: " << m_nPElem << "\n"; os << "Limits: xmin=" << m_xmin << ", ymin=" << m_ymin << ", xmax=" << m_xmax << ", ymax=" << m_ymax << "\n"; - for (PElemConstIterator i = m_listPElem.begin(); i != m_listPElem.end(); i++) { + for (PElemConstIterator i = m_listPElem.begin(); i != m_listPElem.end(); i++) { const PhantomElement& rPE = **i; - os << "PhantomElement: nPoints=" << rPE.nOutlinePoints(); + os << "PhantomElement: nPoints=" << rPE.nOutlinePoints(); os << ", atten=" << rPE.atten() << " rot=" << convertRadiansToDegrees (rPE.rot()) << "\n"; os << "xmin=" << rPE.xmin() << ", ymin=" << rPE.ymin() << ", xmax=" << rPE.xmax() << ", ymax=" << rPE.ymax() << "\n"; - + if (false) for (int i = 0; i < rPE.nOutlinePoints(); i++) os << rPE.xOutline()[i] << "," << rPE.yOutline()[i] << "\n"; @@ -305,36 +305,36 @@ Phantom::print (std::ostringstream& os) const os << "Number of PElements: " << m_nPElem << "\n"; os << "Limits: xmin=" << m_xmin << ", ymin=" << m_ymin << ", xmax=" << m_xmax << ", ymax=" << m_ymax << "\n"; - for (PElemConstIterator i = m_listPElem.begin(); i != m_listPElem.end(); i++) { + for (PElemConstIterator i = m_listPElem.begin(); i != m_listPElem.end(); i++) { const PhantomElement& rPE = **i; - os << "PhantomElement: nPoints=" << rPE.nOutlinePoints(); + os << "PhantomElement: nPoints=" << rPE.nOutlinePoints(); os << ", atten=" << rPE.atten() << " rot=" << convertRadiansToDegrees (rPE.rot()) << "\n"; os << "xmin=" << rPE.xmin() << ", ymin=" << rPE.ymin() << ", xmax=" << rPE.xmax() << ", ymax=" << rPE.ymax() << "\n"; - + if (false) for (int i = 0; i < rPE.nOutlinePoints(); i++) os << rPE.xOutline()[i] << "," << rPE.yOutline()[i] << "\n"; } } - -void -Phantom::printDefinitions (std::ostream& os) const -{ - for (PElemConstIterator i = m_listPElem.begin(); i != m_listPElem.end(); i++) { - const PhantomElement& rPE = **i; - rPE.printDefinition (os); - } -} - -void -Phantom::printDefinitions (std::ostringstream& os) const -{ - for (PElemConstIterator i = m_listPElem.begin(); i != m_listPElem.end(); i++) { - const PhantomElement& rPE = **i; - rPE.printDefinition (os); - } -} - + +void +Phantom::printDefinitions (std::ostream& os) const +{ + for (PElemConstIterator i = m_listPElem.begin(); i != m_listPElem.end(); i++) { + const PhantomElement& rPE = **i; + rPE.printDefinition (os); + } +} + +void +Phantom::printDefinitions (std::ostringstream& os) const +{ + for (PElemConstIterator i = m_listPElem.begin(); i != m_listPElem.end(); i++) { + const PhantomElement& rPE = **i; + rPE.printDefinition (os); + } +} + /* NAME * show Show vector outline of Phantom to user @@ -550,13 +550,13 @@ Phantom::convertToImagefile (ImageFile& im, const int in_nsample, const int trac if (nsample > 1) { double factor = 1.0 / static_cast(nsample * nsample); - + for (int ix = 0; ix < colCount; ix++) { - int iColStore = ix; - if (bStoreAtColumnPos) - iColStore += colStart; + int iColStore = ix; + if (bStoreAtColumnPos) + iColStore += colStart; for (int iy = 0; iy < ny; iy++) - v[iColStore][iy] *= factor; + v[iColStore][iy] *= factor; } } } @@ -594,27 +594,27 @@ PhantomElement::PhantomElement (const char *type, const double cx, const double m_rectLimits[2] = m_xmax; m_rectLimits[3] = m_ymax; } - + PhantomElement::~PhantomElement () { delete m_xOutline; delete m_yOutline; } - -void -PhantomElement::printDefinition (std::ostream& os) const -{ - os << convertTypeToName (m_type) << " " << m_cx << " " << m_cy << " " << m_u << " " - << m_v << " " << convertRadiansToDegrees (m_rot) << " " << m_atten << "\n"; -} - -void -PhantomElement::printDefinition (std::ostringstream& os) const -{ - os << convertTypeToName (m_type) << " " << m_cx << " " << m_cy << " " << m_u << " " - << m_v << " " << convertRadiansToDegrees (m_rot) << " " << m_atten << "\n"; -} + +void +PhantomElement::printDefinition (std::ostream& os) const +{ + os << convertTypeToName (m_type) << " " << m_cx << " " << m_cy << " " << m_u << " " + << m_v << " " << convertRadiansToDegrees (m_rot) << " " << m_atten << "\n"; +} + +void +PhantomElement::printDefinition (std::ostringstream& os) const +{ + os << convertTypeToName (m_type) << " " << m_cx << " " << m_cy << " " << m_u << " " + << m_v << " " << convertRadiansToDegrees (m_rot) << " " << m_atten << "\n"; +} PhmElemType PhantomElement::convertNameToType (const char* const typeName) @@ -636,26 +636,26 @@ PhantomElement::convertNameToType (const char* const typeName) return (type); } - -const char* const -PhantomElement::convertTypeToName (PhmElemType iType) -{ - static char* pszType = "Unknown"; - - if (iType == PELEM_RECTANGLE) - pszType = "rectangle"; - else if (iType == PELEM_TRIANGLE) - pszType = "triangle"; - else if (iType == PELEM_ELLIPSE) - pszType = "ellipse"; - else if (iType == PELEM_SECTOR) - pszType = "sector"; - else if (iType == PELEM_SEGMENT) - pszType = "segment"; - - return pszType; -} - + +const char* const +PhantomElement::convertTypeToName (PhmElemType iType) +{ + static char* pszType = "Unknown"; + + if (iType == PELEM_RECTANGLE) + pszType = "rectangle"; + else if (iType == PELEM_TRIANGLE) + pszType = "triangle"; + else if (iType == PELEM_ELLIPSE) + pszType = "ellipse"; + else if (iType == PELEM_SECTOR) + pszType = "sector"; + else if (iType == PELEM_SEGMENT) + pszType = "segment"; + + return pszType; +} + void PhantomElement::makeTransformMatrices ()