📄 libcrfpp.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 + -