Jump to content

Dissociated press

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Graham87 (talk | contribs) at 11:49, 1 April 2015 (The algorithm: copyedit). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Dissociated press is a parody generator (a computer program that generates nonsensical text). The generated text is based on another text using the Markov chain technique. The name is a play on "Associated Press".

An implementation of the algorithm is available in Emacs. Another implementation is available as a Perl module in CPAN, Games::Dissociate.[1]

The algorithm

The algorithm starts by printing a number of consecutive words (or letters) from the source text. Then it searches the source text for an occurrence of the few last words or letters printed out so far. If multiple occurrences are found, it picks a random one, and proceeds with printing the text following the chosen occurrence. After a predetermined length of text was printed out, the search procedure is repeated for the newly printed ending.

Considering that words and phrases tend to appear in specific grammatical contexts, the resulting text usually seems correct grammatically, and if the source text is uniform in style, the result appears to be of similar style and subject, and takes some effort on the reader's side to recognize as not genuine. Still, the randomness of the assembly process deprives it of any logical flow - the loosely related parts are connected in a nonsensical way, creating a humorously abstract, random result.

Examples

Here is a short example of word-based Dissociated Press applied to the Jargon File:[2]

wart: n. A small, crocky feature that sticks out of an array (C has no checks for this). This is relatively benign and easy to spot if the phrase is bent so as to be not worth paying attention to the medium in question.

Here is a short example of letter-based Dissociated Press applied to the same source:

window sysIWYG: n. A bit was named aften /bee´t@/ prefer to use the other guy's re, especially in every cast a chuckle on neithout getting into useful informash speech makes removing a featuring a move or usage actual abstractionsidered interj. Indeed spectace logic or problem!

History

The dissociated press algorithm is described in HAKMEM (1972) Item #176. The name "dissociated press" is first known to have been associated with the Emacs implementation.

Brian Hayes discussed a Travesty algorithm in Scientific American in November 1983.[3] The article provided a garbled William Faulkner passage:

When he got on the table, he come in. He never come out of my own pocket as a measure of protecting the company against riot and bloodshed. And when he said. "You tell me a bus ticket, let alone write out no case histories. Then the law come back with a knife!"

Hugh Kenner and Joseph O'Rourke of The Johns Hopkins University discussed their frequency table-based Travesty generator for microcomputers in BYTE in November 1984. The article included the Turbo Pascal source for two versions of the generator, one using Hayes' algorithm and another using Claude Shannon's Hellbat algorithm.[3] Murray Lesser offered a compiled BASIC version in the magazine in July 1985,[4] in September 1985 Peter Wayner offered a version that used tree data structures instead of frequency tables,[5] and in December 1985 Neil J. Rubenking offered a version written in Turbo Pascal that stored frequency information in a B-tree.[6]

See also

References

  1. ^ Burke, Sean M. and Avi Finkel. Games::Dissociate distribution in CPAN. Retrieved 2012-11-13. Most recent release: 2010, "v1.0".
  2. ^ Raymond, Eric S. (2003-12-29). "Dissociated Press". Jargon File 4.4.7. Retrieved 2007-04-10.
  3. ^ a b Kenner, Hugh; O'Rourke, Joseph (November 1984). "A Travesty Generator for Micros". BYTE. p. 129. Retrieved 23 October 2013.{{cite news}}: CS1 maint: multiple names: authors list (link)
  4. ^ Lesser, Murray (July 1985). "Travesty Revisited". BYTE. p. 163. Retrieved 27 October 2013.
  5. ^ Wayner, Peter (September 1985). "Build a Travesty Tree". BYTE. p. 183. Retrieved 27 October 2013.
  6. ^ Rubenking, Neil J. (December 1985). "Travesty with Database". BYTE. p. 161. Retrieved 28 October 2013.

This article is based in part on the Jargon File, which is in the public domain.