https://github.com/ElsevierSoftwareX/SOFTX_2019_219
Raw File
Tip revision: 99932db9e71d31a76425d68eef7d5859523ca0e4 authored by Konrad Werys on 04 November 2019, 09:33:32 UTC
doc: changes in the documentation
Tip revision: 99932db
OxTestItkImagesFactory.hxx
/*!
 * \file itkOxTestImage.hxx
 * \author Konrad Werys
 * \date 2018/08/13
 */

#ifndef Tomato_itkOxTestImage_HXX
#define Tomato_itkOxTestImage_HXX

#include "CmakeConfigForTomato.h"
#ifdef USE_ITK


namespace Ox {

    template< typename MeasureType >
    TestItkImagesFactory< MeasureType >
    ::TestItkImagesFactory(int nRows, int nCols, std::vector <std::string> filesPaths, std::vector<int> invTimesOrder){
        _testImage = new TestImage< MeasureType >(nRows, nCols, filesPaths, invTimesOrder);
    }

    template< typename MeasureType >
    TestItkImagesFactory< MeasureType >
    ::TestItkImagesFactory(int nRows, int nCols, std::vector <std::string> filesPaths){
        _testImage = new TestImage< MeasureType >(nRows, nCols, filesPaths);
    }

    template< typename MeasureType >
    TestItkImagesFactory< MeasureType >
    ::~TestItkImagesFactory(){
        delete _testImage;
    }

    template< typename MeasureType >
    int
    TestItkImagesFactory< MeasureType >
    ::getNSamples() const {
        return _testImage->getNSamples();
    }

    template< typename MeasureType >
    MeasureType*
    TestItkImagesFactory< MeasureType >
    ::getInvTimesPtr(){
        return _testImage->getInvTimesPtr();
    }

    template< typename MeasureType >
    std::vector<MeasureType>
    TestItkImagesFactory< MeasureType >
    ::getInvTimes() const{
        return _testImage->getInvTimes();
    }

    template< typename MeasureType >
    vnl_vector<MeasureType>
    TestItkImagesFactory< MeasureType >
    :: getInvTimesVnl() const{
        return vnl_vector<MeasureType>(_testImage->getInvTimesPtr(), _testImage->getNSamples());
    }


    template< typename MeasureType >
    typename itk::Image< MeasureType, 3 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImageMag(){
        typename itk::Image< MeasureType, 3 >::Pointer image = generateImage3d();
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 3 > > imageIterator(image, image->GetLargestPossibleRegion());
        copyBufferToImage3d(image, _testImage->getImageMagPtr());
        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 3 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImagePha(){
        typename itk::Image< MeasureType, 3 >::Pointer image = generateImage3d();
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 3 > > imageIterator(image, image->GetLargestPossibleRegion());
        copyBufferToImage3d(image, _testImage->getImagePhaPtr());
        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 2 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImageResultsMolliA(){
        typename itk::Image< MeasureType, 2 >::Pointer image = generateImage2d();
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 2 > > imageIterator(image, image->GetLargestPossibleRegion());
        copyBufferToImage2d(image, _testImage->getImageResultsMolliPtr());
        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 2 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImageResultsMolliB(){
        typename itk::Image< MeasureType, 2 >::Pointer image = generateImage2d();
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 2 > > imageIterator(image, image->GetLargestPossibleRegion());
        int nRows = _testImage->getNRows();
        int nCols = _testImage->getNCols();
        // shift pointer to point to 2rd element of the array
        MeasureType *pointer = _testImage->getImageResultsMolliPtr() + nRows*nCols;
        copyBufferToImage2d(image, pointer);
        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 2 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImageResultsMolliT1star(){
        typename itk::Image< MeasureType, 2 >::Pointer image = generateImage2d();
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 2 > > imageIterator(image, image->GetLargestPossibleRegion());
        int nRows = _testImage->getNRows();
        int nCols = _testImage->getNCols();
        // shift pointer to point to 3rd element of the array
        MeasureType *pointer = _testImage->getImageResultsMolliPtr() + 2*nRows*nCols;
        copyBufferToImage2d(image, pointer);
        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 2 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImageResultsShmolliA(){
        typename itk::Image< MeasureType, 2 >::Pointer image = generateImage2d();
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 2 > > imageIterator(image, image->GetLargestPossibleRegion());
        copyBufferToImage2d(image, _testImage->getImageResultsShmolliPtr());
        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 2 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImageResultsShmolliB(){
        typename itk::Image< MeasureType, 2 >::Pointer image = generateImage2d();
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 2 > > imageIterator(image, image->GetLargestPossibleRegion());
        int nRows = _testImage->getNRows();
        int nCols = _testImage->getNCols();
        // shift pointer to point to 2rd element of the array
        MeasureType *pointer = _testImage->getImageResultsShmolliPtr() + nRows*nCols;
        copyBufferToImage2d(image, pointer);
        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 2 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImageResultsShmolliT1star(){
        typename itk::Image< MeasureType, 2 >::Pointer image = generateImage2d();
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 2 > > imageIterator(image, image->GetLargestPossibleRegion());
        int nRows = _testImage->getNRows();
        int nCols = _testImage->getNCols();
        // shift pointer to point to 3rd element of the array
        MeasureType *pointer = _testImage->getImageResultsShmolliPtr() + 2*nRows*nCols;
        copyBufferToImage2d(image, pointer);
        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 2 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImage2d(){

        typename itk::Image< MeasureType, 2 >::RegionType region;
        typename itk::Image< MeasureType, 2 >::IndexType start;
        start[0] = 0;
        start[1] = 0;

        typename itk::Image< MeasureType, 2 >::SizeType size;
        size[0] = _testImage->getNCols();
        size[1] = _testImage->getNRows();

        region.SetSize(size);
        region.SetIndex(start);

        typename itk::Image< MeasureType, 2 >::Pointer image = itk::Image< MeasureType, 2 >::New();
        image->SetRegions(region);
        image->Allocate();
        image->FillBuffer(0);

        return image;
    };

    template< typename MeasureType >
    typename itk::Image< MeasureType, 3 >::Pointer
    TestItkImagesFactory< MeasureType >
    ::generateImage3d(){

        typename itk::Image< MeasureType, 3 >::RegionType region;
        typename itk::Image< MeasureType, 3 >::IndexType start;
        start[0] = 0;
        start[1] = 0;
        start[2] = 0;

        typename itk::Image< MeasureType, 3 >::SizeType size;
        size[0] = _testImage->getNCols();
        size[1] = _testImage->getNRows();
        size[2] = _testImage->getNSamples();

        region.SetSize(size);
        region.SetIndex(start);

        typename itk::Image< MeasureType, 3 >::Pointer image = itk::Image< MeasureType, 3 >::New();
        image->SetRegions(region);
        image->Allocate();
        image->FillBuffer(0);

        return image;
    };

    template< typename MeasureType >
    void
    TestItkImagesFactory< MeasureType >
    ::copyBufferToImage2d(typename itk::Image< MeasureType, 2 >::Pointer image, MeasureType* buffer) {
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 2 > > imageIterator(image, image->GetLargestPossibleRegion());

        int nRows = _testImage->getNRows();
        int nCols = _testImage->getNCols();
        while(!imageIterator.IsAtEnd())
        {
            int iCol = imageIterator.GetIndex()[0];
            int iRow = imageIterator.GetIndex()[1];
            //imageIterator.Set(buffer[iCol * nRows + iRow]);
            imageIterator.Set(buffer[iRow * nCols + iCol]);
            ++imageIterator;
        }
    }

    template< typename MeasureType >
    void
    TestItkImagesFactory< MeasureType >
    ::copyBufferToImage3d(typename itk::Image< MeasureType, 3 >::Pointer image, MeasureType* buffer) {
        itk::ImageRegionIteratorWithIndex<itk::Image< MeasureType, 3 > > imageIterator(image, image->GetLargestPossibleRegion());

        int nRows = _testImage->getNRows();
        int nCols = _testImage->getNCols();
        while(!imageIterator.IsAtEnd())
        {
            int iCol = imageIterator.GetIndex()[0];
            int iRow = imageIterator.GetIndex()[1];
            int iSample = imageIterator.GetIndex()[2];
            //imageIterator.Set(buffer[iSample * nRows * nCols+ iCol * nRows + iRow]);
            imageIterator.Set(buffer[iSample * nRows * nCols+ iRow * nCols + iCol]);
            ++imageIterator;
        }
    }
} // namespace Ox


#endif // USE_ITK

#endif //Tomato_itkOxTestImage_HXX
back to top