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; 33473018b4a1d088cdda0e7bd059fddf1f308a8195aIan Rogers const char* 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 36973018b4a1d088cdda0e7bd059fddf1f308a8195aIan Rogers if (file > (const char*)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