A high-performance Markov string chain for Node.js written in Rust.
npm install fast-markov
# or
yarn add fast-markov
# or
pnpm add fast-markov
const { MarkovChain } = require("fast-markov");
// Create a new chain
const chain = new MarkovChain();
// Add some training text
chain.addText("the quick brown fox jumps over the lazy dog");
chain.addText("the lazy cat sleeps all day long");
// Generate new text (10 words)
console.log(chain.generate(null, 10));
const { MarkovChain } = require("fast-markov");
const chain = new MarkovChain();
chain.addText("the quick brown fox jumps over the lazy dog");
// Generate text starting with 'the'
console.log(chain.generate("the", 5));
const { MarkovChain } = require("fast-markov");
// Create and train chain
const chain = new MarkovChain();
chain.addText("some training text here");
// Export chain state
const exported = chain.exportCorpus();
// Create new chain and import state
const newChain = new MarkovChain();
newChain.importCorpus(exported);
const { MarkovChain } = require("fast-markov");
// Create chain with larger initial capacity for better performance
// when training with large datasets
const chain = new MarkovChain({ initialCapacity: 10000 });
Creates a new Markov chain instance.
options.initialCapacity?: number
- Initial capacity for the internal hash map (default: 1000)
Adds training text to the chain.
Generates new text based on the trained patterns.
startWord
- Optional word to start generation withlength
- Number of words to generate- Returns generated text string
Returns the total number of words in the chain.
Exports the chain state as a JSON string.
Imports a previously exported chain state.
Pre-built binaries are available for the following platforms:
- Windows (x64, arm64)
- macOS (x64, arm64)
- Linux (x64, arm64)
MIT
Contributions are welcome! Please feel free to submit a Pull Request.