Nearest Neighbor Classifier. More...
#include <shark/Models/NearestNeighborClassifier.h>
Inheritance diagram for shark::NearestNeighborClassifier< InputType >:Public Types | |
| enum | DistanceWeights { UNIFORM, ONE_OVER_DISTANCE } |
| Type of distance-based weights. More... | |
| typedef AbstractNearestNeighbors< InputType, unsigned int > | NearestNeighbors |
| typedef base_type::BatchInputType | BatchInputType |
| typedef base_type::BatchOutputType | BatchOutputType |
Public Types inherited from shark::AbstractModel< InputType, unsigned int > | |
| enum | Feature |
| typedef InputType | InputType |
| Defines the input type of the model. More... | |
| typedef unsigned int | OutputType |
| Defines the output type of the model. More... | |
| typedef Batch< InputType >::type | BatchInputType |
| defines the batch type of the input type. More... | |
| typedef Batch< OutputType >::type | BatchOutputType |
| defines the batch type of the output type More... | |
| typedef TypedFlags< Feature > | Features |
| typedef TypedFeatureNotAvailableException< Feature > | FeatureNotAvailableException |
Public Member Functions | |
| NearestNeighborClassifier (NearestNeighbors const *algorithm, std::size_t neighbors=3) | |
| Constructor. More... | |
| std::string | name () const |
| From INameable: return the class name. More... | |
| std::size_t | neighbors () const |
| return the number of neighbors More... | |
| void | setNeighbors (std::size_t neighbors) |
| set the number of neighbors More... | |
| DistanceWeights | getDistanceWeightType () const |
| query the way distances enter as weights More... | |
| void | setDistanceWeightType (DistanceWeights dw) |
| set the way distances enter as weights More... | |
| virtual RealVector | parameterVector () const |
| get internal parameters of the model More... | |
| virtual void | setParameterVector (RealVector const &newParameters) |
| set internal parameters of the model More... | |
| virtual std::size_t | numberOfParameters () const |
| return the size of the parameter vector More... | |
| boost::shared_ptr< State > | createState () const |
| Creates an internal state of the model. More... | |
| void | eval (BatchInputType const &patterns, BatchOutputType &output, State &state) const |
| soft k-nearest-neighbor prediction More... | |
| void | read (InArchive &archive) |
| from ISerializable, reads a model from an archive More... | |
| void | write (OutArchive &archive) const |
| from ISerializable, writes a model to an archive More... | |
Public Member Functions inherited from shark::AbstractModel< InputType, unsigned int > | |
| AbstractModel () | |
| virtual | ~AbstractModel () |
| const Features & | features () const |
| virtual void | updateFeatures () |
| bool | hasFirstParameterDerivative () const |
| Returns true when the first parameter derivative is implemented. More... | |
| bool | hasSecondParameterDerivative () const |
| Returns true when the second parameter derivative is implemented. More... | |
| bool | hasFirstInputDerivative () const |
| Returns true when the first input derivative is implemented. More... | |
| bool | hasSecondInputDerivative () const |
| Returns true when the second parameter derivative is implemented. More... | |
| bool | isSequential () const |
| virtual void | eval (BatchInputType const &patterns, BatchOutputType &outputs) const |
| Standard interface for evaluating the response of the model to a batch of patterns. More... | |
| virtual void | eval (InputType const &pattern, OutputType &output) const |
| Standard interface for evaluating the response of the model to a single pattern. More... | |
| Data< OutputType > | operator() (Data< InputType > const &patterns) const |
| Model evaluation as an operator for a whole dataset. This is a convenience function. More... | |
| OutputType | operator() (InputType const &pattern) const |
| Model evaluation as an operator for a single pattern. This is a convenience function. More... | |
| BatchOutputType | operator() (BatchInputType const &patterns) const |
| Model evaluation as an operator for a single pattern. This is a convenience function. More... | |
| virtual void | weightedParameterDerivative (BatchInputType const &pattern, BatchOutputType const &coefficients, State const &state, RealVector &derivative) const |
| calculates the weighted sum of derivatives w.r.t the parameters. More... | |
| virtual void | weightedParameterDerivative (BatchInputType const &pattern, BatchOutputType const &coefficients, Batch< RealMatrix >::type const &errorHessian, State const &state, RealVector &derivative, RealMatrix &hessian) const |
| calculates the weighted sum of derivatives w.r.t the parameters More... | |
| virtual void | weightedInputDerivative (BatchInputType const &pattern, BatchOutputType const &coefficients, State const &state, BatchInputType &derivative) const |
| calculates the weighted sum of derivatives w.r.t the inputs More... | |
| virtual void | weightedInputDerivative (BatchInputType const &pattern, BatchOutputType const &coefficients, typename Batch< RealMatrix >::type const &errorHessian, State const &state, RealMatrix &derivative, Batch< RealMatrix >::type &hessian) const |
| calculates the weighted sum of derivatives w.r.t the inputs More... | |
| virtual void | weightedDerivatives (BatchInputType const &patterns, BatchOutputType const &coefficients, State const &state, RealVector ¶meterDerivative, BatchInputType &inputDerivative) const |
| calculates weighted input and parameter derivative at the same time More... | |
Public Member Functions inherited from shark::IParameterizable | |
| virtual | ~IParameterizable () |
Public Member Functions inherited from shark::INameable | |
| virtual | ~INameable () |
Public Member Functions inherited from shark::ISerializable | |
| virtual | ~ISerializable () |
| Virtual d'tor. More... | |
| void | load (InArchive &archive, unsigned int version) |
| Versioned loading of components, calls read(...). More... | |
| void | save (OutArchive &archive, unsigned int version) const |
| Versioned storing of components, calls write(...). More... | |
| BOOST_SERIALIZATION_SPLIT_MEMBER () | |
Protected Attributes | |
| NearestNeighbors const * | m_algorithm |
| std::size_t | m_classes |
| number of classes More... | |
| std::size_t | m_neighbors |
| number of neighbors to be taken into account More... | |
| DistanceWeights | m_distanceWeights |
| type of distance-based weights computation More... | |
Protected Attributes inherited from shark::AbstractModel< InputType, unsigned int > | |
| Features | m_features |
Nearest Neighbor Classifier.
This model requires the use of one of sharks nearest neighhbor Algorithms.
Definition at line 56 of file NearestNeighborClassifier.h.
| typedef base_type::BatchInputType shark::NearestNeighborClassifier< InputType >::BatchInputType |
Definition at line 61 of file NearestNeighborClassifier.h.
| typedef base_type::BatchOutputType shark::NearestNeighborClassifier< InputType >::BatchOutputType |
Definition at line 62 of file NearestNeighborClassifier.h.
| typedef AbstractNearestNeighbors<InputType,unsigned int> shark::NearestNeighborClassifier< InputType >::NearestNeighbors |
Definition at line 59 of file NearestNeighborClassifier.h.
| enum shark::NearestNeighborClassifier::DistanceWeights |
Type of distance-based weights.
| Enumerator | |
|---|---|
| UNIFORM | uniform (= no) distance-based weights |
| ONE_OVER_DISTANCE | weight each neighbor's label with 1/distance |
Definition at line 65 of file NearestNeighborClassifier.h.
|
inline |
Constructor.
| algorithm | the used algorithm for nearst neighbor search |
| neighbors | number of neighbors |
Definition at line 75 of file NearestNeighborClassifier.h.
|
inlinevirtual |
Creates an internal state of the model.
The state is needed when the derivatives are to be calculated. Eval can store a state which is then reused to speed up the calculations of the derivatives. This also allows eval to be evaluated in parallel!
Reimplemented from shark::AbstractModel< InputType, unsigned int >.
Definition at line 126 of file NearestNeighborClassifier.h.
References shark::AbstractModel< InputType, unsigned int >::eval().
|
inlinevirtual |
soft k-nearest-neighbor prediction
Implements shark::AbstractModel< InputType, unsigned int >.
Definition at line 133 of file NearestNeighborClassifier.h.
References shark::AbstractNearestNeighbors< InputType, LabelType >::getNeighbors(), shark::NearestNeighborClassifier< InputType >::m_algorithm, shark::NearestNeighborClassifier< InputType >::m_classes, shark::NearestNeighborClassifier< InputType >::m_distanceWeights, shark::NearestNeighborClassifier< InputType >::m_neighbors, shark::NearestNeighborClassifier< InputType >::neighbors(), shark::size(), and shark::NearestNeighborClassifier< InputType >::UNIFORM.
|
inline |
query the way distances enter as weights
Definition at line 98 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_distanceWeights.
|
inlinevirtual |
From INameable: return the class name.
Reimplemented from shark::INameable.
Definition at line 83 of file NearestNeighborClassifier.h.
Referenced by main().
|
inline |
return the number of neighbors
Definition at line 88 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_neighbors.
Referenced by shark::NearestNeighborClassifier< InputType >::eval(), and shark::NearestNeighborClassifier< InputType >::setNeighbors().
|
inlinevirtual |
return the size of the parameter vector
Reimplemented from shark::IParameterizable.
Definition at line 122 of file NearestNeighborClassifier.h.
|
inlinevirtual |
get internal parameters of the model
Reimplemented from shark::IParameterizable.
Definition at line 106 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_neighbors, and shark::blas::parameters().
|
inlinevirtual |
from ISerializable, reads a model from an archive
Reimplemented from shark::AbstractModel< InputType, unsigned int >.
Definition at line 156 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_classes, and shark::NearestNeighborClassifier< InputType >::m_neighbors.
|
inline |
set the way distances enter as weights
Definition at line 102 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_distanceWeights.
|
inline |
set the number of neighbors
Definition at line 93 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_neighbors, and shark::NearestNeighborClassifier< InputType >::neighbors().
|
inlinevirtual |
set internal parameters of the model
Reimplemented from shark::IParameterizable.
Definition at line 113 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_neighbors, and SHARK_CHECK.
|
inlinevirtual |
from ISerializable, writes a model to an archive
Reimplemented from shark::AbstractModel< InputType, unsigned int >.
Definition at line 162 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_classes, and shark::NearestNeighborClassifier< InputType >::m_neighbors.
|
protected |
Definition at line 168 of file NearestNeighborClassifier.h.
Referenced by shark::NearestNeighborClassifier< InputType >::eval().
|
protected |
number of classes
Definition at line 171 of file NearestNeighborClassifier.h.
Referenced by shark::NearestNeighborClassifier< InputType >::eval(), shark::NearestNeighborClassifier< InputType >::read(), and shark::NearestNeighborClassifier< InputType >::write().
|
protected |
type of distance-based weights computation
Definition at line 177 of file NearestNeighborClassifier.h.
Referenced by shark::NearestNeighborClassifier< InputType >::eval(), shark::NearestNeighborClassifier< InputType >::getDistanceWeightType(), and shark::NearestNeighborClassifier< InputType >::setDistanceWeightType().
|
protected |
number of neighbors to be taken into account
Definition at line 174 of file NearestNeighborClassifier.h.
Referenced by shark::NearestNeighborClassifier< InputType >::eval(), shark::NearestNeighborClassifier< InputType >::neighbors(), shark::NearestNeighborClassifier< InputType >::parameterVector(), shark::NearestNeighborClassifier< InputType >::read(), shark::NearestNeighborClassifier< InputType >::setNeighbors(), shark::NearestNeighborClassifier< InputType >::setParameterVector(), and shark::NearestNeighborClassifier< InputType >::write().