blob: 0a0e32dfdbd1f68cc7143480b2815581a0efec04 [file] [log] [blame]
/*---------------------------------------------------------------------------*
* matx_ops.h *
* *
* Copyright 2007, 2008 Nuance Communciations, Inc. *
* *
* Licensed under the Apache License, Version 2.0 (the 'License'); *
* you may not use this file except in compliance with the License. *
* *
* You may obtain a copy of the License at *
* http://www.apache.org/licenses/LICENSE-2.0 *
* *
* Unless required by applicable law or agreed to in writing, software *
* distributed under the License is distributed on an 'AS IS' BASIS, *
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
* See the License for the specific language governing permissions and *
* limitations under the License. *
* *
*---------------------------------------------------------------------------*/
#include "hmm_type.h"
static PINLINE void matrix_fixed_multiply_frame(imeldata *outvec, imeldata **matrix,
imeldata *vector, int dimr, int dimc);
static PINLINE void matrix_fixed_multiply_frame(imeldata *outvec, imeldata **matrix,
imeldata *vector, int dimr, int dimc)
{
int ii, jj;
imeldata sum;
ASSERT(matrix);
ASSERT(vector);
ASSERT(outvec);
ASSERT(outvec != vector);
for (ii = 0; ii < dimr; ii++)
{
sum = 0;
for (jj = 0; jj < dimc; jj++)
sum += matrix[ii][jj] * vector[jj];
outvec[ii] = sum;
}
return;
}