/*========================================================================= * * 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 itkGaussianRandomSpatialNeighborSubsampler_hxx #define itkGaussianRandomSpatialNeighborSubsampler_hxx namespace itk { namespace Statistics { template GaussianRandomSpatialNeighborSubsampler::GaussianRandomSpatialNeighborSubsampler() { m_Variance = DefaultVariance; } template typename LightObject::Pointer GaussianRandomSpatialNeighborSubsampler::InternalClone() const { typename LightObject::Pointer loPtr = Superclass::InternalClone(); typename Self::Pointer rval = dynamic_cast(loPtr.GetPointer()); if (rval.IsNull()) { itkExceptionMacro("downcast to type " << this->GetNameOfClass() << " failed."); } rval->m_Variance = this->m_Variance; return loPtr; } template auto GaussianRandomSpatialNeighborSubsampler::GetIntegerVariate(RandomIntType lowerBound, RandomIntType upperBound, RandomIntType mean) -> RandomIntType { if (upperBound < lowerBound) { itkExceptionMacro("upperBound (" << upperBound << ") not >= to lowerBound(" << lowerBound << ')'); } RandomIntType randInt = 0; do { RealType randVar = this->m_RandomNumberGenerator->GetNormalVariate(mean, m_Variance); randInt = static_cast(std::floor(randVar)); } while ((randInt < lowerBound) || (randInt > upperBound)); return randInt; } template void GaussianRandomSpatialNeighborSubsampler::PrintSelf(std::ostream & os, Indent indent) const { Superclass::PrintSelf(os, indent); os << indent << "Gaussian variance: " << m_Variance << std::endl; os << std::endl; } } // end namespace Statistics } // end namespace itk #endif