#pragma once #include "./core/omp_config.h" #include "./utils/vector.h" #include "./utils/matrix.h" #include "./utils/random.h" namespace neural_networks{ template struct dense_layer{ utils::Matrix weights; utils::Vector biases; utils::Matrix outputs; // Default Constructor dense_layer() = default; // Constructor dense_layer(const uint64_t n_inputs, const uint64_t n_neurons){ weights.random(n_inputs, n_neurons, -1, 1); biases.resize(n_neurons, T{0}); //weights.print(); //outputs.resize() } void forward(utils::Matrix inputs){ outputs = numerics::matadd(numerics::matmul_auto(inputs, (weights)), biases, "row"); } }; } // end namespace neural_networks