我想构建一个机器人,向某人询问几个简单的问题,并根据回答进行分支。我意识到从人类回答中解析意义将是具有挑战性的,但是如何设置程序以处理对话的"状态"?
这将是人与机器人之间的一对一对话。
我想构建一个机器人,向某人询问几个简单的问题,并根据回答进行分支。我意识到从人类回答中解析意义将是具有挑战性的,但是如何设置程序以处理对话的"状态"?
这将是人与机器人之间的一对一对话。
import random, sys
NONWORD = "\n"
STARTKEY = NONWORD, NONWORD
MAXGEN=1000
class MarkovChainer(object):
def __init__(self):
self.state = dict()
def input(self, input):
word1, word2 = STARTKEY
for word3 in input.split():
self.state.setdefault((word1, word2), list()).append(word3)
word1, word2 = word2, word3
self.state.setdefault((word1, word2), list()).append(NONWORD)
def output(self):
output = list()
word1, word2 = STARTKEY
for i in range(MAXGEN):
word3 = random.choice(self.state[(word1,word2)])
if word3 == NONWORD: break
output.append(word3)
word1, word2 = word2, word3
return " ".join(output)
if __name__ == "__main__":
c = MarkovChainer()
c.input(sys.stdin.read())
print c.output()
一些人已经提到过,对于典型的聊天机器人来说,状态并不是一个重要组成部分:
一个纯马尔可夫模型的实现可能会在实时增加词汇和表格时表达出一种非常宽松的状态——人类对话者之前的话语可能会在后面的对话中偶然地被重复使用——但马尔可夫模型没有任何固有的机制来选择或产生这样的回应。
基于解析的机器人(例如ELIZA)通常试图响应用户最近输入的(某些)语义内容,而不太考虑先前的交流。
尽管如此,您无论使用什么样的输入解析和语句合成模型,都可以向聊天机器人添加一些状态。如何做取决于您想通过状态实现什么目标,从您的问题中并不清楚。然而,有一些一般性的想法:
创建关键字堆栈。当人类提供输入时,从他们的陈述/问题中解析出关键字,并将这些关键字放入某种堆栈中。当聊天机器人无法在最近的输入中想出令人信服的回应时——或者,也许只是为了混合一下——回到您的堆栈中,获取先前的关键字,并使用它来生成下一个语句。为获得额外加分,让机器人明确地承认它正在回到之前的主题上,例如“等一下,HUMAN,您之前提到过foo。[由foo引发的句子]”。
将类似RPG的对话逻辑构建到机器人中。当解析人类输入时,切换特定对话提示或用户内容的标志,并有条件地改变聊天机器人可以谈论的内容或通信方式。例如,一个在污言秽语上发怒(或责骂、或笑)的聊天机器人相当普遍;一个会变得激动,并且有条件地一直保持这种状态直到道歉为止的聊天机器人,将是这种状态的有趣变化。切换输出到全大写,加入对抗性修辞或要求或哭泣等。
你能进一步澄清一下你希望使用这种状态来达到什么目的吗?
#lukebot-trainer.py
import pickle
b=open('war&peace.txt')
text=[]
for line in b:
for word in line.split():
text.append (word)
b.close()
textset=list(set(text))
follow={}
for l in range(len(textset)):
working=[]
check=textset[l]
for w in range(len(text)-1):
if check==text[w] and text[w][-1] not in '(),.?!':
working.append(str(text[w+1]))
follow[check]=working
a=open('lexicon-luke','wb')
pickle.dump(follow,a,2)
a.close()
#lukebot.py
import pickle,random
a=open('lexicon-luke','rb')
successorlist=pickle.load(a)
a.close()
def nextword(a):
if a in successorlist:
return random.choice(successorlist[a])
else:
return 'the'
speech=''
while speech!='quit':
speech=raw_input('>')
s=random.choice(speech.split())
response=''
while True:
neword=nextword(s)
response+=' '+neword
s=neword
if neword[-1] in ',?!.':
break
print response
你可以使用“ChatterBot”,并使用“flask-chatterbot-master”进行本地托管。
链接:
祝一切顺利,
Ratnakar
我不确定这是否符合您的要求,但有一个叫做ELIZA的老程序,它可以通过进行一些简单的文本转换来保持对话。
如果我没记错的话,许多人都相信他们正在与真人交谈,并与之展开了长时间的复杂对话。