0.1.7 • Published 7 years ago
markov-text v0.1.7
Markov Text 
A simple procedural text generator implementing Markov chains

Installation
npm install markov-textUsage
var Markov = require('markov-text');
const trainingText = 'Lorem ipsum dolor sit ammet'
options = {...}
const loremGenerator = new Markov(options) // Setup generator
loremGenerator.seed(trainingText) // Seed chain with "training" text
const generatedText = loremGenerator.generate(5) // Set length of the generated output.| Method | Arguments | Returns | Description |
|---|---|---|---|
| seed | trainingText | - | Seeds the generator with the training text. The generator splits the text into nGrams (pieces of n-characters or n-words length, depending on the mode)analog to chainlinks. |
| generate | outputLength | output | Returns the generated text of the specified length. (Length is in ngrams not in charcters/words) |
Options
You can pass in an options object when instancing the generator that accepts the following options:
| Property | Type | Options | Default | Description | |
|---|---|---|---|---|---|
| order | integer | 1-n | no | Specifies the length of the ngrams (chainlinks). Longer chainlinks will produce more coherent text but less 'creativity' | |
| mode | string | 'single' | 'multiple' | 'multiple' | Single mode will generate single words and will use training text as single independent words. Multiple mode will generate sentences and will use training text as word blocks. |
Debuggin
You can view the chain building step by setting up the enviroment variable DEBUG_CHAIN to true
DEBUG_CHAIN=true node myTextGeneratorExamples
Provided are two examples you can run using:
Metamorphosis

Uses a excerpt of Franz Kafka's Metamorphosis to generate sentences of the desired length.
npm run example:metamorphosisLotr

Uses all the names from characters of LOTR to generate a new one
npm run example:lotrCopyright for training texts is owned by their respetive authors and is not protected by the license of this library
Tests
npm testCredit
This is mainly my best shot at implementating in Javascript what is explained in this great series by starbeamrainbowlabs