亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hutil.c

?? 隱馬爾科夫模型工具箱
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* ----------------------------------------------------------- *//*                                                             *//*                          ___                                *//*                       |_| | |_/   SPEECH                    *//*                       | | | | \   RECOGNITION               *//*                       =========   SOFTWARE                  */ /*                                                             *//*                                                             *//* ----------------------------------------------------------- *//* developed at:                                               *//*                                                             *//*      Speech Vision and Robotics group                       *//*      Cambridge University Engineering Department            *//*      http://svr-www.eng.cam.ac.uk/                          *//*                                                             *//*      Entropic Cambridge Research Laboratory                 *//*      (now part of Microsoft)                                *//*                                                             *//* ----------------------------------------------------------- *//*         Copyright: Microsoft Corporation                    *//*          1995-2000 Redmond, Washington USA                  *//*                    http://www.microsoft.com                 *//*                                                             *//*              2002  Cambridge University                     *//*                    Engineering Department                   *//*                                                             *//*   Use of this software is governed by a License Agreement   *//*    ** See the file License for the Conditions of Use  **    *//*    **     This banner notice must not be removed      **    *//*                                                             *//* ----------------------------------------------------------- *//*         File: HUtil.c      HMM utility routines             *//* ----------------------------------------------------------- */char *hutil_version = "!HVER!HUtil:   3.2 [CUED 09/12/02]";char *hutil_vc_id = "$Id: HUtil.c,v 1.9 2002/12/19 16:37:11 ge204 Exp $";#include "HShell.h"#include "HMem.h"#include "HMath.h"#include "HSigP.h"#include "HAudio.h"#include "HWave.h"#include "HVQ.h"#include "HParm.h"#include "HLabel.h"#include "HModel.h"#include "HUtil.h"/* --------------------------- Trace Flags ------------------------- */#define T_TOP  0001       /* Top Level tracing */#define T_ITM  0002       /* Item List tracing */#define T_OCC  0004       /* Occupancy statistics tracing */static int trace = 0;static MemHeap setHeap;static MemHeap itemHeap;/* --------------------------- Initialisation ---------------------- */static ConfParam *cParm[MAXGLOBS];      /* config parameters */static int nParm = 0;/* EXPORT->InitUtil: initialise configuration parameters */void InitUtil(void){   int i;   Register(hutil_version,hutil_vc_id);   nParm = GetConfig("HUTIL", TRUE, cParm, MAXGLOBS);   if (nParm>0){      if (GetConfInt(cParm,nParm,"TRACE",&i)) trace = i;   }   CreateHeap(&itemHeap,"HUtil: ItemList Heap",MHEAP,sizeof(ItemRec),              1.0,200,8000);   CreateHeap(&setHeap,"HUtil: IntSet Heap",MSTAK,1,1.0,2000,16000);}/* -------------------- Clone Routines ------------------------ *//* CloneSVector: return a clone of given matrix */SVector CloneSVector(MemHeap *hmem, SVector s, Boolean sharing){   SVector t;  /* the target */      if (s==NULL) return NULL;   if (GetUse(s)>0 && sharing) {      IncUse(s);      return s;   }   t = CreateSVector(hmem,VectorSize(s));   CopyVector(s,t);   return t;}/* CloneSMatrix: return a clone of given Matrix */SMatrix CloneSMatrix(MemHeap *hmem, SMatrix s, Boolean sharing){   SMatrix t;  /* the target */      if (s==NULL) return NULL;   if (GetUse(s)>0 && sharing) {      IncUse(s);      return s;   }   t = CreateSMatrix(hmem,NumRows(s),NumCols(s));   CopyMatrix(s,t);   return t;}/* CloneSTriMat: return a clone of given TriMat */STriMat CloneSTriMat(MemHeap *hmem, STriMat s, Boolean sharing){   STriMat t;  /* the target */      if (s==NULL) return NULL;   if (GetUse(s)>0 && sharing) {      IncUse(s);      return s;   }   t = CreateSTriMat(hmem,TriMatSize(s));   CopyTriMat(s,t);   return t;}/* CloneMixPDF: return a clone of given MixPDF */MixPDF *CloneMixPDF(HMMSet *hset, MixPDF *s, Boolean sharing){   MixPDF *t;      if (s->nUse>0 && sharing) {       ++s->nUse;      return s;   }   t = (MixPDF*)New(hset->hmem,sizeof(MixPDF));   t->nUse = 0; t->hook = NULL; t->gConst = s->gConst;   t->mean = CloneSVector(hset->hmem,s->mean,sharing);   t->ckind = s->ckind;   switch(s->ckind) {   case DIAGC:    case INVDIAGC:       t->cov.var = CloneSVector(hset->hmem,s->cov.var,sharing);      break;   case FULLC:   case LLTC:      t->cov.inv = CloneSTriMat(hset->hmem,s->cov.inv,sharing);      break;   case XFORMC:      t->cov.xform = CloneSMatrix(hset->hmem,s->cov.xform,sharing);      break;   }   return t;}/* CloneStream: return a clone of given stream */MixtureVector CloneStream(HMMSet *hset, StreamElem *ste, Boolean sharing){   int m,M;   MixtureElem *sme,*tme;   MixtureVector mv;   M = ste->nMix;   if (hset->hsKind == PLAINHS || hset->hsKind == SHAREDHS){      tme = (MixtureElem *)New(hset->hmem,M*sizeof(MixtureElem));      mv.cpdf = tme-1; sme = ste->spdf.cpdf + 1;      for (m=1; m<=M; m++,sme++,tme++){         tme->weight = sme->weight;         tme->mpdf =             (tme->weight>MINMIX)?CloneMixPDF(hset,sme->mpdf,sharing):NULL;      }   } else if (hset->hsKind == TIEDHS) {      mv.tpdf = CreateVector(hset->hmem,M);      CopyVector(ste->spdf.tpdf,mv.tpdf);   } else {      mv.dpdf = CreateShortVec(hset->hmem,M);      CopyShortVec(ste->spdf.dpdf,mv.dpdf);   }   return mv;}/* CloneState: return a clone of given State */StateInfo *CloneState(HMMSet *hset, StateInfo *ssi, Boolean sharing){   StateInfo *tsi;  /* the target */   StreamElem *tste,*sste;   int s,S;      if (ssi->nUse>0 && sharing) {       ++ssi->nUse;      return ssi;   }   S = hset->swidth[0];   tsi = (StateInfo *)New(hset->hmem,sizeof(StateInfo));   tsi->nUse = 0; tsi->hook = NULL;   tste = (StreamElem *)New(hset->hmem,S*sizeof(StreamElem));   tsi->pdf = tste-1; sste = ssi->pdf + 1;   for (s=1; s<=S; s++,tste++,sste++){      tste->nMix = sste->nMix;       tste->hook = NULL;      tste->spdf = CloneStream(hset,sste,sharing);   }   tsi->dur     = CloneSVector(hset->hmem,ssi->dur,sharing);   tsi->weights = CloneSVector(hset->hmem,ssi->weights,sharing);   return tsi;}/* EXPORT->CloneHMM: copy src HMM into tgt.  If sharing, then macros are shared */void CloneHMM(HLink src, HLink tgt, Boolean sharing){   StateElem *s,*t;   int i;   HMMSet *hset = src->owner;      tgt->owner = src->owner;   tgt->numStates = src->numStates;   tgt->dur = CloneSVector(hset->hmem,src->dur,sharing);   tgt->transP = CloneSMatrix(hset->hmem,src->transP,sharing);   t = (StateElem *)New(hset->hmem,(tgt->numStates-2)*sizeof(StateElem));   tgt->svec = t-2; s = src->svec+2;   for (i=2; i<tgt->numStates; i++,s++,t++)      t->info = CloneState(hset,s->info,sharing);   tgt->hook = NULL; tgt->nUse = 0;}/* -------------------- Mapping Routines ------------------------ *//* EXPORT->NewHMMScan:  create new HMM scan record */void NewHMMScan(HMMSet *hset, HMMScanState *hss){   hss->hset = hset;   hss->S = hset->swidth[0];   hss->isCont = (hset->hsKind == PLAINHS) || (hset->hsKind == SHAREDHS);   hss->h = -1;   hss->mac=NULL;   if (!GoNextHMM(hss))      HError(7220,"NewHMMScan: cannot find any physical HMMs to scan");}/* EXPORT->EndHMMScan: terminate scan and restore nUse flags */void EndHMMScan(HMMScanState *hss){   ClearSeenFlags(hss->hset,CLR_ALL);   hss->hmm = NULL; hss->se = NULL; hss->ste = NULL; hss->me = NULL;}/* EXPORT->GoNextHMM: Move to next unseen HMM in HMM set */Boolean GoNextHMM(HMMScanState *hss){   int M;   MLink mac;   mac = hss->mac ? hss->mac->next : NULL;   if (mac==NULL) hss->h++;   for (;hss->h<MACHASHSIZE;hss->h++)      for (mac=((mac==NULL)?hss->hset->mtab[hss->h]:mac);           mac!=NULL;mac=mac->next) {         if (mac->type == 'h') {            hss->mac = mac;            hss->hmm = (HLink)mac->structure;            hss->N = hss->hmm->numStates;            hss->se = hss->hmm->svec+2; hss->i=2;            hss->si = hss->se->info;            hss->ste = hss->si->pdf+1; hss->s=1;            M = hss->ste->nMix;            hss->M = (M<0)?-M:M; hss->m=1;            if (hss->isCont){               hss->me = hss->ste->spdf.cpdf+1;               hss->mp = hss->me->mpdf;            }            return TRUE;         }      }   hss->hmm = NULL;   return FALSE;}/* EXPORT->GoNextState: move to next unseen state */Boolean GoNextState(HMMScanState *hss, Boolean noSkip){   Boolean stepping = FALSE, ok = TRUE;   int M;      while (IsSeen(hss->si->nUse) && ok){      if (hss->i < hss->N-1) {         ++hss->i; ++hss->se; stepping = TRUE;         hss->si = hss->se->info;      } else if (noSkip)         return FALSE;      else{         stepping = FALSE;         ok = GoNextHMM(hss);       }   }   if (ok) {      Touch(&hss->si->nUse);      if (stepping){         hss->ste = hss->si->pdf+1; hss->s=1;         M = hss->ste->nMix;         hss->M = (M<0)?-M:M; hss->m=1;         if (hss->isCont){            hss->me = hss->ste->spdf.cpdf+1;            hss->mp = hss->me->mpdf;         }      }      return TRUE;   }   hss->se = NULL;   return FALSE;}/* EXPORT->GoNextStream: move to next unseen stream */Boolean GoNextStream(HMMScanState *hss, Boolean noSkip){   Boolean stepping = FALSE, ok = TRUE;   int M;      while (IsSeen(hss->ste->nMix) && ok){      if (hss->s < hss->S) {         ++hss->s; ++hss->ste; stepping = TRUE;      } else if (noSkip)         return FALSE;      else{         stepping = FALSE;             ok = GoNextState(hss,FALSE);      }   }   if (ok) {      Touch(&hss->ste->nMix);      if (stepping) {         M = hss->ste->nMix;         hss->M = (M<0)?-M:M; hss->m=1;         if (hss->isCont){            hss->me = hss->ste->spdf.cpdf+1;            hss->mp = hss->me->mpdf;         }      }      return TRUE;   }   hss->ste = NULL;   return FALSE;}/* EXPORT->GoNextMix: move to next unseen mixture component */Boolean GoNextMix(HMMScanState *hss, Boolean noSkip){   Boolean ok = TRUE;      if (hss->isCont){      while (IsSeen(hss->mp->nUse) && ok){         if (hss->m < hss->M) {            ++hss->m; ++hss->me;             hss->mp = hss->me->mpdf;         } else if (noSkip)            return FALSE;         else            ok = GoNextStream(hss,FALSE);      }      if (ok) {         Touch(&hss->mp->nUse);         return TRUE;      }   } else {      if (hss->m < hss->M) {         ++hss->m;      } else if (noSkip)         return FALSE;      else         ok = GoNextStream(hss,FALSE);      if (ok) return TRUE;   }   hss->me = NULL;   return FALSE;}/* ----------------------- DiagC conversions ----------------------------- *//* minimum and max values used in conversions */#define MINVAR 1E-30#define MAXVAR 1E+30/* EXPORT->ConvDiagC Convert Diagonal Covariance Kind  Converts all the HMMs in hset to INVDIAGC from DIAGC  or vice versa. If convData is TRUE then each variance element is  replaced by its reciprocal - otherwise only the CovKind in each HMM  is changed and no data conversions are performed. */void ConvDiagC(HMMSet *hset, Boolean convData){   HMMScanState hss;   SVector v;   int k;   if (hset->hsKind == DISCRETEHS || hset->hsKind == TIEDHS)       return;   NewHMMScan(hset, &hss);   while (GoNextMix(&hss,FALSE)) {      if (hss.mp->ckind == DIAGC || hss.mp->ckind == INVDIAGC){         hss.mp->ckind = (hss.mp->ckind == DIAGC)?INVDIAGC:DIAGC;         if (convData){            v = hss.mp->cov.var;            if (! IsSeenV(v)) {               for (k=1; k<=hset->swidth[hss.s]; k++) {                  if (v[k] > MAXVAR) v[k] = MAXVAR;                  if (v[k] < MINVAR) v[k] = MINVAR;                  v[k] = 1/v[k];               }               TouchV(v);            }         }      }   }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人深夜福利app| 欧美一区二区在线免费观看| 欧美日韩一区三区四区| 2020日本不卡一区二区视频| 亚洲高清免费观看| av午夜一区麻豆| 久久久亚洲精品石原莉奈| 亚洲电影欧美电影有声小说| 91一区一区三区| 国产精品久久一级| 国产精品一区二区三区乱码 | www国产精品av| 亚洲亚洲精品在线观看| 成人黄色软件下载| 国产精品三级在线观看| 久久99国产精品久久99果冻传媒| 欧美日韩中文字幕精品| 亚洲欧洲精品一区二区三区| 国产精品原创巨作av| 日韩视频免费观看高清在线视频| 亚洲精品中文字幕乱码三区| www.欧美.com| 国产精品久久看| 成人av片在线观看| 日本一区二区视频在线观看| 国产一区二区三区日韩| 精品少妇一区二区三区在线视频| 日欧美一区二区| 4438成人网| 另类小说图片综合网| 91精品欧美久久久久久动漫 | 精品一区二区三区免费观看| 欧美一区二区美女| 久久99久久精品欧美| 日韩午夜在线播放| 国产一区二区女| 久久亚洲免费视频| 国产精品亚洲综合一区在线观看| 国产日韩视频一区二区三区| 国产精品99久久久久久久vr| 日本一区二区视频在线| 成人免费观看av| 中文字幕亚洲一区二区av在线| 91年精品国产| 亚洲第一福利视频在线| 日韩一区二区三区在线视频| 麻豆精品视频在线观看免费| 日韩免费在线观看| 高清久久久久久| 亚洲欧美怡红院| 欧美日韩三级一区| 美美哒免费高清在线观看视频一区二区| 欧美日韩高清一区| 韩国毛片一区二区三区| 中文字幕一区二区三区在线观看 | 欧美日韩久久久| 美国毛片一区二区| 欧美激情资源网| 91国在线观看| 极品销魂美女一区二区三区| 中文字幕日韩av资源站| 欧美日韩黄色一区二区| 黄网站免费久久| 亚洲男人天堂av| 欧美精品一区在线观看| 91免费看`日韩一区二区| 视频在线在亚洲| 中文久久乱码一区二区| 欧美日韩精品一区视频| 国产乱一区二区| 亚洲一区视频在线| 国产亚洲欧美日韩日本| 在线视频一区二区三区| 国产在线精品不卡| 亚洲成年人影院| 国产精品久久福利| 欧美一卡二卡在线观看| 97精品超碰一区二区三区| 香港成人在线视频| 一区二区中文字幕在线| 欧美一区二区私人影院日本| 97se亚洲国产综合自在线| 蜜臀av一区二区在线观看| 国产精品成人一区二区三区夜夜夜 | 亚洲欧洲av色图| 日韩欧美一区二区免费| 在线观看视频91| 成人h动漫精品一区二区| 久久激情五月激情| 午夜精品成人在线| 亚洲精品国久久99热| 国产婷婷精品av在线| 日韩欧美高清一区| 91精品福利在线一区二区三区| 97久久精品人人爽人人爽蜜臀| 国产一区二区三区视频在线播放| 日韩高清在线一区| 亚洲一区二区三区小说| 亚洲色图另类专区| 国产精品久久久久久久久快鸭 | 日韩伦理电影网| 久久精品人人做| 精品国内片67194| 欧美成人video| 69久久99精品久久久久婷婷| 色婷婷精品大在线视频| 91麻豆国产在线观看| 风间由美一区二区av101| 国产一区二区三区国产| 精品在线你懂的| 久久99久久久久久久久久久| 蜜臀av性久久久久蜜臀av麻豆| 香蕉加勒比综合久久| 无吗不卡中文字幕| 日本不卡一区二区| 青青草国产成人99久久| 蜜臀精品一区二区三区在线观看 | 95精品视频在线| proumb性欧美在线观看| 波多野结衣精品在线| 成人午夜伦理影院| 99久久777色| 欧美综合天天夜夜久久| 91免费观看视频在线| 色婷婷av久久久久久久| 欧美日韩国产综合一区二区 | 欧美国产成人在线| 国产精品每日更新| 亚洲伦理在线精品| 亚洲一二三区在线观看| 性欧美大战久久久久久久久| 美美哒免费高清在线观看视频一区二区| 久久99久久99精品免视看婷婷| 国产精品资源在线| 99久久婷婷国产综合精品电影| 在线亚洲免费视频| 日韩欧美一级二级| 国产精品午夜春色av| 洋洋成人永久网站入口| 亚洲午夜在线视频| 美女精品自拍一二三四| 成人免费福利片| 欧美性生活久久| 26uuu亚洲综合色欧美| 国产精品久久久久毛片软件| 一区二区三区在线高清| 极品少妇xxxx精品少妇偷拍 | 亚洲三级在线观看| 日韩电影在线观看网站| 国v精品久久久网| 欧美猛男超大videosgay| 欧美精品一区二区三区四区| 亚洲欧美另类久久久精品| 欧美96一区二区免费视频| 成人免费av在线| 欧美肥妇free| 亚洲欧洲精品一区二区三区不卡| 丝袜亚洲另类丝袜在线| 成人午夜电影网站| 欧美一区二区三区在线观看| 国产精品视频一二| 久久99国产精品尤物| 在线视频国产一区| 中文字幕精品综合| 日韩国产一二三区| 一本久久精品一区二区| 欧美哺乳videos| 亚洲午夜三级在线| 不卡的看片网站| 久久久久久久av麻豆果冻| 亚洲大型综合色站| 91麻豆国产在线观看| 久久综合av免费| 毛片av一区二区| 欧美日韩亚洲高清一区二区| 亚洲视频在线观看一区| 国产精品正在播放| 日韩美女一区二区三区四区| 亚洲福利视频导航| 99re这里只有精品视频首页| 久久久不卡影院| 国产激情视频一区二区三区欧美 | 91麻豆精品国产自产在线观看一区| 综合欧美亚洲日本| 成人爽a毛片一区二区免费| 久久青草国产手机看片福利盒子| 亚洲香蕉伊在人在线观| 91亚洲精品久久久蜜桃网站| 日本一区二区三区在线观看| 国产麻豆日韩欧美久久| 精品精品欲导航| 美日韩黄色大片| 欧美成人精品高清在线播放| 麻豆国产欧美一区二区三区| 欧美精品1区2区3区| 视频一区视频二区在线观看| 在线观看日韩国产| 日韩中文字幕亚洲一区二区va在线| 欧美在线短视频| 五月天视频一区|