偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

使用 Python 創(chuàng)建一個簡單的基于規(guī)則的聊天機(jī)器人

開發(fā) 后端
聊天機(jī)器人本身是一種機(jī)器或軟件,它通過文本或句子模仿人類交互。 簡而言之,可以使用類似于與人類對話的軟件進(jìn)行聊天。

[[431911]]

還記得這個價值一個億的AI核心代碼?

 

使用 Python 創(chuàng)建一個簡單的基于規(guī)則的聊天機(jī)器人

 

 

  1. while True
  2.   AI = input('我:'
  3.   print(AI.replace("嗎"" ").replace('?','!').replace('?','!')) 

 

以上這段代碼就是我們今天的主題,基于規(guī)則的聊天機(jī)器人

聊天機(jī)器人

聊天機(jī)器人本身是一種機(jī)器或軟件,它通過文本或句子模仿人類交互。 簡而言之,可以使用類似于與人類對話的軟件進(jìn)行聊天。

為什么要嘗試創(chuàng)建聊天機(jī)器人? 也許你對一個新項目感興趣,或者公司需要一個,或者想去拉投資。 無論動機(jī)是什么,本文都將嘗試解釋如何創(chuàng)建一個簡單的基于規(guī)則的聊天機(jī)器人。

基于規(guī)則的聊天機(jī)器人

什么是基于規(guī)則的聊天機(jī)器人?它是一種基于特定規(guī)則來回答人類給出的文本的聊天機(jī)器人。由于它基于強加的規(guī)則所以這個聊天機(jī)器人生成的響應(yīng)幾乎是準(zhǔn)確的;但是,如果我們收到與規(guī)則不匹配的查詢,聊天機(jī)器人將不會回答。與它相對的另一個版本是基于模型的聊天機(jī)器人,它通過機(jī)器學(xué)習(xí)模型來回答給定的查詢。(二者的區(qū)別就是基于規(guī)則的需要我們指定每一條規(guī)則,而且基于模型的會通過訓(xùn)練模型自動生成規(guī)則,還記得我們上一篇的”機(jī)器學(xué)習(xí)介紹“嗎,"機(jī)器學(xué)習(xí)為系統(tǒng)提供無需明確編程就能根據(jù)經(jīng)驗自動學(xué)習(xí)和改進(jìn)的能力。")

基于規(guī)則的聊天機(jī)器人可能基于人類給出的規(guī)則,但這并不意味著我們不使用數(shù)據(jù)集。聊天機(jī)器人的主要目標(biāo)仍然是自動化人類提出的問題,所以我們還是需要數(shù)據(jù)來制定特定的規(guī)則。

在本文中,我們將利用余弦相似距離作為基礎(chǔ)開發(fā)基于規(guī)則的聊天機(jī)器人。余弦相似度是向量(特別是內(nèi)積空間的非零向量)之間的相似度度量,常用于度量兩個文本之間的相似度。

我們將使用余弦相似度創(chuàng)建一個聊天機(jī)器人,通過對比查詢與我們開發(fā)的語料庫之間的相似性來回答查詢提出的問題。這也是我們最初需要開發(fā)我們的語料庫的原因。

創(chuàng)建語料庫

對于這個聊天機(jī)器人示例,我想創(chuàng)建一個聊天機(jī)器人來回答有關(guān)貓的所有問題。 為了收集關(guān)于貓的數(shù)據(jù),我會從網(wǎng)上抓取它。

 

  1. import bs4 as bs 
  2. import urllib.request#Open the cat web data page 
  3. cat_data = urllib.request.urlopen('https://simple.wikipedia.org/wiki/Cat').read() 
  4. #Find all the paragraph html from the web page 
  5. cat_data_paragraphs = bs.BeautifulSoup(cat_data,'lxml').find_all('p'
  6. #Creating the corpus of all the web page paragraphs 
  7. cat_text = '' 
  8. #Creating lower text corpus of cat paragraphs 
  9. for p in cat_data_paragraphs: 
  10. cat_text += p.text.lower() 
  11. print(cat_text) 

 

 

使用 Python 創(chuàng)建一個簡單的基于規(guī)則的聊天機(jī)器人

 

使用上面的代碼,會得到來自wikipedia頁面的段落集合。 接下來,需要清理文本以去除括號編號和空格等無用的文本。

 

  1. import re 
  2. cat_text = re.sub(r'\s+'' ',re.sub(r'\[[0-9]*\]'' ', cat_text)) 

 

上述代碼將從語料庫中刪除括號號。我特意沒有去掉這些符號和標(biāo)點符號,因為當(dāng)與聊天機(jī)器人進(jìn)行對話時,這樣聽起來會很自然。

最后,我將根據(jù)之前創(chuàng)建的語料庫創(chuàng)建一個句子列表。

 

  1. import nltk 
  2. cat_sentences = nltk.sent_tokenize(cat_text) 

 

 

 

我們的規(guī)則很簡單:將聊天機(jī)器人的查詢文本與句子列表中的每一個文本之間的進(jìn)行余弦相似性的度量,哪個結(jié)果產(chǎn)生的相似度最接近(最高余弦相似度)那么它就是我們的聊天機(jī)器人的答案。

創(chuàng)建一個聊天機(jī)器人

我們上面的語料庫仍然是文本形式,余弦相似度不接受文本數(shù)據(jù);所以需要將語料庫轉(zhuǎn)換成數(shù)字向量。通常的做法是將文本轉(zhuǎn)換為詞袋(單詞計數(shù))或使用TF-IDF方法(頻率概率)。在我們的例子中,我們將使用TF-IDF。

我將創(chuàng)建一個函數(shù),它接收查詢文本,并根據(jù)以下代碼中的余弦相似性給出一個輸出。讓我們看一下代碼。

  1. from sklearn.metrics.pairwise import cosine_similarity 
  2. from sklearn.feature_extraction.text import TfidfVectorizer 
  3. def chatbot_answer(user_query): 
  4.  
  5. #Append the query to the sentences list 
  6. cat_sentences.append(user_query)  
  7. #Create the sentences vector based on the list 
  8. vectorizer = TfidfVectorizer() 
  9. sentences_vectors = vectorizer.fit_transform(cat_sentences) 
  10.  
  11. #Measure the cosine similarity and take the second closest index because the first index is the user query 
  12. vector_values = cosine_similarity(sentences_vectors[-1], sentences_vectors) 
  13. answer = cat_sentences[vector_values.argsort()[0][-2]]  
  14. #Final check to make sure there are result present. If all the result are 0, means the text input by us are not captured in the corpus 
  15. input_check = vector_values.flatten() 
  16. input_check.sort() 
  17.  
  18. if input_check[-2] == 0: 
  19. return "Please Try again" 
  20. else:  
  21. return answer 

 

我們可以把上面的函數(shù)使用下面的流程圖進(jìn)行表示:

 

使用 Python 創(chuàng)建一個簡單的基于規(guī)則的聊天機(jī)器人

 

最后,使用以下代碼創(chuàng)建一個簡單的回答交互。

 

  1. print("Hello, I am the Cat Chatbot. What is your meow questions?:"
  2. while(True): 
  3. query = input().lower() 
  4. if query not in ['bye''good bye''take care']: 
  5. print("Cat Chatbot: "end=""
  6. print(chatbot_answer(query)) 
  7. cat_sentences.remove(query) 
  8. else
  9. print("See You Again"
  10. break 

 

上面的腳本將接收查詢,并通過我們之前開發(fā)的聊天機(jī)器人處理它們。

 

 

從上面的圖片中看到的,結(jié)果還是可以接受的,但有也有些奇怪的回答。但是我們要想到,目前只從一個數(shù)據(jù)源中得到的結(jié)果,并且也沒有做任何的優(yōu)化。如果我們用額外的數(shù)據(jù)集和規(guī)則來改進(jìn)它,它肯定會更好地回答問題。

總結(jié)

聊天機(jī)器人項目是一個令人興奮的數(shù)據(jù)科學(xué)項目,因為它在許多領(lǐng)域都有幫助。在本文中,我們使用從網(wǎng)頁中獲取的數(shù)據(jù),利用余弦相似度和TF-IDF,用Python創(chuàng)建了一個簡單的聊天機(jī)器人項目,真正的將我們的1個億的項目落地。其實這里面還有很多的改進(jìn):

  • 向量化的選擇,除了TF-IDF還可以使用word2vec,甚至使用預(yù)訓(xùn)練的bert提取詞向量。
  • 回答環(huán)節(jié),其實就是通過某種特定的算法或者規(guī)則從我們的語料庫中搜索最匹配的答案,本文中使用的相似度TOP1的方法其實就是一個最簡單的類greedsearch的方法,對于答案結(jié)果的優(yōu)化還可以使用類beamsearch 的算法提取回答的匹配項。
  • 等等很多

 

在端到端的深度學(xué)習(xí)興起之前,很多的聊天機(jī)器人都是這樣基于規(guī)則來運行的并且也有很多落地案例,如果你想快速的做一個POC展示,這種基于規(guī)則方法還是非常有用的。

 

責(zé)任編輯:華軒 來源: 今日頭條
相關(guān)推薦

2021-11-30 10:56:43

ChatterBot機(jī)器人人工智能

2020-12-02 13:00:17

Recast.AI聊天機(jī)器人人工智能

2022-08-04 07:03:41

AnswersInfobip無代碼

2022-09-30 13:55:46

Python機(jī)器人

2023-04-05 19:32:28

2021-05-24 15:29:24

人工智能機(jī)器人聊天

2022-07-05 06:42:01

聊天機(jī)器人人工智能

2025-06-04 08:21:28

2020-02-26 17:39:18

Python機(jī)器人Word

2018-06-08 16:18:43

Python微信聊天機(jī)器人

2023-03-08 08:00:00

機(jī)器人開發(fā)

2016-10-09 13:40:44

PythonSlack聊天機(jī)器人

2017-06-08 10:07:53

機(jī)器人銀行微軟

2013-04-15 17:02:33

2020-02-20 09:00:00

網(wǎng)絡(luò)應(yīng)用數(shù)據(jù)技術(shù)

2023-12-18 19:05:34

2017-03-28 12:21:21

機(jī)器人定義

2020-02-02 09:19:14

聊天機(jī)器人機(jī)器人智能

2019-04-19 14:40:15

代碼Python機(jī)器人

2016-02-16 14:46:33

聊天機(jī)器人機(jī)器學(xué)習(xí)自然語言
點贊
收藏

51CTO技術(shù)棧公眾號