14a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/*---------------------------------------------------------------------------*
24a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  swimodel.c  *
34a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
44a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Copyright 2007, 2008 Nuance Communciations, Inc.                               *
54a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
64a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Licensed under the Apache License, Version 2.0 (the 'License');          *
74a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  you may not use this file except in compliance with the License.         *
84a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
94a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  You may obtain a copy of the License at                                  *
104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0                           *
114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Unless required by applicable law or agreed to in writing, software      *
134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  distributed under the License is distributed on an 'AS IS' BASIS,        *
144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  See the License for the specific language governing permissions and      *
164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  limitations under the License.                                           *
174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *---------------------------------------------------------------------------*/
194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#ifndef _RTT
214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include <stdio.h>
224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#endif
234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include <math.h>
244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include <stdlib.h>
254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include <assert.h>
264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "prelib.h"
284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "hmmlib.h"
294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "portable.h"
304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "errhndl.h"
314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "log_add.h"
334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "swimodel.h"
344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#define MTAG NULL
374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/*--------------------------------------------------------------*
404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                              *
414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                              *
424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                              *
434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *--------------------------------------------------------------*/
444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/* the looping cost lookup table. This table was generated empirically
464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   by looking at resulting residency distributions, trying to make them
474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   look roughly like normal distributions centered at the average state
484a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   durations */
494a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
504a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectconst char loop_cost_table [128][6] = {
514a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,0},
524a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{13,15,16,16,16,16},
534a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{12,13,14,14,14,14},
544a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{11,12,13,13,13,13},
554a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{10,12,12,12,12,12},
564a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{10,11,11,12,12,12},
574a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{10,11,11,11,11,11},
584a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{10,11,11,11,11,11},
594a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,11,11,11,11,11},
604a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,10,11,11,11,11},
614a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,10,10,10,10,10},
624a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,10,10,10,10,10},
634a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,10,10,10,10,10},
644a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,10,10,10,10,10},
654a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,10,10,10,10,10},
664a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,10,10,10,10,10},
674a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,10,10,10,10,10},
684a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{8,10,10,10,10,10},
694a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{8,10,10,10,10,10},
704a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{8,10,10,10,10,10},
714a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{8,10,10,10,10,10},
724a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{8,10,10,10,10,10},
734a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{8,10,10,10,10,10},
744a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{7,10,10,10,10,10},
754a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{7,10,10,10,10,10},
764a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{7,10,10,10,10,10},
774a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{6,10,10,10,10,10},
784a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{6,10,10,10,10,10},
794a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{6,10,10,10,10,10},
804a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{5,10,10,10,10,10},
814a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{5,10,10,10,10,10},
824a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{4,10,10,10,10,10},
834a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{4,9,10,10,10,10},
844a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{3,9,10,10,10,10},
854a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,9,10,10,10,10},
864a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,9,10,10,10,10},
874a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,9,10,10,10,10},
884a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,9,10,10,10,10},
894a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,9,10,10,10,10},
904a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,9,10,10,10,10},
914a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,9,10,10,10,10},
924a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,9,10,10,10,10},
934a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,9,10,10,10,10},
944a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,8,10,10,10,10},
954a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,8,10,10,10,10},
964a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,8,10,10,10,10},
974a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,7,10,10,10,10},
984a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,7,10,10,10,10},
994a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,6,10,10,10,10},
1004a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,5,10,10,10,10},
1014a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,5,10,10,10,10},
1024a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,4,10,10,10,10},
1034a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,3,10,10,10,10},
1044a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,2,10,10,10,10},
1054a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,2,10,10,10,10},
1064a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,1,10,10,10,10},
1074a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,1,9,10,10,10},
1084a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,9,10,10,10},
1094a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,9,10,10,10},
1104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,9,10,10,10},
1114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,9,10,10,10},
1124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,9,10,10,10},
1134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,9,10,10,10},
1144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,9,10,10,10},
1154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,9,10,10,10},
1164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,8,10,10,10},
1174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,8,10,10,10},
1184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,7,10,10,10},
1194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,6,10,10,10},
1204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,6,10,10,10},
1214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,5,10,10,10},
1224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,4,10,10,10},
1234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,3,10,10,10},
1244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,2,10,10,10},
1254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,1,10,10,10},
1264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,1,10,10,10},
1274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,10,10,10},
1284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,10,10,10},
1294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,9,10,10},
1304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,9,10,10},
1314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,9,10,10},
1324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,9,10,10},
1334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,9,10,10},
1344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,9,10,10},
1354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,9,10,10},
1364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,9,10,10},
1374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,8,10,10},
1384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,8,10,10},
1394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,7,10,10},
1404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,6,10,10},
1414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,5,10,10},
1424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,3,10,10},
1434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,2,10,10},
1444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,1,10,10},
1454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,1,10,10},
1464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,10,10},
1474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,10,10},
1484a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,10,10},
1494a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,10,10},
1504a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,10,10},
1514a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,9,10},
1524a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,9,10},
1534a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,9,10},
1544a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,9,10},
1554a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,9,10},
1564a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,9,10},
1574a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,9,10},
1584a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,8,10},
1594a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,7,10},
1604a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,6,10},
1614a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,5,10},
1624a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,3,10},
1634a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,2,10},
1644a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,1,10},
1654a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,10},
1664a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,10},
1674a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,10},
1684a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,10},
1694a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,10},
1704a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,10},
1714a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,10},
1724a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,9},
1734a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,9},
1744a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,9},
1754a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,9},
1764a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,9},
1774a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,9},
1784a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,8}
1794a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project};
1804a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1814a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/* the transition cost lookup table. This table was generated empirically
1824a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   by looking at resulting residency distributions, trying to make them
1834a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   look roughly like normal distributions centered at the average state
1844a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   durations */
1854a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1864a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectconst char trans_cost_table [128][6] = {
1874a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,0},
1884a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,0},
1894a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,0},
1904a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,0},
1914a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,0},
1924a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,0},
1934a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{0,0,0,0,0,0},
1944a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
1954a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
1964a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
1974a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
1984a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
1994a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
2004a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
2014a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
2024a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
2034a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
2044a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
2054a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
2064a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{1,0,0,0,0,0},
2074a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,0,0,0,0,0},
2084a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,0,0,0,0,0},
2094a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,0,0,0,0,0},
2104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,0,0,0,0,0},
2114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,0,0,0,0,0},
2124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,0,0,0,0,0},
2134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{2,0,0,0,0,0},
2144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{3,0,0,0,0,0},
2154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{3,0,0,0,0,0},
2164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{3,0,0,0,0,0},
2174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{3,0,0,0,0,0},
2184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{4,0,0,0,0,0},
2194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{4,0,0,0,0,0},
2204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{4,0,0,0,0,0},
2214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{5,0,0,0,0,0},
2224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{5,0,0,0,0,0},
2234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{6,1,0,0,0,0},
2244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{6,1,0,0,0,0},
2254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{7,1,0,0,0,0},
2264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{7,1,0,0,0,0},
2274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{8,1,0,0,0,0},
2284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{8,1,0,0,0,0},
2294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{9,1,0,0,0,0},
2304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{10,1,0,0,0,0},
2314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{10,1,0,0,0,0},
2324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{11,2,0,0,0,0},
2334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{12,2,0,0,0,0},
2344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{13,2,0,0,0,0},
2354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{13,2,0,0,0,0},
2364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{14,3,0,0,0,0},
2374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{15,3,0,0,0,0},
2384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{15,3,0,0,0,0},
2394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{16,4,0,0,0,0},
2404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{17,4,0,0,0,0},
2414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{17,5,0,0,0,0},
2424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{18,6,0,0,0,0},
2434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{18,6,0,0,0,0},
2444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{19,7,0,0,0,0},
2454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{19,8,0,0,0,0},
2464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{19,9,0,0,0,0},
2474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{20,10,0,0,0,0},
2484a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{20,11,0,0,0,0},
2494a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{20,12,0,0,0,0},
2504a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{20,13,0,0,0,0},
2514a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{21,14,1,0,0,0},
2524a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{21,15,1,0,0,0},
2534a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{21,16,1,0,0,0},
2544a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{21,17,1,0,0,0},
2554a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{22,18,2,0,0,0},
2564a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{22,19,2,0,0,0},
2574a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{22,19,2,0,0,0},
2584a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{22,20,3,0,0,0},
2594a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{22,20,3,0,0,0},
2604a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{23,21,4,0,0,0},
2614a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{23,21,5,0,0,0},
2624a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{23,22,6,0,0,0},
2634a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{23,22,7,0,0,0},
2644a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{23,23,8,0,0,0},
2654a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{23,23,9,0,0,0},
2664a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{23,23,10,0,0,0},
2674a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{24,23,12,0,0,0},
2684a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{24,24,13,0,0,0},
2694a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{24,24,14,0,0,0},
2704a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{24,24,16,0,0,0},
2714a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{24,24,17,0,0,0},
2724a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{24,24,18,0,0,0},
2734a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{25,24,20,0,0,0},
2744a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{25,25,21,1,0,0},
2754a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{25,25,22,1,0,0},
2764a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{25,25,22,1,0,0},
2774a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{25,25,23,2,0,0},
2784a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{25,25,24,2,0,0},
2794a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{25,25,24,3,0,0},
2804a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{25,25,25,3,0,0},
2814a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{26,26,25,4,0,0},
2824a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{26,26,25,5,0,0},
2834a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{26,26,25,6,0,0},
2844a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{26,26,26,8,0,0},
2854a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{26,26,26,9,0,0},
2864a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{26,26,26,11,0,0},
2874a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{26,26,26,13,0,0},
2884a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,26,15,0,0},
2894a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,27,17,0,0},
2904a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,27,18,0,0},
2914a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,27,20,0,0},
2924a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,27,22,0,0},
2934a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,27,23,0,0},
2944a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,27,24,0,0},
2954a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,27,25,0,0},
2964a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{27,27,27,26,1,0},
2974a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,26,1,0},
2984a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,27,1,0},
2994a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,27,2,0},
3004a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,27,3,0},
3014a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,28,3,0},
3024a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,28,5,0},
3034a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,28,6,0},
3044a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,28,8,0},
3054a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{28,28,28,28,10,0},
3064a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,12,0},
3074a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,14,0},
3084a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,16,0},
3094a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,19,0},
3104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,21,0},
3114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,23,0},
3124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,24,0},
3134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,26,0},
3144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{29,29,29,29,27,0}
3154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project};
3164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/*--------------------------------------------------------------*
3184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                              *
3194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                              *
3204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                              *
3214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *--------------------------------------------------------------*/
3224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectstatic short load_short(PFile* fp)
3244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
3254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  short v;
3264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  pfread(&v, sizeof(short), 1, fp);
3274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  return v;
3284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
3294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectconst SWIModel* load_swimodel(const char *filename)
3314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
3324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  int i;
3334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  SWIModel *swimodel = NULL;
3344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  const void* file = NULL;
3354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#ifdef SREC_ENGINE_VERBOSE_LOGGING
3374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  PLogMessage("load_swimodel: loaded %s", filename);
3384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#endif
3394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  swimodel = (SWIModel*) CALLOC(1, sizeof(SWIModel), "clib.models.base");
3404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if (mmap_zip(filename, &swimodel->mmap_zip_data, &swimodel->mmap_zip_size)) {
3424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      PLogError("load_swimodel: mmap_zip failed for %s\n", filename);
3434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      goto CLEANUP;
3444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
3454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  file = swimodel->mmap_zip_data;
3464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  swimodel->num_hmmstates = *(const short*)file;
3484a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  file += sizeof(short);
3494a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  swimodel->num_dims = *(const short*)file;
3504a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  file += sizeof(short);
3514a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  swimodel->num_pdfs = *(const short*)file;
3524a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  file += sizeof(short);
3534a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3544a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  SWIhmmState* hmmstates = (SWIhmmState*) CALLOC(swimodel->num_hmmstates, sizeof(SWIhmmState), "clib.models.states");
3554a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  swimodel->hmmstates = hmmstates;
3564a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3574a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  const short* num_pdfs_in_model = (const short*)file;
3584a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  file += sizeof(short) * swimodel->num_hmmstates;
3594a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3604a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  swimodel->allmeans = (const featdata*)file;
3614a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  file += sizeof(featdata) * swimodel->num_pdfs * swimodel->num_dims;
3624a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3634a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  swimodel->allweights = (const wtdata*)file;
3644a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  file += sizeof(wtdata) * swimodel->num_pdfs;
3654a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3664a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  swimodel->avg_state_durations = (const featdata*)file;
3674a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  file += sizeof(featdata) * swimodel->num_hmmstates;
3684a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3694a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if (file > swimodel->mmap_zip_data + swimodel->mmap_zip_size) {
3704a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      PLogError("load_swimodel: not enough data in %s", filename);
3714a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      goto CLEANUP;
3724a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
3734a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3744a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#ifdef SREC_ENGINE_VERBOSE_LOGGING
3754a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  PLogMessage("loaded models %s num_hmmstates %d num_dims %d num_pdfs %d weights[0] %d\n",
3764a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project              filename, swimodel->num_hmmstates, swimodel->num_dims, swimodel->num_pdfs,
3774a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project              *swimodel->allweights);
3784a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#endif
3794a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3804a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  const featdata* mean_ptr = swimodel->allmeans;
3814a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  const wtdata* weight_ptr = swimodel->allweights;
3824a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3834a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  for (i = 0;i < swimodel->num_hmmstates;i++)
3844a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  {
3854a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    hmmstates[i].num_pdfs = num_pdfs_in_model[i];
3864a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    hmmstates[i].means = mean_ptr;
3874a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    hmmstates[i].weights = weight_ptr;
3884a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    mean_ptr += swimodel->num_dims * num_pdfs_in_model[i];
3894a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    weight_ptr += num_pdfs_in_model[i];
3904a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
3914a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3924a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  return swimodel;
3934a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3944a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source ProjectCLEANUP:
3954a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  free_swimodel(swimodel);
3964a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  return NULL;
3974a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
3984a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
3994a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectvoid free_swimodel(const SWIModel* swimodel)
4004a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
4014a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if (!swimodel) return;
4024a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if (swimodel->mmap_zip_data) munmap_zip(swimodel->mmap_zip_data, swimodel->mmap_zip_size);
4034a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  FREE((void*)swimodel->hmmstates);
4044a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  FREE((void*)swimodel);
4054a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
4064a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4074a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectstatic PINLINE prdata Gaussian_Grand_Density_Swimodel(const preprocessed *data, const featdata *means)
4084a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/*
4094a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project**  Observation probability function of a Gaussian pdf
4104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project**  with diagonal covariance matrix.
4114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project*/
4124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
4134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  prdata pval;
4144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  prdata diff;
4154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  const imeldata *dvec;
4164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  const imeldata *dend;
4174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  int count;
4184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  dvec = data->seq + data->use_from;    /* Move to starting feature element */
4204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  pval = 0;
4224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  dend = dvec + data->use_dim;
4234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  count = 0;
4244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  while (dvec < dend)
4254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  {
4264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    diff = *(means++) - *(dvec++);
4274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    pval -= diff * diff;
4284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
4294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  pval = data->mul.multable_factor_gaussian
4304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project         * (pval - data->mul.grand_mod_cov_gaussian);
4314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  return (pval);
4324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
4334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectscodata mixture_diagonal_gaussian_swimodel(const preprocessed *prep,
4354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    const SWIhmmState *spd, short num_dims)
4364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/*
4374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project**  Observation probability function
4384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project*/
4394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
4404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  int ii;
4414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  prdata pval, gval;
4424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  prdata dval;
4444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  const featdata *meanptr;
4454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  const wtdata *weightptr;
4464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  ASSERT(prep);
4484a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  ASSERT(spd);
4494a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4504a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  pval = -(prdata) MAX_LOG;
4514a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4524a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  meanptr = spd->means;
4534a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  weightptr = spd->weights;
4544a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4554a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  for (ii = 0; ii < spd->num_pdfs; ii++)
4564a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  {
4574a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    gval = ((prdata) * (weightptr++) * prep->add.scale
4584a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project            + Gaussian_Grand_Density_Swimodel(prep, meanptr));
4594a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4604a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    meanptr += num_dims;
4614a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4624a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if (pval > gval)
4634a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    {
4644a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      dval = pval - gval;
4654a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      if (dval < prep->add.add_log_limit)
4664a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project        pval += log_increment_inline(dval, &prep->add);
4674a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    }
4684a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    else
4694a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    {
4704a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      dval = gval - pval;
4714a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      if (dval < prep->add.add_log_limit)
4724a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project        pval = gval + log_increment_inline(dval, &prep->add);
4734a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      else
4744a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project        pval = gval;
4754a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    }
4764a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
4774a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  ASSERT(pval > ((0x01 << 31) / (prep->mix_score_scale * prep->add.inv_scale)));
4784a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  pval = ((pval * prep->mix_score_scale - 64 * prep->add.scale)
4794a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project          * prep->add.inv_scale) >> 19;
4804a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
4814a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  return ((scodata)pval);
4824a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
483