0
|
1 /*
|
|
2 * $Id: kaiseki.h,v 1.5 2003/05/11 18:35:54 hiroo Exp $
|
|
3 */
|
|
4
|
|
5 /*
|
|
6 * FreeWnn is a network-extensible Kana-to-Kanji conversion system.
|
|
7 * This file is part of FreeWnn.
|
|
8 *
|
|
9 * Copyright Kyoto University Research Institute for Mathematical Sciences
|
|
10 * 1987, 1988, 1989, 1990, 1991, 1992
|
|
11 * Copyright OMRON Corporation. 1987, 1988, 1989, 1990, 1991, 1992, 1999
|
|
12 * Copyright ASTEC, Inc. 1987, 1988, 1989, 1990, 1991, 1992
|
|
13 * Copyright FreeWnn Project 1999, 2000, 2003
|
|
14 *
|
|
15 * Maintainer: FreeWnn Project <freewnn@tomo.gr.jp>
|
|
16 *
|
|
17 * This program is free software; you can redistribute it and/or modify
|
|
18 * it under the terms of the GNU General Public License as published by
|
|
19 * the Free Software Foundation; either version 2 of the License, or
|
|
20 * (at your option) any later version.
|
|
21 *
|
|
22 * This program is distributed in the hope that it will be useful,
|
|
23 * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
24 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
25 * GNU General Public License for more details.
|
|
26 *
|
|
27 * You should have received a copy of the GNU General Public License
|
|
28 * along with this program; if not, write to the Free Software
|
|
29 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
30 */
|
|
31
|
|
32 #ifndef JSERVER_KAISEKI_H
|
|
33 #define JSERVER_KAISEKI_H 1
|
|
34
|
|
35 #ifdef STDC_HEADERS
|
|
36 # include <sys/types.h>
|
|
37 #endif /* STDC_HEADERS */
|
|
38
|
|
39 #ifdef GLOBAL_VALUE_DEFINE
|
|
40 #define GLOBAL
|
|
41 #define GLOBAL_VAL(v) = (v)
|
|
42 #else
|
|
43 #define GLOBAL extern
|
|
44 #define GLOBAL_VAL(v)
|
|
45 #endif /* GLOBAL_VALUE_DEFINE */
|
|
46
|
|
47 #include "commonhd.h"
|
|
48 #include "ddefine.h"
|
|
49
|
|
50 /*********************
|
|
51 * header of daemon
|
|
52 **********************/
|
|
53 #define WNN_BUN 0
|
|
54 #define WNN_ZENKOUHO 1
|
|
55 #define WNN_SHO 0
|
|
56 #define WNN_DAI 1
|
|
57
|
|
58
|
|
59 #define _MININT 0x80000000
|
|
60 #define HIRA_HYOUKA -2000; /* 全候補取り出しの時の平仮名の評価値 */
|
|
61 #define KATA_HYOUKA -1000; /* 全候補取り出しの時の片仮名の評価値 */
|
|
62
|
|
63 #define _DIVID(val, div) (((int)(val) > (int)0) ? ((val) / (div)) : ((val) * (div)))
|
|
64
|
|
65 extern struct fzkkouho *getfzkoh_body ();
|
|
66 extern struct fzkkouho *getfzkoh1_body ();
|
|
67
|
|
68 #define getfzkoh(ichbnp_p,no) \
|
|
69 (((int)(no) < (int)FZKIBNO) ? &((ichbnp_p)->fzkib[no]) : getfzkoh_body(ichbnp_p,no))
|
|
70
|
|
71 #define getfzkoh1(ichbnp_p,no) \
|
|
72 (((int)(no) < (int)FZKIBNO) ? &((ichbnp_p)->fzkib1[no]) : getfzkoh1_body(ichbnp_p,no))
|
|
73
|
|
74 #define kan_ck_vector(h, v) \
|
|
75 (((((int)*((v) + ((h) / (sizeof(int)<<3))) >> (int)((int)(h) % (int)((int)sizeof(int)<<(int)3))) & 1) == 1) ? \
|
|
76 WNN_CONNECT_BK : WNN_NOT_CONNECT_BK)
|
|
77
|
|
78 GLOBAL struct FT *ft; /* カレントの付属語テーブル */
|
|
79
|
|
80 /* 解析エリアの管理用のリスト */
|
|
81 struct free_list
|
|
82 {
|
|
83 struct free_list *lnk;
|
|
84 int num;
|
|
85 };
|
|
86
|
|
87 #define FIRST_BZD_KOSUU 200 /* 最初に取り出す大文節解析エリア */
|
|
88 #define BZD_KOSUU 20 /* 足らんかったら付け加える大きさ */
|
|
89
|
|
90 #define FIRST_SBN_KOSUU 200 /* 最初に取り出す小文節解析エリア */
|
|
91 #define SBN_KOSUU 20 /* 足らんかったら付け加える大きさ */
|
|
92
|
|
93 #define FIRST_ICHBN_KOSUU 20 /* 最初に取り出す付属語解析エリア */
|
|
94 #define ICHBN_KOSUU 4 /* 足らんかったら付け加える大きさ */
|
|
95
|
|
96 #define FIRST_JKDBN_KOSUU 50 /* 最初に取り出す大文節次候補エリア */
|
|
97 #define JKDBN_KOSUU 10 /* 足らんかったら付け加える大きさ */
|
|
98
|
|
99 #define FIRST_JKSBN_KOSUU 50 /* 最初に取り出す小文節次候補エリア */
|
|
100 #define JKSBN_KOSUU 10 /* 足らんかったら付け加える大きさ */
|
|
101
|
|
102 #define FIRST_JKSONE_KOSUU 300 /* 最初に取り出す小文節次候補エリア */
|
|
103 #define JKSONE_KOSUU 20 /* 足らんかったら付け加える大きさ */
|
|
104
|
|
105 /************************************************
|
|
106 * 擬似文節候補評価ルーチン *
|
|
107 ************************************************/
|
|
108 /*
|
|
109 #define HYOKAVAL(jiritugo_len, bnst_len) \
|
|
110 hyoka1(0x80, 0, (jiritugo_len), (bnst_len), 0)
|
|
111 */
|
|
112 /*
|
|
113 #define HYOKAVAL(hindo, jiritugo_len, bnst_len) \
|
|
114 hyoka1(0, hindo, (jiritugo_len), (bnst_len), 0)
|
|
115 */
|
|
116 #define HYOKAVAL(hindo, jiritugo_len, bnst_len) \
|
|
117 (c_env->hindoval * (hindo) \
|
|
118 + c_env->jirival * (jiritugo_len) \
|
|
119 + c_env->lenval * (bnst_len) )
|
|
120
|
|
121 /************************************************
|
|
122 * 小文節候補評価ルーチン *
|
|
123 ************************************************/
|
|
124 #define hyoka1(HINDO, HINDO_IN, LENGTH, BUNLNGTH, PRIO) \
|
|
125 (c_env->hindoval * (((HINDO) & 0x7f) + ((HINDO_IN) & 0x7f)) \
|
|
126 + c_env->jirival * (LENGTH) \
|
|
127 + c_env->lenval * (BUNLNGTH) \
|
|
128 + c_env->jishoval * (PRIO)\
|
|
129 + c_env->flagval * ((int)((HINDO) & 0x80) >> (int)7))
|
|
130
|
|
131 /************************************************
|
|
132 * 大文節候補評価ルーチン *
|
|
133 ************************************************/
|
|
134 /* 大文節の評価値
|
|
135 sbn_val * 小文節の評価値の和 / 小文節数
|
|
136 + sbn_cnt_val * 小文節数
|
|
137 + dbn_len_val * 大文節長
|
|
138 */
|
|
139 #define hyoka_dbn(SON_V, SBNCNT, DAILEN) \
|
|
140 ((c_env->sbn_val * (SON_V)) / (SBNCNT) \
|
|
141 + c_env->sbn_cnt_val * (SBNCNT) \
|
|
142 + c_env->dbn_len_val * (DAILEN))
|
|
143
|
|
144 /* 大文節の評価値を前の文節と接続できるか否かで変える。
|
|
145 divid : 1 前の文節と接続できる hyouka * 2
|
|
146 0 大文節の先頭 hyouka
|
|
147 -1 前の文節と接続できない hyouka / 2
|
|
148 */
|
|
149 #define DIVID_HYOUKA(hyouka, divid) \
|
|
150 (((divid) == 0) ? (hyouka) : \
|
|
151 (((divid)) > 0 ? ((hyouka) << 1) : ((hyouka) >> 1)))
|
|
152
|
|
153 /*********************
|
|
154 * kaiseki work area
|
|
155 **********************/
|
|
156 GLOBAL w_char *bun; /* D */
|
|
157 GLOBAL w_char giji_eisuu[20]; /* 擬似「英数」の定義 */
|
|
158 GLOBAL size_t maxchg;
|
|
159 GLOBAL int *maxj; /* maxj is counts to entries in jmt_ */
|
|
160
|
|
161 /* jmt_ptr is used in jmt0.c only. (untrue! do_dic_no.c use it 2003.05.09)
|
|
162 but it must be changed by clients.
|
|
163 jishobiki does not use it. this is sent to jishobiki by arguments
|
|
164 */
|
|
165
|
|
166 GLOBAL struct jdata *j_e_p; /* holds the current point to which jmtw_ is used */
|
|
167 GLOBAL struct jdata **jmt_;
|
|
168 GLOBAL struct jdata *jmtw_;
|
|
169 GLOBAL struct jdata **jmt_end;
|
|
170 GLOBAL struct jdata *jmtw_end;
|
|
171 GLOBAL struct jdata **jmt_ptr;
|
|
172 GLOBAL struct jdata ***jmtp;
|
|
173
|
|
174
|
|
175 /********************************
|
|
176 * 疑似自立語の品詞 *
|
|
177 ********************************/
|
|
178 #ifdef nodef
|
|
179 GLOBAL int sentou_no; /* 「先頭」文節先頭に成れるもの */
|
|
180 GLOBAL int suuji_no; /* 「数字」数詞相当 */
|
|
181 GLOBAL int katakanago_no; /* 「カナ」外来語など 名詞相当 */
|
|
182 GLOBAL int eisuu_no; /* 「英数」 */
|
|
183 GLOBAL int kigou_no; /* 「記号」 */
|
|
184 GLOBAL int toji_kakko_no; /* 「閉括弧」 */
|
|
185 GLOBAL int fuzokugo_no; /* 付属語だけ */
|
|
186 GLOBAL int kai_kakko_no; /* 「開括弧」 */
|
|
187 GLOBAL int giji_no; /* 疑似 */
|
|
188 #endif /* nodef */
|
|
189
|
|
190 #define sentou_no 0 /* 「先頭」文節先頭に成れるもの */
|
|
191 #define suuji_no 1 /* 「数字」数詞相当 */
|
|
192 #define katakanago_no 2 /* 「カナ」外来語など 名詞相当 */
|
|
193 #define eisuu_no 3 /* 「英数」 */
|
|
194 #define kigou_no 4 /* 「記号」 */
|
|
195 #define toji_kakko_no 5 /* 「閉括弧」 */
|
|
196 #define fuzokugo_no 6 /* 付属語だけ */
|
|
197 #define kai_kakko_no 7 /* 「開括弧」 */
|
|
198 #define giji_no 8 /* 疑似 */
|
|
199
|
|
200 #endif /* JSERVER_KAISEKI_H */
|
|
201
|