summaryrefslogtreecommitdiff
path: root/RGens/src/main/java/bjc/rgens/text/markov/StandaloneMarkov.java
blob: bc318477c66b2309416da1a6040add9fdb91c865 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
package bjc.rgens.text.markov;

import java.util.Map;

public class StandaloneMarkov {
	private int k;

	private Map<String, Markov>	markovHash;
	private String			firstSub;

	public StandaloneMarkov(int k, Map<String, Markov> markovHash, String firstSub) {
		this.k = k;
		this.markovHash = markovHash;
		this.firstSub = firstSub;
	}

	public String generateTextFromMarkov(int M) {
		StringBuilder text = new StringBuilder();
		for (int i = k; i < M; i++) {
			if (i == k) {
				text.append(firstSub);

				if (text.length() > k) i = text.length();
			}

			String sub = text.substring((i - k), (i));
			Markov tmp = markovHash.get(sub);

			if (tmp != null) {
				Character nextChar = tmp.random();
				text.append(nextChar);
			} else {
				i = k - 1;
			}
		}

		return text.toString();
	}

}