mirror of
https://github.com/Relintai/pmlpp.git
synced 2025-01-10 17:49:36 +01:00
Renamed MultiOutputLayer to OldMultiOutputLayer.
This commit is contained in:
parent
53ad617681
commit
a34628e8c4
@ -151,9 +151,9 @@ void MLPPMANN::addLayer(int n_hidden, std::string activation, std::string weight
|
|||||||
|
|
||||||
void MLPPMANN::addOutputLayer(std::string activation, std::string loss, std::string weightInit, std::string reg, real_t lambda, real_t alpha) {
|
void MLPPMANN::addOutputLayer(std::string activation, std::string loss, std::string weightInit, std::string reg, real_t lambda, real_t alpha) {
|
||||||
if (!network.empty()) {
|
if (!network.empty()) {
|
||||||
outputLayer = new MLPPMultiOutputLayer(n_output, network[0].n_hidden, activation, loss, network[network.size() - 1].a, weightInit, reg, lambda, alpha);
|
outputLayer = new MLPPOldMultiOutputLayer(n_output, network[0].n_hidden, activation, loss, network[network.size() - 1].a, weightInit, reg, lambda, alpha);
|
||||||
} else {
|
} else {
|
||||||
outputLayer = new MLPPMultiOutputLayer(n_output, k, activation, loss, inputSet, weightInit, reg, lambda, alpha);
|
outputLayer = new MLPPOldMultiOutputLayer(n_output, k, activation, loss, inputSet, weightInit, reg, lambda, alpha);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ private:
|
|||||||
std::vector<std::vector<real_t>> y_hat;
|
std::vector<std::vector<real_t>> y_hat;
|
||||||
|
|
||||||
std::vector<MLPPOldHiddenLayer> network;
|
std::vector<MLPPOldHiddenLayer> network;
|
||||||
MLPPMultiOutputLayer *outputLayer;
|
MLPPOldMultiOutputLayer *outputLayer;
|
||||||
|
|
||||||
int n;
|
int n;
|
||||||
int k;
|
int k;
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#include <random>
|
#include <random>
|
||||||
|
|
||||||
|
|
||||||
MLPPMultiOutputLayer::MLPPMultiOutputLayer(int n_output, int n_hidden, std::string activation, std::string cost, std::vector<std::vector<real_t>> input, std::string weightInit, std::string reg, real_t lambda, real_t alpha) :
|
MLPPOldMultiOutputLayer::MLPPOldMultiOutputLayer(int n_output, int n_hidden, std::string activation, std::string cost, std::vector<std::vector<real_t>> input, std::string weightInit, std::string reg, real_t lambda, real_t alpha) :
|
||||||
n_output(n_output), n_hidden(n_hidden), activation(activation), cost(cost), input(input), weightInit(weightInit), reg(reg), lambda(lambda), alpha(alpha) {
|
n_output(n_output), n_hidden(n_hidden), activation(activation), cost(cost), input(input), weightInit(weightInit), reg(reg), lambda(lambda), alpha(alpha) {
|
||||||
weights = MLPPUtilities::weightInitialization(n_hidden, n_output, weightInit);
|
weights = MLPPUtilities::weightInitialization(n_hidden, n_output, weightInit);
|
||||||
bias = MLPPUtilities::biasInitialization(n_output);
|
bias = MLPPUtilities::biasInitialization(n_output);
|
||||||
@ -116,14 +116,14 @@ MLPPMultiOutputLayer::MLPPMultiOutputLayer(int n_output, int n_hidden, std::stri
|
|||||||
cost_map["WassersteinLoss"] = &MLPPCost::HingeLoss;
|
cost_map["WassersteinLoss"] = &MLPPCost::HingeLoss;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MLPPMultiOutputLayer::forwardPass() {
|
void MLPPOldMultiOutputLayer::forwardPass() {
|
||||||
MLPPLinAlg alg;
|
MLPPLinAlg alg;
|
||||||
MLPPActivation avn;
|
MLPPActivation avn;
|
||||||
z = alg.mat_vec_add(alg.matmult(input, weights), bias);
|
z = alg.mat_vec_add(alg.matmult(input, weights), bias);
|
||||||
a = (avn.*activation_map[activation])(z, 0);
|
a = (avn.*activation_map[activation])(z, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MLPPMultiOutputLayer::Test(std::vector<real_t> x) {
|
void MLPPOldMultiOutputLayer::Test(std::vector<real_t> x) {
|
||||||
MLPPLinAlg alg;
|
MLPPLinAlg alg;
|
||||||
MLPPActivation avn;
|
MLPPActivation avn;
|
||||||
z_test = alg.addition(alg.mat_vec_mult(alg.transpose(weights), x), bias);
|
z_test = alg.addition(alg.mat_vec_mult(alg.transpose(weights), x), bias);
|
||||||
|
@ -9,18 +9,26 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#include "core/math/math_defs.h"
|
#include "core/math/math_defs.h"
|
||||||
|
#include "core/string/ustring.h"
|
||||||
|
|
||||||
|
#include "core/object/reference.h"
|
||||||
|
|
||||||
#include "../activation/activation.h"
|
#include "../activation/activation.h"
|
||||||
#include "../cost/cost.h"
|
#include "../cost/cost.h"
|
||||||
|
#include "../regularization/reg.h"
|
||||||
|
#include "../utilities/utilities.h"
|
||||||
|
|
||||||
|
#include "../lin_alg/mlpp_matrix.h"
|
||||||
|
#include "../lin_alg/mlpp_vector.h"
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
|
||||||
class MLPPMultiOutputLayer {
|
class MLPPOldMultiOutputLayer {
|
||||||
public:
|
public:
|
||||||
MLPPMultiOutputLayer(int n_output, int n_hidden, std::string activation, std::string cost, std::vector<std::vector<real_t>> input, std::string weightInit, std::string reg, real_t lambda, real_t alpha);
|
MLPPOldMultiOutputLayer(int n_output, int n_hidden, std::string activation, std::string cost, std::vector<std::vector<real_t>> input, std::string weightInit, std::string reg, real_t lambda, real_t alpha);
|
||||||
|
|
||||||
int n_output;
|
int n_output;
|
||||||
int n_hidden;
|
int n_hidden;
|
||||||
|
Loading…
Reference in New Issue
Block a user