/*========================================================================= * * Copyright NumFOCUS * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * https://www.apache.org/licenses/LICENSE-2.0.txt * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * *=========================================================================*/ #ifndef itkImageToListSampleAdaptor_hxx #define itkImageToListSampleAdaptor_hxx namespace itk { namespace Statistics { template ImageToListSampleAdaptor::ImageToListSampleAdaptor() { m_Image = nullptr; } template auto ImageToListSampleAdaptor::GetMeasurementVector(InstanceIdentifier id) const -> const MeasurementVectorType & { if (m_Image.IsNull()) { itkExceptionMacro("Image has not been set yet"); } MeasurementVectorTraits::Assign(m_MeasurementVectorInternal, m_Image->GetPixel(m_Image->ComputeIndex(id))); return m_MeasurementVectorInternal; } /** returns the number of measurement vectors in this container*/ template auto ImageToListSampleAdaptor::Size() const -> InstanceIdentifier { if (m_Image.IsNull()) { itkExceptionMacro("Image has not been set yet"); } return m_Image->GetLargestPossibleRegion().GetNumberOfPixels(); } template inline auto ImageToListSampleAdaptor::GetFrequency(InstanceIdentifier) const -> AbsoluteFrequencyType { if (m_Image.IsNull()) { itkExceptionMacro("Image has not been set yet"); } return NumericTraits::OneValue(); } template void ImageToListSampleAdaptor::PrintSelf(std::ostream & os, Indent indent) const { Superclass::PrintSelf(os, indent); os << indent << "Image: "; if (m_Image.IsNotNull()) { os << m_Image << std::endl; } else { os << "not set." << std::endl; } os << indent << "MeasurementVectorSize: "; if (m_Image.IsNotNull()) { os << this->GetMeasurementVectorSize() << std::endl; } else { os << "not set." << std::endl; } } template void ImageToListSampleAdaptor::SetImage(const TImage * image) { m_Image = image; this->Modified(); } template const TImage * ImageToListSampleAdaptor::GetImage() const { if (m_Image.IsNull()) { itkExceptionMacro("Image has not been set yet"); } return m_Image.GetPointer(); } template auto ImageToListSampleAdaptor::GetTotalFrequency() const -> TotalAbsoluteFrequencyType { if (m_Image.IsNull()) { itkExceptionMacro("Image has not been set yet"); } return this->Size(); } } // end of namespace Statistics } // end of namespace itk #endif