Tupper's self-referential formula

From testwiki
Jump to navigation Jump to search

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:

12<mod(y17217xmod(y,17),2) where denotes the floor function, and mod is the modulo operation.

Plots

Let k 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
Derivation of k

Graphing the set of points (x,y) in 0x<106 and ky<k+17 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 k, and it could be used to draw any other image. When applied to the unbounded positive range 0y, 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 k is a simple monochrome bitmap image of the formula treated as a binary number and multiplied by 17. If k is divided by 17, the least significant bit encodes the upper-right corner (k,0); 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 k is the number whose binary digits form the plot. The following plot demonstrates the addition of different k 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 k.[4]

Addition of different values of k

See also

References

Footnotes

Template:Notefoot

Notes

Template:Reflist

Sources

Template:Refbegin

Template:Refend