您的位置:首页 > 其它

VNR共享辞书中翻译的转码和代理

2015-06-05 21:20 369 查看
源地址:http://sakuradite.com/topic/724

优先进入官网看,官网不行再观看本文

坏掉的功能

由于共享辞书的变更,部分以前的功能变得不那么好用了。

[
]重命名为[[m]]

在前缀、后缀中使用的[
],现在改为用[[m]]了。带来不便很抱歉!

边界+姓名+后缀

当姓名打开边界后,将可能无法正常的与后缀匹配。

比如,如果定义了两个词条:

姓名:悠真 => 悠真


后缀:兄 => 哥哥

那么一旦对姓名或者后缀打开词条边界的选项,那么VNR将不能在翻译"悠真兄"了。

翻译的解码



VNR改为使用和VTrans相同的SynCFG的来处理词条。

共享辞书中所有翻译、姓名、前缀、后缀、读法的词条都会被编译为SynCFG的语法。下边是一些SynCFG语法的例子:

翻译:こんにちは => 你好


SynCFG: x ||| こんにちは ||| 你好

姓名:ゆい => 由依

SynCFG: m ||| ゆい ||| 由依

后缀:ちゃん => 酱

SynCFG: m ||| [[m]]ちゃん ||| [[m]]酱

这里以最后一个SynCFG为例。它为【ちゃん】定义了翻译,并且这个翻译只有在姓名(m)后出现时,才会被应用。而应用了词条后的结果,仍然属于姓名(m)。

总的来说,SynCFG的语法如下。这个语法在VNR正在Cache里生成的词条的文件中是可以观察到的。

LHS_Role ||| RHS_Source ||| RHS_Target ||| Features

Role的集合

比如,可以用[[m,n]]来匹配任何m(姓名)和n(noun)的集合。

多个Roles

在一个规则里,是可以定义多个Role的。

比方说,下边的规则可以用来翻译:ゆいちゃんを殺す

m ||| ゆい ||| 由依


m ||| [[m]]ちゃん ||| [[m]]酱

v ||| 殺す ||| 杀死

x ||| [[m]]を[[v]] || [[v]] [[m]]

要注意的是,当使用多个相同的role在一个规则里时,一定要加上数字编号。比如:

x ||| [[x#1]][[x#2]] || [[x#1]][[x#2]]

这条规则可以将相邻的两个位置的phrasae合并为一个。

另外,数字编号并不要求是连续增加的。比如下边的规则和上边的那个是一样的。

x ||| [[x#10]][[x#5]] || [[x#10]][[x#5]]

再比如,下边的规则都是等价的:


x ||| [[m,n]]を[[v]] ||| [[v]] [[m,n]]

x ||| [[m,n#1]]を[[v#2]] ||| [[v#2]] [[m,n#1]]

x ||| [[m,n#1]]を[[v#2]] ||| [[#2]] [[#1]]

x ||| [[m,n#1]]を[[v]] ||| [[v]] [[#1]]



另外当role只有一个时,翻译中的role的表达式是可以省略的。比如下边的规则都是等价的:

adj ||| [[m,n]]の ||| [[m,n]]的


adj ||| [[m,n#1]]の => [[m,n#1]]的

adj ||| [[m,n#1]]の => [[#1]]的

adj ||| [[m,n#1]]の => [[]]的

adj ||| [[m,n]]の => [[]]的

自定义Role

我建议大家用n来代表名词,v代表动词,x代表未知词组,m代表姓名。

如果大家需要自定义Role,可以使用[_a-yA-Y0-9]中的字母任意搭配,比如可以用adj来代表形容词。

基本和C等变成语言中的变量名字是一样的,但是要注意:



不要用字母Z。VNR内部保留Z做别的拥堵。自定义的role请用至少两个字母表示。单个的字母还是保留给VNR以后可能的用途吧。



与正则表达交织

当SynCFG的Role出现在匹配文本中时,由于技术困难,正则表达不可以出现named group,比如下边这样的表达式是不可以出现的:

(A|BC|D) [[x]]

如果需要使用或的关系,可以使用unnamed group,比如下边:

(?:A|BC|D) [[x]]

翻译的代理



添加了新的代理词条,可以用来定义编码特定翻译Role的方法。

比方说:如果为m(姓名)定义了"佐藤=>佐藤"的词条。

那么VNR在编码m词条时,就会用佐藤来替代姓名了。

这样就可以避免姓名翻译词条会扰乱翻译的问题了。

要注意的是,代理词条的添加会是很危险的,词条提交后,VNR默认总是设定为私有的。大家一定要debug,debug,再debug,毫无问题后,再设定代理词条为公开才好。

另外,代理词条最好要避免出现简体字才好。比如:斉藤 => 齐藤,由于齐是简体字,设定为代理词条可能会扰乱正体中文的翻译的。要选择那些比如:佐藤那样,不包含简体字的+翻译器认识的+一一对应的姓名作为代理词条才好。

再比如:"ゆい=>由依"就不是一个好的代理词条。因为有些其他姓名(比如:ユイ、由依)的翻译也可能是由依。翻译和原始的姓名不是一一对应的。


提问:

不过如此的话需要添加的辞条数量似乎太庞大。

回答:其实这个SynCFG是阉割版的。缺少概率的多叉树和分词。我在训练vtrans的时候使用UniDic分词的,可以知道单词的边界的词性。 我想下一步,首先删掉VNR对IPADIC和CaboCha的支持,改用和VNR服务器一样UniDic+align字典(比如EDICT)来分词。然后再把UniDic分词的词性的结果annotate到翻译里边。

另外,这样也可以让VNR鼠标查词的时间复杂度从O(N)降到O(1)(N为字典的容量),来实现瞬时的取词,不用像现在这样还要等待五秒钟。

提问:

是说syncfg定义的“杀死”只会在能识别[[m]]的位置使用,而其它的[[x]]部分则不会被翻译为杀死呢。



[b]回答:[/b]

刚刚添加语法可以用比如吧:[[m,x]]来代表一个m和x的set。



[b]提问:[/b]

看完英文例子了,可惜限制过大,基本只有很正经的GAL总是称呼标准人名才用得 上

[b]回答:

[/b]

其实那个代理主要就是为了修正名字的。通过使用代理可以是的替换自定义人物姓名变得non-intrusive,机器翻译不会被替换后的1234.567之类的影响到了。



[b]提问:[/b]

后缀的处理使得酱适用后因为依旧属于[[m]]所以后缀的の也能适用了吧?

回答:

恩,后缀规则可以被迭代。 比如:如果定义了「さま=大人」和「の=的」的后缀,那么「さまの」就会被翻译成【大人的】。

然而,「のさま」也会被翻译成【的大人】,而这应该不是我们想要的。我觉得【の】最好先不要定义为后缀。比如,如果像下边这样定义:

[b]m ||| [[m]]さな ||| [[m]]大人[/b]

adj ||| [[m]]の ||| [[m]]的

那么就只有「さなの」会被翻译为形容词,而「のさな」不会被翻译了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: