Tupper's self-referential formula
Template:Short description Tupper's self-referential formula is a formula that visually represents itself when graphed at a specific location in the (x, y) plane.
History
The formula was defined by Jeff Tupper and appears as an example in his 2001 SIGGRAPH paper on reliable two-dimensional computer graphing algorithms.[1] This paper discusses methods related to the GrafEq formula-graphing program developed by Tupper.[2]
Formula
The formula is an inequality defined as:
where denotes the floor function, and mod is the modulo operation.
Plots
Let equal the following 543-digit integer:
- 960Template:Thinspace939Template:Thinspace379Template:Thinspace918Template:Thinspace958Template:Thinspace884Template:Thinspace971Template:Thinspace672Template:Thinspace962Template:Thinspace127Template:Thinspace852Template:Thinspace754Template:Thinspace715Template:Thinspace004Template:Thinspace339Template:Thinspace660Template:Thinspace129Template:Thinspace306Template:Thinspace651Template:Thinspace505Template:Thinspace519Template:Thinspace271Template:Thinspace702Template:Thinspace802Template:Thinspace395Template:Thinspace266Template:Thinspace424Template:Thinspace689Template:Thinspace642Template:Thinspace842Template:Thinspace174Template:Thinspace350Template:Thinspace718Template:Thinspace121Template:Thinspace267Template:Thinspace153Template:Thinspace782Template:Thinspace770Template:Thinspace623Template:Thinspace355Template:Thinspace993Template:Thinspace237Template:Thinspace280Template:Thinspace874Template:Thinspace144Template:Thinspace307Template:Thinspace891Template:Thinspace325Template:Thinspace963Template:Thinspace941Template:Thinspace337Template:Thinspace723Template:Thinspace487Template:Thinspace857Template:Thinspace735Template:Thinspace749Template:Thinspace823Template:Thinspace926Template:Thinspace629Template:Thinspace715Template:Thinspace517Template:Thinspace173Template:Thinspace716Template:Thinspace995Template:Thinspace165Template:Thinspace232Template:Thinspace890Template:Thinspace538Template:Thinspace221Template:Thinspace612Template:Thinspace403Template:Thinspace238Template:Thinspace855Template:Thinspace866Template:Thinspace184Template:Thinspace013Template:Thinspace235Template:Thinspace585Template:Thinspace136Template:Thinspace048Template:Thinspace828Template:Thinspace693Template:Thinspace337Template:Thinspace902Template:Thinspace491Template:Thinspace454Template:Thinspace229Template:Thinspace288Template:Thinspace667Template:Thinspace081Template:Thinspace096Template:Thinspace184Template:Thinspace496Template:Thinspace091Template:Thinspace705Template:Thinspace183Template:Thinspace454Template:Thinspace067Template:Thinspace827Template:Thinspace731Template:Thinspace551Template:Thinspace705Template:Thinspace405Template:Thinspace381Template:Thinspace627Template:Thinspace380Template:Thinspace967Template:Thinspace602Template:Thinspace565Template:Thinspace625Template:Thinspace016Template:Thinspace981Template:Thinspace482Template:Thinspace083Template:Thinspace418Template:Thinspace783Template:Thinspace163Template:Thinspace849Template:Thinspace115Template:Thinspace590Template:Thinspace225Template:Thinspace610Template:Thinspace003Template:Thinspace652Template:Thinspace351Template:Thinspace370Template:Thinspace343Template:Thinspace874Template:Thinspace461Template:Thinspace848Template:Thinspace378Template:Thinspace737Template:Thinspace238Template:Thinspace198Template:Thinspace224Template:Thinspace849Template:Thinspace863Template:Thinspace465Template:Thinspace033Template:Thinspace159Template:Thinspace410Template:Thinspace054Template:Thinspace974Template:Thinspace700Template:Thinspace593Template:Thinspace138Template:Thinspace339Template:Thinspace226Template:Thinspace497Template:Thinspace249Template:Thinspace461Template:Thinspace751Template:Thinspace545Template:Thinspace728Template:Thinspace366Template:Thinspace702Template:Thinspace369Template:Thinspace745Template:Thinspace461Template:Thinspace014Template:Thinspace655Template:Thinspace997Template:Thinspace933Template:Thinspace798Template:Thinspace537Template:Thinspace483Template:Thinspace143Template:Thinspace786Template:Thinspace841Template:Thinspace806Template:Thinspace593Template:Thinspace422Template:Thinspace227Template:Thinspace898Template:Thinspace388Template:Thinspace722Template:Thinspace980Template:Thinspace000Template:Thinspace748Template:Thinspace404Template:Thinspace719

Graphing the set of points in and which satisfy the formula, results in the following plot:Template:NoteTag
The formula is a general-purpose method of decoding a bitmap stored in the constant , and it could be used to draw any other image. When applied to the unbounded positive range , the formula tiles a vertical swath of the plane with a pattern that contains all possible 17-pixel-tall bitmaps. One horizontal slice of that infinite bitmap depicts the drawing formula since other slices depict all other possible formulae that might fit in a 17-pixel-tall bitmap. Tupper has created extended versions of his original formula that rule out all but one slice.[3]
The constant is a simple monochrome bitmap image of the formula treated as a binary number and multiplied by 17. If is divided by 17, the least significant bit encodes the upper-right corner ; the 17 least significant bits encode the rightmost column of pixels; the next 17 least significant bits encode the 2nd-rightmost column, and so on.
It fundamentally describes a way to plot points on a two-dimensional surface. The value of is the number whose binary digits form the plot. The following plot demonstrates the addition of different values. In the fourth subplot, the k-value of "AFGP" and "Aesthetic Function Graph" is added to get the resultant graph, where both texts can be seen with some distortion due to the effects of binary addition. The information regarding the shape of the plot is stored within .[4]

See also
References
Footnotes
Notes
Sources
- Weisstein, Eric W. "Tupper's Self-Referential Formula." From MathWorld—A Wolfram Web Resource. Template:Webarchive
- Bailey, D. H.; Borwein, J. M.; Calkin, N. J.; Girgensohn, R.; Luke, D. R.; and Moll, V. H. Experimental Mathematics in Action. Natick, MA: A. K. Peters, p. 289, 2006. Template:Webarchive
- "Self-Answering Problems." Math. Horizons 13, No. 4, 19, April 2006
- Wagon, S. Problem 14 in stanwagon.com Template:Webarchive
External links
- Template:Official
- Extensions of Tupper's original self-referential formula
- Tupper's self-referential formula in Rosetta Code, implementation in several programming languages
- TupperPlot, an implementation in JavaScript
- Tupper self referential formula, an implementation in Python
- The Library of Babel function, a detailed explanation of the workings of Tupper's self-referential formula
- Tupper's Formula Tools, an implementation in JavaScript
- Trávník's formula that draws itself close to the origin