Nearest Neighbor Classifier. More...
#include <shark/Models/NearestNeighborClassifier.h>
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 123 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 130 of file NearestNeighborClassifier.h.
References shark::batchSize(), 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(), 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 119 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.
|
inlinevirtual |
from ISerializable, reads a model from an archive
Reimplemented from shark::AbstractModel< InputType, unsigned int >.
Definition at line 153 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_RUNTIME_CHECK.
|
inlinevirtual |
from ISerializable, writes a model to an archive
Reimplemented from shark::AbstractModel< InputType, unsigned int >.
Definition at line 159 of file NearestNeighborClassifier.h.
References shark::NearestNeighborClassifier< InputType >::m_classes, and shark::NearestNeighborClassifier< InputType >::m_neighbors.
|
protected |
Definition at line 165 of file NearestNeighborClassifier.h.
Referenced by shark::NearestNeighborClassifier< InputType >::eval().
|
protected |
number of classes
Definition at line 168 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 174 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 171 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().