/usr/include/sphinx3/wid.h is in libs3decoder-dev 0.8-0ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 | /* -*- c-basic-offset: 4; indent-tabs-mode: nil -*- */
/* ====================================================================
* Copyright (c) 1999-2004 Carnegie Mellon University. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* This work was supported in part by funding from the Defense Advanced
* Research Projects Agency and the National Science Foundation of the
* United States of America, and the CMU Sphinx Speech Consortium.
*
* THIS SOFTWARE IS PROVIDED BY CARNEGIE MELLON UNIVERSITY ``AS IS'' AND
* ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL CARNEGIE MELLON UNIVERSITY
* NOR ITS EMPLOYEES BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* ====================================================================
*
*/
/*
* wid.c -- Mapping word-IDs between LM and dictionary.
*
* **********************************************
* CMU ARPA Speech Project
*
* Copyright (c) 1999 Carnegie Mellon University.
* ALL RIGHTS RESERVED.
* **********************************************
*
* HISTORY
* $Log: wid.h,v $
* Revision 1.9 2005/06/21 21:05:49 arthchan2003
* 1, Fixed doxygen documentation, 2, Added keyword.
*
* Revision 1.4 2005/06/13 04:02:58 archan
* Fixed most doxygen-style documentation under libs3decoder.
*
* Revision 1.3 2005/03/30 01:22:47 archan
* Fixed mistakes in last updates. Add
*
*
* 01-Mar-1999 M K Ravishankar (rkm@cs.cmu.edu) at Carnegie Mellon University
* Started.
*/
#ifndef _S3_WID_H_
#define _S3_WID_H_
#include <s3types.h>
#include "dict.h"
#include "lm.h"
/** \file wid.h
\brief coversion of dictionary ID to LM ID.
*/
#ifdef __cplusplus
extern "C" {
#endif
#if 0
} /* Fool Emacs into not indenting things. */
#endif
/**
* Create mappings between dictionary and LM word-IDs. In short:
* - An array of s3lmwid32_t entries (map[]) is created; where map[i] is the LM word-ID for
* the dictionary word-ID i. Mappings are created for the alternative pronunciations as
* well. For words not in the LM, the corresponding entries are BAD_LMWID(lm).
* - Similarly, lm->ug[u].dictwid is assigned the dictionary word id for unigram word u.
* Return value: The map[] array built as described above.
*/
s3lmwid32_t *wid_dict_lm_map (dict_t *dict, /**< In: Dictionary */
lm_t *lm, /**< In/Out: LM; lm->ug[].dictwid values are
updated. */
int32 lw /**< In: Language Weight */
);
/**
* Augment the given wordprob array with alternative pronunciations from the dictionary.
* Return value: #entries in the augmented wordprob array (including the original ones).
*/
int32 wid_wordprob2alt (dict_t *dict, /**< In: Dictionary */
wordprob_t *wp, /**< In/Out: Input wordprob array, to be augmented with
alternative pronunciations for the entries that
already exist in it. Caller must have allocated
this array. */
int32 n /**< In: #Input entries in the wordprob array */
);
#if 0
{ /* Stop indent from complaining */
#endif
#ifdef __cplusplus
}
#endif
#endif
|