我希望使用自然语言解析库来进行简单的聊天机器人.我可以获得词性标签,但我总是想知道.你怎么用POS做的.如果我知道演讲的部分,那么呢?
我想这会对回复有所帮助.但是我可以使用哪些数据结构和架构.
词性标注器为输入文本中的单词指定标签.例如,流行的Penn Treebank标签集有大约40个标签,例如"复数名词","比较形容词","过去时动词"等.标签也解决了一些模糊性.例如,许多英语单词形式可以是名词或动词,但在其他词语的上下文中,它们的词性是明确的.因此,使用POS标签注释您的文本,您可以回答以下问题:我有多少名词?有多少句子不包含动词?等等.
对于聊天机器人,你显然需要更多.你需要找出文本中的主语和对象,以及它们附加的动词(谓词); 你需要解决anaphors(他或她指向哪个人),否定和量词的范围是什么(例如每个,超过3个)等等.
理想情况下,您需要将输入文本映射到某些逻辑表示(例如一阶逻辑),这可以让您引入推理以确定两个句子在意义上是否相等,或者在蕴涵关系中是否等等.
而POS标签会映射句子
Mary likes no man who owns a cat.
Run Code Online (Sandbox Code Playgroud)
这样的结构
Mary/NNP likes/VBZ no/DT man/NN who/WP owns/VBZ a/DT cat/NN ./.
Run Code Online (Sandbox Code Playgroud)
你宁愿需要这样的东西:
SubClassOf(
ObjectIntersectionOf(
Class(:man)
ObjectSomeValuesFrom(
ObjectProperty(:own)
Class(:cat)
)
)
ObjectComplementOf(
ObjectSomeValuesFrom(
ObjectInverseOf(ObjectProperty(:like))
ObjectOneOf(
NamedIndividual(:Mary)
)
)
)
)
Run Code Online (Sandbox Code Playgroud)
当然,虽然POS标签器的精确度和召回率接近100%,但更复杂的自动处理会更糟糕.
一个优秀的NLP Java库是LingPipe.但是,它不会超出POS标记,分块和命名实体识别.
归档时间: |
|
查看次数: |
3430 次 |
最近记录: |