26 template<
typename AFloat>
    46                             A, &m, B, &n, &beta, C, &m);
    49 template<
typename AFloat>
    67 template<
typename AFloat>
    78    Hadamard(df, activationGradients);
    82        Multiply(activationGradientsBackward, df, weights);
    86        TransposeMultiply(weightGradients, df, activationsBackward);
    90        SumColumns(biasGradients, df);
 
static void MultiplyTranspose(TCpuMatrix< Scalar_t > &output, const TCpuMatrix< Scalar_t > &input, const TCpuMatrix< Scalar_t > &weights)
Matrix-multiply input with the transpose of  and write the results into output. 
void Ger(const int *m, const int *n, const Real_t *alpha, const Real_t *x, const int *incx, const Real_t *y, const int *incy, Real_t *A, const int *lda)
Add the outer product of x and y to the matrix A. 
double beta(double x, double y)
Calculates the beta function. 
static void AddRowWise(TCpuMatrix< Scalar_t > &output, const TCpuMatrix< Scalar_t > &biases)
Add the vectors biases row-wise to the matrix output. 
size_t GetNElements() const
void Gemm(const char *transa, const char *transb, const int *m, const int *n, const int *k, const Real_t *alpha, const Real_t *A, const int *lda, const Real_t *B, const int *ldb, const Real_t *beta, Real_t *C, const int *ldc)
Multiply the matrix A with the matrix B and store the result in C. 
static void Backward(TCpuMatrix< Scalar_t > &activationGradientsBackward, TCpuMatrix< Scalar_t > &weightGradients, TCpuMatrix< Scalar_t > &biasGradients, TCpuMatrix< Scalar_t > &df, const TCpuMatrix< Scalar_t > &activationGradients, const TCpuMatrix< Scalar_t > &weights, const TCpuMatrix< Scalar_t > &activationBackward)
Perform the complete backward propagation step. 
AFloat * GetRawDataPointer()
Return raw pointer to the elements stored contiguously in column-major order. 
static const AFloat * GetOnePointer()
Returns pointer to a vector holding only ones with a guaranteed length of the number of columns of ev...
Abstract ClassifierFactory template that handles arbitrary types.