Piet Mondrian组合的娱乐


23

下午好,

您的目标是在最少的源代码字节中重新创建Piet Mondrian的任何“ Composition”绘画(例如,Composition#10)。

重新创建可以使用实际的颜色,也可以使用Windows默认16调色板中的适当颜色替换它

您的娱乐活动可以PNG,BMP或NetPBM格式输出到文件或STDOUT,或直接输出到屏幕。

您的休闲娱乐必须是512x512或更高的分辨率。

您的娱乐活动不得访问互联网。如果您的程序需要数据文件,则它们的大小将添加到源文件的大小中。

分数将是源文件的大小(以字节为单位)。

请在您的输入中注明您要重新创作的绘画,并提供原始图片和休闲图片的链接。

祝好运。


第一步:找到带有内置PNG,BMP或NetPBM编码器的语言。
约翰·德沃夏克

6
相关报道:Piet
Griffin

4
这是一种很难使用的语言...时不时地我尝试执行Quine输出NetPBM的方法...但是,是的。如果有人可以在Piet中重现Piet Mondrian,我会留下深刻的印象!
lochok

2
我们可以使用终端颜色转义符和方框图字符输出字符图形吗?(例如▃▃▌)或最好将其摆在另一个挑战上?
Tobia 2014年

2
@lochok如果有人对尝试非常感兴趣,我会提供悬赏以奖励Piet。
杰里·耶利米

Answers:


14

Tikz,175个字节

黑白组合III,175字节

\documentclass[tikz]{standalone}\begin{document}\tikz{\def\b{;\draw[line width=}\def\a{)--(}\clip(1,1\a1,5\a5,5\a5,1)\b2mm](0,4\a6,4\a6,3\a4,3)\b1mm](4,0\a4,5);}\end{document}

在Blogosphere中验证

这也许是蒙德里安最简约的作品之一,令我惊讶的是没有人发现它。但是,它并不是特别有趣,因此我在回答中还添加了其他几幅画。

说明

每个tikz答案都有一个包装器。包装器是:

\documentclass[tikz]{standalone}\begin{document}\tikz{
}\end{document}

一旦通过包装器,就会有一些\def语句保存字节,但不幸的是混淆了代码:

\def\b{;\draw[line width=}\def\a{)--(}

如果我们进行所有适当的替换,我们的代码将如下所示:

\clip(1,1)--(1,5)--(5,5)--(5,1);
\draw[line width=2mm](0,4)--(6,4)--(6,3)--(4,3);
\draw[line width=1mm](4,0)--(4,5);

第一个是a \clip,非常重要,但是暂时我们将跳过它。

现在,我们在空白画布上绘制第一条线,这条线相当粗,因此我们[line width=2mm]将厚度设置为2mm

\draw[line width=2mm](0,4)--(6,4)--(6,3)--(4,3);

这将连接几个节点并产生以下形状:

接下来,我们\draw进行第二次笔划,但是该笔划较细,因此我们必须将线条粗细设置为1mm

\draw[line width=1mm](4,0)--(4,5);

现在我们的画看起来像:

这与原始版本很接近,但并不完全相同,因此在这里\clip发挥了作用。我们使用\clip来从画布中删除所有多余的行,并将画布设置为正确的大小。调整画布大小后,我们得到了图像:

黑色和白色的成分III


有黄色补丁的合成,214字节

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(7,7);\draw(0,8)rectangle(4,3.5)rectangle(6.5,1.2)rectangle(4,0);\draw[fill=yellow](6.5,3.5)rectangle(8,2.5);}\end{document}

在Cyber​​Space中进行评估

解释来


蓝色和黄色的合成II,225个字节

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(7,10);\draw(8,9)rectangle(3,6)rectangle(0,0);\draw[fill=yellow](0,0)rectangle(3,2);\draw[fill=blue](0,11)rectangle(3,9);}\end{document}

通过Webbernetz进行评估!

解释来


成分B(第2个),红色,232字节

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(10,13);\draw[line width=1mm](1.2,5)--(1.2,9);\draw[fill=red](0,14)rectangle(5,9);\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);}\end{document}

在Internet上尝试!

说明

首先,这里是插入换行符以提高可读性的代码:

\documentclass[tikz]{standalone}
\begin{document}
\tikz[line width=2mm]{
\clip(1,1)rectangle(10,13);
\draw[line width=1mm](1.2,5)--(1.2,9);
\draw[fill=red](0,14)rectangle(5,9);
\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);
}
\end{document}

感兴趣的第一个命令是

\draw[fill=red](0,14)rectangle(5,9);

这将绘制一个带有黑色轮廓的红色矩形。用于绘画的左上角。

然后,我们再绘制两个具有白色内部和黑色轮廓的矩形,以在绘画上创建网格图案

\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);

然后我们画一条细线

\draw[line width=1mm](1.2,5)--(1.2,9);

并将图像裁剪为适当的尺寸

\clip(1,1)rectangle(10,13);


组成II:红色,蓝色和黄色,251字节

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=1mm]{\clip(1,1)rectangle(9,9);\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);\draw[fill=red](3,3)rectangle(10,10);\draw[fill=blue](0,0)rectangle(3,3);}\end{document}

在万维网上进行测试!

说明

首先,我将插入一些换行符以使代码可读

\documentclass[tikz]{standalone}
\begin{document}
\tikz[line width=1mm]{
\clip(1,1)rectangle(9,9);
\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);
\draw[fill=red](3,3)rectangle(10,10);
\draw[fill=blue](0,0)rectangle(3,3);
}
\end{document}

第一行的重要性是:

\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);

得出以下形状:

这个奇怪的形状是右下角的黄色矩形和两条没有彩色矩形边缘的线。接下来,我们插入红色正方形并掩盖最后一个形状所产生的多余线条:

\draw[fill=red](3,3)rectangle(10,10);

看起来像这样:

现在我们插入蓝色方块:

\draw[fill=blue](0,0)rectangle(3,3);

现在剩下的就是使用裁剪掉图像中所有不必要的部分 \clip

\clip(1,1)rectangle(10,10);

成分II红色,蓝色和黄色


合成II,308个字节

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(12.6,13);\draw(0,0)rectangle(10,4)rectangle(2,12)--(0,12);\draw[fill=red](10,1.6)rectangle(14,0);\draw[fill=yellow](6,12)rectangle(10,14);\draw[fill=blue](0,4)rectangle(2,8);\fill(10,10)rectangle(14,14);}\end{document}

信息高速公路上查看

解释来


12

Mathematica 202 287个字节。

只是为了好玩!330字节:Mondrian,标题中带有“ Boogie Woogie”

Column[{"Boogie Woogie", Grid[{{"",i["",b->Red],\[SpanFromLeft]},{"",\[SpanFromAbove],\[SpanFromBoth]},{i["",b->Blue],"",""},{\[SpanFromAbove],\[SpanFromAbove],i["",b -> Yellow]}},Dividers->{{2->t@5,3->t@6},{2->t@9,3->t@7,4->t@6}},ItemSize->{{1->3,2->9,3->1},{1->6,2->6,3->2,4->2}}]},Alignment->Center]

在此处输入图片说明


实际提交[287字节]

\[SpanFromLeft]类似的表达式大约占用85个字节。在mathematica中,每个这样的表达式都有其专用的一个字符符号。

t=Thickness;b=Background;i=Item;
Grid[{{"",i["",b->Red], \[SpanFromLeft]},{"",\[SpanFromAbove],\[SpanFromBoth]},{i["",b->Blue],"",""},{\[SpanFromAbove],\[SpanFromAbove],i[ "",b->Yellow]}},
Dividers->{{2->t@5, 3->t@6},{2->t@9,3->t@7,4->t@6}},ItemSize->{{1->3, 2->9, 3->1},
{1->6, 2->6, 3->2, 4->2}}] 

并排

输出在左边;Piet Mondrian右边的红色蓝色黄色构图。


3
不错的尝试。您不会轻易获得赏金。
小麦巫师

11

Ruby,112(111)个字符

Piet Mondrian-B(II)中的红色

b="0 "*9
w="2 "*9
puts"P3 609 771 2",["1 0 0 "*267,w*8+b*2+w*79,w*89].map{|x|(x+b*3+w*42+b*3+w*66)*249}*(b*2436)

左侧是我的作品,右侧是上级参考。

在此处输入图片说明

可以通过微调PPM中的最大值来微调颜色(精度高达1/9),而不会损失分数。我选择了“合适的Win16颜色”方法。8/9白色可能更接近画布的原始颜色,而9/9白色更接近作者的意图。

如果我们将其替换"1 0 0 "(w+b+b)(#F00红色),则可以保存一个字符。我认为算是“足够接近”

文件输出版本(不打高尔夫球)

File.open "tmp.ppm", ?w do |f|
    b="0 "
    w="2 "
    s=b*27+w*378+b*27+w*594
    f.puts"P3 609 771 2",["1 0 0 "*267,w*72+b*18+w*711,w*801].map{|x|(x+s)*249}*(b*21924)
end

一个简单的方法:"0 "->b
霍华德

@霍华德该死。缩小时错过了这个。谢谢
John Dvorak

还有一些,如果您更改w="2 "w="2 "*9and b也。
霍华德

嗯... 我明白了(它永远持续下去)
门把手

@Doorknob将其另存为ppm文件并在图像编辑器中打开
John Dvorak

9

SmileBASIC,2774 1892字节

百老汇布吉伍吉

GCLS-920851D$="w$BȜąr:BȂąr7?Ƣǘy1SƑǘb<?ŵǘw-/ƶvyFMƮeb<<ŶIr:,ėǭy:Sėǘw-LŒƄw7;ėƎrkLćƄrBMĜey26ğ¸bKBē²y,Bć²w<Dđïw+DüïyDÒïw--çvyU8Òpw.1±syBM¨eb;<Iy28¥żrJNůbwN{ůr?@Ǣb3>Sǭw.Fb¤w24D­rMF5¤w,7Nnr[75ny1X=e
FOR I=1TO 36G A(),A(),A(),A(),A()NEXT
D$=" w*+r6,r1+b<*w1+b/+b++r(+w*+w,Br )b+*b()w0,w=+b,,r5+b1+r ,w24-Ȃ  w  w#.r-#-Ǥ  w*+r4,b3+r6*w2+b,-r-,b++r*+b**r(*b(*r*+b<-w@+b -w ,r4+b1+b%-w,5-ǔ  w +r)+w?#-ƹǘ w +r%-b,#-ƭ +w *r +w/,b2,r1-b;-w7+b*.w5+r1+r +-ƒ> w +r'-b*#-ž *r+)w +r?+b:+b1-b2+w:+w*+w3-b4-r4-b6,w2+r--w3+b1+r )w52-ş  w*+r )w ,b>+r7+b :w -b,+r:+w*+w7,r 6w ,r7-r0.w/+bM+b1+b ,w24-ľ *w +r)+r *w5+r9,b7.w++w ,r.+w*+w6*b Dw *r06w -r5+b *w8+w +r1+b ,w *r(7-ü  w*+w )b +w*+r*+bD-rC/r7+b*+r5+bD-r,.b/.w.+b *w8+r +w1+b'+r,4-Ò  w*+b )w+*r+*w +b )w<0wX-w +r*+b /wd-w/.b/*w+-r 7w)+bC+r,3-p *w+)w +b*+w*+b )w@2wU*w+*w++wx-wQ-w.,bT+b,.-* +w +r++r5,w6+w %|üŭ w3+r1*w(+r0+r7*b (w )r3*w+*w,+r-*w +b5+r )w6+w.,r1+w *b*-w +b *w(,r()w ,r+*r :| ȋ+w7*b 1w4)w +r %|şǷ+r,*w)+w.*w*)w ?r -w+'|pǷ)w,)w +b*#| Ƿ+r/+b()w ?r -w+*w),r(*w *b +w *r +| Ǣ w+(w +b1*w(+r0+b7)b *w *r2)w +b *w,+r7+b5+r )w6+b/+b )w1,r7+b.*b9*w +b*8| Ǎ w3+w )b0*w +r4)w +r/+w**w**b +w6+w )r1*b3+w /|üň+b-*w1+w%*r(-w +r *w.+w')r (w5*| ň w3+w )r0*w +b )r5*b/+w3+w *r +w *r,+w9+r3+w-*b (w +r,+b2,w /r3+b0)r *b+-w+*r :| ij w3+b )w)*r 'w +b (w+)w *r1+b0*w.+r6+b )w0)w,)w +b4+w +b0)w'*r1*b))w+*b.*b1(w+*r ;| 3w +b )w*)b 'w +b.)r 'w )b0+r <b,+b6+b.,b=+r 3w ,b +w *b 6w *r);b)+b7+b 1w=9| Z w3+r (w.-w +b1+w +r0+r )w +r (w,+r6+b *w),r8+b?+bJ*w:)w+)w.*r1)w+*r 7| >+r )w6+r2*b1+r6*b1*w +b*(| ,
FOR Q=1TO 27S=A()T=A()R=A()L=A()FOR I=1TO L
R A(),89R A(),A()NEXT
NEXT
DEF A()RETURN-32+ASC(POP(D$))END
DEF R L,C
IF L THEN IF R-13THEN G C,L,11,T,S:T=T+L ELSE G C,11,L,T,S:S=S+L
END
DEF G C,H,W,Y,X
GFILL X,Y,X+W-1,Y+H-1,-1716698*(C>88)-2302505*(C==87)-6080725*(C==82)-14597488*(C<67)END

屏幕截图

图像中的每个“行”都以这种格式存储:

x,y,direction,numberOfSegments,
yellowLength,nextColor,colorLength,
yellowLength,nextColor,colorLength,...

所有数字均存储为CHR$(number+32),颜色存储为一个字符。wyr,或b,和方向被存储为|-

多余的矩形仅存储为:

x,y,width,height,color,
x,y,width,height,color,...

以同样的方式。


真好!我当时正在考虑做QBasic,但没有512x512屏幕模式。
DLosc

我很幸运;SmileBASIC的图形页面正好是512x512像素
12Me21 '17

7

SVG-455 480- 红色,蓝色和黄色的蒙德里安构图II

如果您可以将Javascript嵌入到SVG中并使其动态,那它就是一种编程语言。嗯,这是一个程序。证明如果SVG中缺少xor y坐标,则默认为0。也red#f00!短!

<?xml version="1.0" encoding="utf-8"?><svg xmlns="http://www.w3.org/2000/svg"><rect x="145" fill="red" width="455" height="440"/><rect y="432" fill="#00F" width="150" height="168"/><rect x="550" y="517" fill="#FF0" width="50" height="83"/><rect x="140" width="16" height="600"/><rect y="430" width="600" height="16"/><rect y="180" width="140" height="25"/><rect x="550" y="430" width="15" height="170"/><rect x="550" y="515" width="50" height="16"/></svg>

精美印刷:

<?xml version="1.0" encoding="utf-8"?>
<svg xmlns="http://www.w3.org/2000/svg">
  <rect x="145" fill="red" width="455" height="440"/>
  <rect y="432" fill="#00F" width="150" height="168"/>
  <rect x="550" y="517" fill="#FF0" width="50" height="83"/>
  <rect x="140" width="16" height="600"/>
  <rect y="430" width="600" height="16"/>
  <rect y="180" width="140" height="25"/>
  <rect x="550" y="430" width="15" height="170"/>
  <rect x="550" y="515" width="50" height="16"/>
</svg>

等等,我以为带有红色1935的作品B(第II号是#2
John Dvorak

4
@JanDvorak我不知道,我只是在Wikipedia上查找了他。老实说,皮耶特是个很懒惰的画家。它们看起来都一样。

我认为您可以避免大多数双引号,并且仍然可以在大多数浏览器中使用。不过,不确定是否合规。
John Dvorak

@LegoStormtroopr懒吗?那是非常有钱的,来自一个在专门编写短程序的网站上闲逛的家伙。
展位,2013年

1
@boothby Touche。我要说的是,由于它的极简主义方法,我从代码高尔夫球中学到了很多东西。但是... Piet的作品也有同样的观点。

3

SmileBASIC,67个字节

GCLS-1GFILL 353,0,367,#R,0GFILL.,121,#R,156,0GFILL 367,266,#R,293,0

我选了一个简单的作品:黑白组合III

幸运的是,SB的图形页面恰好是512x512像素,但它不能完全适合400x240的屏幕,因此我无法轻松获得屏幕截图。

解释:

GCLS -1 'fill screen with &HFFFFFFFF (white)
GFILL 353,0,367,511,0 'draw vertical line in &H00000000 (black)
GFILL 0,121,#R,156,0 'draw horizontal line
GFILL 367,266,#R,293,0 'draw small horizontal line

3

处理,15447个 15441 15439字节

String i="";PImage x=loadImage(i);void draw(){image(x);}

蛮力,而且我还没有找到删除绘图功能的方法。

我认为这是主要处理引擎中的错误,因为它太大了b64。您可以在这里进行测试。

JS小提琴确实将其裁剪为100 * 100px。我的base64有效,但在线环境无效。:(


您可以PImage x=loadImage(i);改用高尔夫运动
Kritixi Lithos

1
问题要求的分辨率为512x512或更高,但是您的小提琴中的画布只有100x100。这是JSFiddle的怪癖吗?
丹尼斯,

@Dennis不仅是画布大小。图像在右侧和底部均被剪切,导致结果不正确。
mbomb007'2

@丹尼斯是的。手动将其设置为512 * 512像素仍会将其裁切为相同大小。这只是JS小提琴,我使用的b64大于512。
Rɪᴋᴇʀ17年

data:;base64效果也很好
Kritixi Lithos'2

2

Love2D,4956 + 395 + 1 = 5351字节

f=io.open("d","rb")s=f:read("*a"):gsub("(.)(.)",function(a,b)return a:rep(b:byte())end)o=love.image.newImageData(512,512)c={{244,243,248},{173,24,0},{250,209,5},{30,64,164}}o:mapPixel(function(x,y)i=math.floor((x+math.floor(y/4)*512)/4)O=3-i%4 n=s:sub(math.floor(i/4)+1,math.floor(i/4)+1)if n and#n>0 then b=math.floor(n:byte()/(4^O))%4 else b=0 end return unpack(c[b+1])end)o:encode("png","o") 

数据文件存储在这里

输出:

输出量

原版的:

原版的

说明

f = io.open("d","rb")                                                   -- Open the image in raw format.
s = f:read("*a"):gsub("(.)(.)",function(a,b)return a:rep(b:byte())end)  -- And read it's contents. 
o=love.image.newImageData(512,512)                                      -- Make the output image
c = {{244,243,248},{173,24,0},{250,209,5},{30,64,164}}                  -- Build the Pallet
o:mapPixel(function(x,y)                                                -- Fill the image, based on a function
    i = (x+y*512)                                   -- The position this pixel exists on the string, 0 indexed.
    O = 3-i%4                                       -- The offset. The byte stores 4 pixels, so this is the id among a group of 4.
    n = s:sub(math.floor(i/4)+1,math.floor(i/4)+1)  -- And this gets the byte itself.
    if n and #n > 0 then                            -- Sometimes this is null and I don't like it.
        b = math.floor(n:byte()/(4^O))%4            -- /4^offset % 4 gives us the value of the index on the pallet.
    else
        b = 0                                       -- Fallback plan.
    end
    return unpack(c[b+1])                           -- Set the pixel to the colour required.
end)
o:encode("png","o") -- Store it in Appdata as "o", which is a png file.

编码器。

这只是我用来编码图像的脚本。Gif的压缩效果更好,但我并没有挑战显示gif。

img = love.image.newImageData("mondrian.jpg")
-- white    0
-- blue     3
-- yellow   2
-- red      1

cols = {{244,243,248},{173,24,0},{250,209,5},{30,64,164}}

local s = ""
for y = 0, 511 do
    for x = 0, 511 do
        local r,g,b = img:getPixel(x,y)
        local n = 0
        local D = math.huge
        for k,v in pairs(cols) do
            local d = (v[1]-r)^2 + (v[2]-g)^2 + (v[3]-b)^2
            if d < D then
                n = k-1
                D = d
            end
        end
        s = s .. n
    end
end
-- Convert base 4 to base 256
-- How many digits do we need- Every 4 digits
encd = ""
for str in s:gmatch"...." do
    local n = str:sub(1,1) * 4^3 +
              str:sub(2,2) * 4^2 +
              str:sub(3,3) * 4^1 +
              str:sub(4,4) * 4^0
    encd = encd .. string.char(n)
end

f = io.open("stored.dat","wb")

smlr = ""
lst = ""
c = 0
for s in encd:gmatch"." do
    if s == lst then
        c = c + 1
        while c > 255 do
            smlr = smlr .. lst .. string.char(255)
            c = c - 255
        end
    else
        if c > 0 then
            smlr = smlr .. lst .. string.char(c)
        end
        lst = s
        c = 1
    end
end

f:write(smlr)

主要是争夺赏金。可能有更好的方法来执行此操作,但我认为尝试使用简单的货盘并进行行程解码很有趣。

编辑:输入图像被简化,准确度稍差,但字节数减少。


2
为什么输出的某些部分看起来像是由拼图组成的?这是您的意思吗?“准确度稍差,但字节数却少得多”?在我看来,色带中的由此产生的间隙使此操作无效。
DLosc
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.