⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 libcrfpp.cpp

📁 Conditional Random Fields的训练识别工具
💻 CPP
字号:
/*  CRF++ -- Yet Another CRF toolkit  $Id: libcrfpp.cpp 1558 2006-11-25 04:59:20Z taku $;  Copyright(C) 2005 Taku Kudo <taku@chasen.org>  This is free software with ABSOLUTELY NO WARRANTY.  This library is free software; you can redistribute it and/or  modify it under the terms of the GNU Lesser General Public  License as published by the Free Software Foundation; either  version 2.1 of the License, or(at your option) any later version.  This library is distributed in the hope that it will be useful,  but WITHOUT ANY WARRANTY; without even the implied warranty of  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU  Lesser General Public License for more details.  You should have received a copy of the GNU Lesser General Public  License along with this library; if not, write to the Free Software  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA*/#include "crfpp.h"#include <string>#ifdef HAVE_CONFIG_H#include "config.h"#endif#define LIBCRFPP_ID 113212namespace {  std::string errorStr;}struct crfpp_t {  int allocated;  CRFPP::Tagger* ptr;};#if defined(_WIN32) && ! defined(__CYGWIN__)#include <windows.h>BOOL __stdcall DllMain( HINSTANCE hinst, DWORD dwReason, void* ){  return TRUE;}#endifcrfpp_t* crfpp_new(int argc, char **argv){  crfpp_t *c = new crfpp_t;  CRFPP::Tagger *ptr = CRFPP::createTagger(argc, argv);  if (! c || ! ptr) {    delete c;    delete ptr;    errorStr = CRFPP::getTaggerError();    return 0;  }  c->ptr = ptr;  c->allocated = LIBCRFPP_ID;  return c;}crfpp_t* crfpp_new2(char *arg){  crfpp_t *c = new crfpp_t;  CRFPP::Tagger *ptr = CRFPP::createTagger(arg);  if (! c || ! ptr) {    delete c;    delete ptr;    errorStr = CRFPP::getTaggerError();    return 0;  }  c->ptr = ptr;  c->allocated = LIBCRFPP_ID;  return c;}const char* crfpp_strerror(crfpp_t *c){  if (! c || ! c->allocated) return const_cast<char *> (errorStr.c_str());  return c->ptr->what();}void crfpp_destroy(crfpp_t *c){  if (c && c->allocated) {    delete c->ptr;    delete c;  }  c = 0;}#define CRFPP_CHECK_FIRST_ARG(c,t)  \ if (!(c) || (c)->allocated != LIBCRFPP_ID) { \    errorStr = "first argment seems to be invalid"; \    return 0; \ } CRFPP::Tagger *(t) = (c)->ptr;bool     crfpp_add2(crfpp_t* c, size_t s, const char **line){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->add(s, line);}bool     crfpp_add(crfpp_t* c, const char*s){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->add(s);}size_t   crfpp_size(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->size();}size_t   crfpp_xsize(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->xsize();}size_t   crfpp_result(crfpp_t* c, size_t i){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->result(i);}size_t   crfpp_answer(crfpp_t* c, size_t i){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->answer(i);}size_t   crfpp_y(crfpp_t* c, size_t i){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->y(i);}size_t   crfpp_ysize(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->ysize();}double   crfpp_prob(crfpp_t* c, size_t i, size_t j){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->prob(i,j);}double   crfpp_prob2(crfpp_t* c, size_t i){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->prob(i);}double   crfpp_prob3(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->prob();}double   crfpp_alpha(crfpp_t* c, size_t i, size_t j){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->alpha(i,j);}double   crfpp_beta(crfpp_t* c, size_t i, size_t j){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->beta(i,j);}double   crfpp_best_cost(crfpp_t* c, size_t i, size_t j){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->best_cost(i,j);}double   crfpp_emisstion_cost(crfpp_t* c, size_t i, size_t j){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->emission_cost(i,j);}const int* crfpp_emisstion_vector(crfpp_t* c, size_t i, size_t j){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->emission_vector(i,j);}double   crfpp_next_transition_cost(crfpp_t* c, size_t i, size_t j, size_t k){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->next_transition_cost(i,j,k);}double   crfpp_prev_transition_cost(crfpp_t* c, size_t i, size_t j, size_t k){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->next_transition_cost(i,j,k);}const  int* crfpp_next_transition_vector(crfpp_t* c, size_t i, size_t j, size_t k){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->next_transition_vector(i,j,k);}const int* crfpp_prev_transition_vector(crfpp_t* c, size_t i, size_t j, size_t k){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->next_transition_vector(i,j,k);}size_t crfpp_dsize(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->dsize();}const float* crfpp_weight_vector(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->weight_vector();}double   crfpp_Z(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->Z();}bool     crfpp_parse(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->parse();}bool     crfpp_empty(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->empty();}bool     crfpp_clear(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->clear();}bool     crfpp_next(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->next();}const char*   crfpp_yname(crfpp_t* c, size_t i){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->yname(i);}const char*   crfpp_y2(crfpp_t* c, size_t i){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->y2(i);}const char*   crfpp_x(crfpp_t* c, size_t i, size_t j){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->x(i,j);}const char**  crfpp_x2(crfpp_t* c, size_t i){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->x(i);}const char*  crfpp_parse_tostr(crfpp_t* c, const char* str){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->parse(str);}const char*  crfpp_parse_tostr2(crfpp_t* c, const char* str, size_t len){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->parse(str, len);}const char*  crfpp_parse_tostr3(crfpp_t* c, const char* str,  size_t len, char *ostr, size_t len2){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->parse(str, len, ostr, len2);}const char*  crfpp_tostr(crfpp_t* c){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->toString();}const char*  crfpp_tostr2(crfpp_t* c, char *ostr, size_t len){  CRFPP_CHECK_FIRST_ARG(c,t);  return t->toString(ostr, len);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -