Python -> Piet, 385 345 caratteri
È possibile generare qualsiasi programma Piet con questo. Avrei potuto fermarmi a pixel casuali, ma volevo creare programmi "interessanti". La funzione m
colora un pixel di un colore e ricorre ricorsivamente a ciascuno dei pixel vicini. Esistono modi migliori per disegnare blob casuali, ma questo è ottimizzato per terminare in un numero ragionevole di passaggi, quindi è abbastanza buono per il golf. La funzione R(w,h,n)
disegna n blob casuali su un'immagine bianca ( w x h ) e stampa il risultato in formato PPM.
Sono particolarmente orgoglioso di come generi i colori: per una scelta casuale di 0 <= c < 20
,
`[0,192,255][int(x)]`for x in'0002212220200101121100'[c:c+3]
è il codice decimale per un colore valido nella palette Piet mediante un codice Gray a traccia singola . Cioè, ogni colore è rappresentato da 3 bit adiacenti e ogni sezione '0003...0'[c:c+3]
rappresenta un colore diverso. Dato che questa non è la lista completa di 27 parole su 3 lettere, sono stato davvero fortunato a trovare il codice Gray.
from random import*
r=randint
def R(w,h,n):
M=[6]*h*w
def m(x,y,c,d):M[y%h*w+x%w]=c;t=r(0,15)*(r(0,d)<2);t&8and m(x+1,y,c,d+1);t&4and m(x-1,y,c,d+1);t&2and m(x,y+1,c,d+1);t&1and m(x,y-1,c,d+1)
while n:m(r(0,w),r(0,h),r(0,19),0);n-=1
print"P3 %s %s 255 "%(w,h)+' '.join(`[0,192,255][int(x)]`for c in M for x in'0002212220200101121100'[c:c+3])
Output di esempio, generato dal comando R(30,40,500)
Senza l'importazione, posso scriverlo anche come 1-liner (senza punto e virgola):
import random
R=(lambda P,I,E,T:lambda w,h,n:E(w,h,I(w,h,n,lambda z,c,d,t:sum((((z,c),)*t*T(0,1)or m((z[0]+a,z[1]+b),c,d+1,T(0,d)>1)for a,b in((0,1),(1,0),(-1,0),(0,-1))),()))))(range,lambda w,h,n,m:dict(sum((m((T(0,w),T(0,h)),T(0,19),0,0)for _ in P(n)),())),lambda w,h,M:"P3 %s %s 255 "%(w,h)+' '.join(' '.join(`(x&1)*255+(x&2)*96`for x in map(int,'0001121110100202212200'[c:c+3]))for c in(M[z]if z in M else 6for z in((x,y)for y in P(h)for x in P(w)))),random.randint)
ma è ridicolmente lento (e quasi 100 caratteri in più) ... anche se non sono del tutto sicuro del perché (e non terribilmente incline a scoprirlo).