亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Python > 正文

在Python上基于Markov鏈生成偽隨機文本的教程

2020-01-04 19:28:30
字體:
來源:轉載
供稿:網友

 首先看一下來自Wolfram的定義

    馬爾可夫鏈是隨機變量{X_t}的集合(t貫穿0,1,...),給定當前的狀態,未來與過去條件獨立。

Wikipedia的定義更清楚一點兒

    ...馬爾可夫鏈是具有馬爾可夫性質的隨機過程...[這意味著]狀態改變是概率性的,未來的狀態僅僅依賴當前的狀態。

馬爾可夫鏈具有多種用途,現在讓我看一下如何用它生產看起來像模像樣的胡言亂語。

算法如下,


代碼如下
 

import randomclass Markov(object):def __init__(self, open_file): self.cache = {} self.open_file = open_file self.words = self.file_to_words() self.word_size = len(self.words) self.database()def file_to_words(self): self.open_file.seek(0) data = self.open_file.read() words = data.split() return wordsdef triples(self): """ Generates triples from the given data string. So if our string were"What a lovely day", we'd generate (What, a, lovely) and then(a, lovely, day). """if len(self.words) < 3:returnfor i in range(len(self.words) - 2):yield (self.words[i], self.words[i+1], self.words[i+2])def database(self): for w1, w2, w3 in self.triples():key = (w1, w2)if key in self.cache:self.cache[key].append(w3)else:self.cache[key] = [w3]def generate_markov_text(self, size=25): seed = random.randint(0, self.word_size-3) seed_word, next_word = self.words[seed], self.words[seed+1] w1, w2 = seed_word, next_word gen_words = [] for i in xrange(size):gen_words.append(w1)w1, w2 = w2, random.choice(self.cache[(w1, w2)]) gen_words.append(w2) return ' '.join(gen_words)

為了看到一個示例結果,我們從古騰堡計劃中拿了沃德豪斯的《My man jeeves》作為文本,示例結果如下。
 

In [1]: file_ = open('/home/shabda/jeeves.txt')In [2]: import markovgenIn [3]: markov = markovgen.Markov(file_)In [4]: markov.generate_markov_text()Out[4]: 'Can you put a few years of your twin-brother Alfred,who was apt to rally round a bit. I should strongly advocatethe blue with milk'

[如果想執行這個例子,請下載jeeves.txt和markovgen.py
馬爾可夫算法怎樣呢?

這是一個示例文本。

復制代碼 代碼如下:

"The quick brown fox jumps over the brown fox who is slow jumps over the brown fox who is dead."

這個文本對應的語料庫像這樣,
 

{('The', 'quick'): ['brown'], ('brown', 'fox'): ['jumps', 'who', 'who'], ('fox', 'jumps'): ['over'], ('fox', 'who'): ['is', 'is'], ('is', 'slow'): ['jumps'], ('jumps', 'over'): ['the', 'the'], ('over', 'the'): ['brown', 'brown'], ('quick', 'brown'): ['fox'], ('slow', 'jumps'): ['over'], ('the', 'brown'): ['fox', 'fox'], ('who', 'is'): ['slow', 'dead.']}

現在如果我們從"brown fox"開始,接下來的單詞可以是"jumps"或者"who"。如果我們選擇"jumps",然后當前的狀態就變成了"fox jumps",再接下的單詞就是"over",之后依此類推。

提示

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久精品欧美| 国产精品久久久久福利| 欧美激情欧美激情在线五月| 欧美日韩高清在线观看| 国产精品99久久久久久www| 欧美中文字幕视频在线观看| 欧美日韩国产一区二区| 97免费在线视频| 欧美日韩裸体免费视频| 91av网站在线播放| 97在线视频免费看| 日韩国产中文字幕| 欧美午夜性色大片在线观看| 国产成人欧美在线观看| 欧美性猛交丰臀xxxxx网站| 91在线|亚洲| 97**国产露脸精品国产| 欧美在线视频免费观看| 亚洲аv电影天堂网| 日韩专区中文字幕| 97国产精品视频人人做人人爱| 久久影院在线观看| 久久精品中文字幕免费mv| 亚洲国产成人精品久久| 欧美激情一二区| 亚洲欧洲免费视频| 亚洲国产三级网| 精品亚洲va在线va天堂资源站| 亚洲18私人小影院| 成人亚洲综合色就1024| 亚洲精品电影在线观看| 色偷偷91综合久久噜噜| 福利视频第一区| 亚洲精品日韩激情在线电影| 国产精品男女猛烈高潮激情| 色婷婷久久一区二区| 国产精品极品在线| 91精品视频在线| 日韩亚洲综合在线| 国产精品高潮视频| 久久69精品久久久久久国产越南| 亚洲免费影视第一页| 伊人成人开心激情综合网| 国产成人精品久久二区二区91| 成人av资源在线播放| 5252色成人免费视频| 亚洲精品日韩久久久| 欧美性精品220| 精品一区二区三区电影| 欧美成人黄色小视频| 91精品国产91久久久久久久久| 国产精品黄色影片导航在线观看| 97成人超碰免| 成人高h视频在线| 成人国产精品一区二区| 欧美日韩黄色大片| 欧美激情中文网| 2019中文字幕在线观看| 亚洲一区二区少妇| 日韩天堂在线视频| 欧美在线视频一二三| 国产精品久久99久久| 性欧美xxxx| 国产精品午夜国产小视频| 欧美超级免费视 在线| 97色在线观看免费视频| 日韩中文字幕精品| 日本电影亚洲天堂| 国产精品毛片a∨一区二区三区|国| 亚洲激情电影中文字幕| 久久影视电视剧凤归四时歌| 亚洲第一精品夜夜躁人人躁| 亚洲码在线观看| 久久精品成人动漫| 九九热最新视频//这里只有精品| 成人激情视频在线观看| 亚洲精品v天堂中文字幕| 亚洲精品一区二三区不卡| 国产午夜精品全部视频播放| 欧美一级大片视频| 日韩中文字幕在线视频播放| 午夜精品一区二区三区在线| 8x海外华人永久免费日韩内陆视频| 最新国产精品亚洲| 亚洲最大中文字幕| 伊人久久免费视频| 国产在线日韩在线| 国产精品稀缺呦系列在线| 亚洲综合中文字幕68页| 国产成人+综合亚洲+天堂| 91香蕉嫩草神马影院在线观看| 国产精品av免费在线观看| 国产精品福利网| 亚洲第一天堂无码专区| 青草青草久热精品视频在线网站| 色视频www在线播放国产成人| 久久精品国产亚洲| 91精品视频在线| 日本亚洲欧洲色α| 一区二区国产精品视频| 国产精品久久久久999| 伊人久久久久久久久久久久久| 亚洲成人黄色网| 亚洲天堂男人天堂| 中文字幕在线看视频国产欧美| 欧美黑人一级爽快片淫片高清| 成人免费观看网址| 国产成人精品久久久| 亚洲大胆人体视频| 92国产精品久久久久首页| 5252色成人免费视频| 欧洲亚洲在线视频| 国产不卡精品视男人的天堂| 亚洲成色777777在线观看影院| 国产免费一区视频观看免费| 国产精品视频专区| 疯狂蹂躏欧美一区二区精品| 欧美一区二区三区艳史| 欧美电影在线观看高清| 欧美性极品xxxx做受| 欧美精品在线观看| 国产在线观看精品| 亚洲精品中文字幕av| 日本久久久久久久久久久| 91精品成人久久| 久久精品视频在线播放| 日韩电影视频免费| 精品国产依人香蕉在线精品| 欧美日韩爱爱视频| 亚洲人成77777在线观看网| 欧美色欧美亚洲高清在线视频| 国产精品黄页免费高清在线观看| 日韩在线免费av| 中文字幕日韩综合av| 欧美成人午夜激情视频| 欧美性猛交xxxx免费看久久久| 久久成人精品视频| 亚洲夜晚福利在线观看| 日韩av网站大全| 欧美激情xxxx性bbbb| 亚洲最大成人免费视频| 中文字幕亚洲无线码a| 日韩欧美在线视频| 91精品国产自产在线老师啪| 在线成人一区二区| 国产亚洲在线播放| 欧美成人午夜影院| 亚洲欧美国内爽妇网| 亚洲精品日韩av| 国产精品高潮呻吟久久av野狼| 日本道色综合久久影院| 57pao国产精品一区| 亚洲第一免费播放区| 精品国产依人香蕉在线精品| 亚洲欧美制服中文字幕| 国外成人在线直播| 成人精品福利视频| 精品国产成人av| 国产亚洲在线播放| 久久九九亚洲综合| 欧美在线视频一区二区| 欧美在线视频网站| 不卡av日日日| 日韩高清av在线|