Python -> Piet, 385 345 char
เป็นไปได้ที่จะสร้างโปรแกรม Piet ด้วยวิธีนี้ ฉันเพิ่งจะหยุดที่พิกเซลสุ่ม แต่ฉันต้องการให้โปรแกรม "น่าสนใจ" ฟังก์ชั่นm
วาดพิกเซลสีและทำซ้ำขั้นตอนในแต่ละพิกเซลเพื่อนบ้าน มีวิธีที่ดีกว่าในการวาดแบบสุ่ม blobs แต่นี่คือการปรับเพื่อยุติในจำนวนขั้นตอนที่เหมาะสมดังนั้นจึงดีพอสำหรับการเล่นกอล์ฟ ฟังก์ชั่นR(w,h,n)
ดึงn blobs สุ่มบน ( W x H ) ภาพสีขาวและพิมพ์ผลในรูปแบบพีพีเอ็ม
ฉันโดยเฉพาะอย่างยิ่งความภาคภูมิใจของวิธีการที่ฉันสร้างสี - สำหรับทางเลือกสุ่ม0 <= c < 20
,
`[0,192,255][int(x)]`for x in'0002212220200101121100'[c:c+3]
เป็นรหัสทศนิยมสำหรับสีที่ถูกต้องในจานปิเอทโดยวิธีการเดียวติดตามรหัสสีเทา นั่นคือแต่ละสีจะถูกแสดงด้วย 3 บิตที่อยู่ติดกันและทุกชิ้นจะ'0003...0'[c:c+3]
แสดงสีที่แตกต่างกัน เนื่องจากนี่ไม่ใช่รายการที่สมบูรณ์ของ 27 คำใน 3 ตัวอักษรฉันโชคดีมากที่ได้ค้นหารหัสสีเทา
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])
เอาต์พุตตัวอย่างสร้างโดยคำสั่ง R(30,40,500)
หากไม่มีการนำเข้าฉันสามารถเขียนเป็นซับที่เหมาะสม (เซมิโคลอน) 1 ซับได้เช่นกัน:
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)
แต่มันก็ช้าอย่างน่าขัน (และเกือบ 100 ตัวอักษร) ... ถึงแม้ว่าฉันจะไม่แน่ใจว่าทำไม (และไม่อยากจะรู้)