📄 itktwohiddenlayerbackpropagationneuralnetwork.h
字号:
/*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: $RCSfile: itkTwoHiddenLayerBackPropagationNeuralNetwork.h,v $
Language: C++
Date: $Date: 2007-08-17 13:10:57 $
Version: $Revision: 1.6 $
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
#ifndef __itkTwoHiddenLayerBackPropNeuralNetworkBase_h
#define __itkTwoHiddenLayerBackPropNeuralNetworkBase_h
#include "itkMultilayerNeuralNetworkBase.h"
#include "itkBackPropagationLayer.h"
#include "itkSigmoidTransferFunction.h"
#include "itkLogSigmoidTransferFunction.h"
#include "itkTanSigmoidTransferFunction.h"
#include "itkHardLimitTransferFunction.h"
#include "itkSignedHardLimitTransferFunction.h"
#include "itkGaussianTransferFunction.h"
#include "itkIdentityTransferFunction.h"
#include "itkSumInputFunction.h"
#include "itkProductInputFunction.h"
namespace itk
{
namespace Statistics
{
template<class TMeasurementVector, class TTargetVector>
class TwoHiddenLayerBackPropagationNeuralNetwork :
public MultilayerNeuralNetworkBase<TMeasurementVector, TTargetVector, BackPropagationLayer<TMeasurementVector, TTargetVector> >
{
public:
typedef TwoHiddenLayerBackPropagationNeuralNetwork Self;
typedef MultilayerNeuralNetworkBase<TMeasurementVector, TTargetVector, BackPropagationLayer<TMeasurementVector, TTargetVector> > Superclass;
typedef SmartPointer<Self> Pointer;
typedef SmartPointer<const Self> ConstPointer;
typedef typename Superclass::ValueType ValueType;
typedef typename Superclass::MeasurementVectorType MeasurementVectorType;
typedef typename Superclass::TargetVectorType TargetVectorType;
typedef typename Superclass::NetworkOutputType NetworkOutputType;
typedef typename Superclass::LayerInterfaceType LayerInterfaceType;
typedef typename Superclass::LearningLayerType LearningLayerType;
typedef typename Superclass::WeightVectorType WeightVectorType;
typedef typename Superclass::LayerVectorType LayerVectorType;
typedef typename Superclass::TransferFunctionInterfaceType TransferFunctionInterfaceType;
typedef typename Superclass::InputFunctionInterfaceType InputFunctionInterfaceType;
/* Method for creation through the object factory. */
itkTypeMacro(TwoHiddenLayerBackPropagationNeuralNetwork,
MultilayerNeuralNetworkBase);
itkNewMacro(Self) ;
//Add the layers to the network.
// 1 input, 2 hidden, 1 output
void Initialize();
itkSetMacro(NumOfInputNodes, unsigned int);
itkGetConstReferenceMacro(NumOfInputNodes, unsigned int);
itkSetMacro(NumOfFirstHiddenNodes, unsigned int);
itkGetConstReferenceMacro(NumOfFirstHiddenNodes, unsigned int);
itkSetMacro(NumOfSecondHiddenNodes, unsigned int);
itkGetConstReferenceMacro(NumOfSecondHiddenNodes,unsigned int);
//#define __USE_OLD_INTERFACE Comment out to ensure that new interface works
#ifdef __USE_OLD_INTERFACE
//Original Function name before consistency naming changes
inline void SetNumOfHiddenNodes1(unsigned int x) { SetNumOfFirstHiddenNodes(x); }
inline unsigned int GetNumOfHiddenNodes1(void) const { return GetNumOfFirstHiddenNodes(); }
inline void SetNumOfHiddenNodes2(unsigned int x) { SetNumOfSecondHiddenNodes(x); }
inline unsigned int GetNumOfHiddenNodes2(void) const { return GetNumOfSecondHiddenNodes(); }
#endif
itkSetMacro(NumOfOutputNodes, unsigned int);
itkGetConstReferenceMacro(NumOfOutputNodes, unsigned int);
itkSetMacro(FirstHiddenLayerBias, ValueType);
itkGetConstReferenceMacro(FirstHiddenLayerBias, ValueType);
itkSetMacro(SecondHiddenLayerBias, ValueType);
itkGetConstReferenceMacro(SecondHiddenLayerBias, ValueType);
itkSetMacro(OutputLayerBias, ValueType);
itkGetConstReferenceMacro(OutputLayerBias, ValueType);
virtual NetworkOutputType GenerateOutput(TMeasurementVector samplevector);
void SetInputFunction(InputFunctionInterfaceType* f);
void SetInputTransferFunction(TransferFunctionInterfaceType* f);
void SetFirstHiddenTransferFunction(TransferFunctionInterfaceType* f);
void SetSecondHiddenTransferFunction(TransferFunctionInterfaceType* f);
void SetOutputTransferFunction(TransferFunctionInterfaceType* f);
protected:
TwoHiddenLayerBackPropagationNeuralNetwork();
virtual ~TwoHiddenLayerBackPropagationNeuralNetwork() {};
/** Method to print the object. */
virtual void PrintSelf( std::ostream& os, Indent indent ) const;
private:
unsigned int m_NumOfInputNodes;
unsigned int m_NumOfFirstHiddenNodes;
unsigned int m_NumOfSecondHiddenNodes;
unsigned int m_NumOfOutputNodes;
ValueType m_FirstHiddenLayerBias;
ValueType m_SecondHiddenLayerBias;
ValueType m_OutputLayerBias;
typename InputFunctionInterfaceType::Pointer m_InputFunction;
typename TransferFunctionInterfaceType::Pointer m_InputTransferFunction;
typename TransferFunctionInterfaceType::Pointer m_FirstHiddenTransferFunction;
typename TransferFunctionInterfaceType::Pointer m_SecondHiddenTransferFunction;
typename TransferFunctionInterfaceType::Pointer m_OutputTransferFunction;
};
} // end namespace Statistics
} // end namespace itk
#ifndef ITK_MANUAL_INSTANTIATION
#include "itkTwoHiddenLayerBackPropagationNeuralNetwork.txx"
#endif
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -