-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathNeuralLayer.hpp
66 lines (50 loc) · 1.62 KB
/
NeuralLayer.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#pragma once
#include "neuro_global.hpp"
#include "DataTransformation.hpp"
#include "Neuron.hpp"
#include <QMetaType>
#include <QVector>
class NEUROSHARED_EXPORT NeuralLayer: public DataTransformation
{
public:
NeuralLayer()=default;
NeuralLayer(const NeuralLayer &)=default;
NeuralLayer(NeuralLayer &&)=default;
NeuralLayer &operator=(const NeuralLayer &)=default;
NeuralLayer &operator=(NeuralLayer &&)=default;
void swap(NeuralLayer &neuralLayer) noexcept;
bool empty() const;
int neuronNumber() const;
Neuron &neuron(const int index);
const Neuron &neuron(const int index) const;
void pushFront(const Neuron &neuron);
void pushBack(const Neuron &neuron);
void popFront();
void popBack();
void clear();
void setActivationFunction(const ActivationFunctionPointer &activationFunction);
int inputNumber() const override;
int outputNumber() const override;
protected:
DataVector transform_(const DataVector &input) const override;
private:
inline friend QVector<Neuron>::iterator begin(NeuralLayer &neuralLayer)
{
return neuralLayer.m_neurons.begin();
}
inline friend QVector<Neuron>::const_iterator begin(const NeuralLayer &neuralLayer)
{
return neuralLayer.m_neurons.begin();
}
inline friend QVector<Neuron>::iterator end(NeuralLayer &neuralLayer)
{
return neuralLayer.m_neurons.end();
}
inline friend QVector<Neuron>::const_iterator end(const NeuralLayer &neuralLayer)
{
return neuralLayer.m_neurons.end();
}
private:
QVector<Neuron> m_neurons;
};
Q_DECLARE_METATYPE(NeuralLayer)