ピエトモンドリアン作曲の再現


23

こんにちは、

あなたの目標は、最小限のソースコードバイトで、Piet Mondrianの「Composition」ペインティング(たとえば、コンポジション#10)を再作成することです。

レクリエーションでは、実際の色を使用するか、Windowsのデフォルト16カラーパレットから適切な色に置き換えることができます

レクリエーションは、PNG、BMP、またはNetPBMで、ファイルまたはSTDOUTに出力するか、直接画面に出力できます。

レクリエーションは、512x512以上の解像度である必要があります。

あなたのレクリエーションはインターネットにアクセスしてはいけません。プログラムでデータファイルが必要な場合、そのサイズがソースのサイズに追加されます。

スコアは、ソースファイルのサイズ(バイト単位)になります。

どの絵を再現しているのかをエントリーに明記し、オリジナルへのリンクとレクリエーションの写真を提供してください。

がんばろう。


ステップ1:組み込みのPNG、BMP、またはNetPBMエンコーダーで言語を見つけます。
ジョンドヴォルザーク

6
関連:ピート
グリフィン

4
作業するのは難しい言語です...時々、NetPBMを出力するQuineを実行しようとします... 誰かがPietでPiet Mondrianを再作成できるなら、私はとても感銘を受けます!
lochok

2
ターミナルカラーエスケープを使用してキャラクターアートを出力し、文字を描画できますか?(例:▃▃▌)または、これは別の課題として提示されるのが最善ですか?
トビア14

2
@lochok誰かが試してみたいと真剣に興味を持っているなら、私はPietの答えに報奨金を提供します。
ジェリーエレミヤ

回答:


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);

これにより、いくつかのノードが接続され、次の形状が生成されます。

次に\draw2番目のストロークを実行しますが、このストロークは細いため、線の太さを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(No. 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}

インターネットで試してみてください!

説明

最初に、読みやすくするために改行を挿入したコードを示します。

\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);

これにより、黒のアウトラインで赤い長方形が描画されます。絵画の左上隅に。

次に、白いインテリアと黒いアウトラインでさらに2つの四角形を描画して、絵画にグリッドパターンを作成します

\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}

World Wide Webでテストしてください!

説明

まず、コードを読みやすくするために改行を挿入します

\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);

これにより、次の形状が描画されます。

この奇妙な形は、右下隅の黄色の長方形と、色付きの長方形の端ではない2本の線です。次に、赤い正方形を挿入し、最後の図形によって作成された余分な線を隠します。

\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}

Information-Super-Highwayで確認してください

来るべき説明


12

Mathematica 202 287バイト。

楽しみのために!330バイト:タイトルに「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バイトを使用します。数学では、そのような式にはそれぞれ専用の1文字記号があります。

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}}] 

並んで

左側の出力。ピエト・モンドリアンの写真、右側に赤青黄色の構図。


3
よい試み。あなたはそれほど簡単に報奨金を得ていない。
小麦ウィザード

11

ルビー、112(111)文字

ピエト・モンドリアン-赤のコンポジションB(No.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は作者の意図に近いです。

(#F00赤)に置き換える"1 0 0 "と、1文字を保存できます(w+b+b)。私はそれが「十分に近い」と数えると信じています

ファイル出力バージョン(ゴルフではありません)

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
ハワード

@Howardくそー。縮小中にこれを逃しました。ありがとう
ジョンドヴォルザーク

そして、いくつかのより多くのあなたが変更された場合w="2 "w="2 "*9してbも。
ハワード

うーん... 私はこれを得る(それは永遠に続く)
ドアノブ

@Doorknobはそれをppmファイルとして保存し、画像エディターで開く
ジョンドヴォルザーク

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)、色は1文字として保存されます。wyr、又はb、および方向は、として保存され|、または-

追加の長方形は次のように保存されます。

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

同じやり方で。


いいね!QBasicの実行を考えていましたが、512x512の画面モードはありません。
DLosc

私はとてもラッキーになりました。SmileBASICのグラフィックページは正確に512x512ピクセル
12Me21

7

SVG-455 480- 赤、青、黄色のモンドリアンコンポジションII

JavascriptをSVGに埋め込み、動的にすることができれば、それはプログラミング言語です。エルゴ、これはプログラムです。SVGでxorまたはycoordが欠落している場合、デフォルトで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>


4
@JanDvorak知りません、彼をウィキペディアで調べました。正直なところ、Pietはかなり怠laな画家でした。それらはすべて同じに見えます。

二重引用符のほとんどを回避し、ほとんどのブラウザーで引き続き機能すると思います。ただし、コンプライアンスについてはわかりません。
ジョンドボラック

@LegoStormtroopr Lazy?短いプログラムを書くことに専念しているウェブサイトにたむろしている人から来た、それはかなり豊かです。
ブースビー

1
@boothby Touche。私は、ハイパーミニマリストのアプローチにより、コードゴルフから多くのことを学んだと主張するつもりでした。しかし...ピエトの仕事についても同じことが言えます。

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

処理中、15,447 15,441 15,439バイト

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

力ずくで、ドロー関数を削除する方法を見つけることができませんでした。

メイン処理エンジンでエラーが発生しました。b64では大きすぎると思います。ここでテストできます

ただし、JSフィドルでは、100 * 100ピクセルにトリミングされます。私のbase64は動作しますが、オンライン環境は動作しません。:(


使用して次のことができ、ゴルフ、これをPImage x=loadImage(i);代わりに
KritixiのLithos

1
質問には512x512以上の解像度が必要ですが、フィドルのキャンバスは100x100のみです。これはJSFiddleの癖ですか?
デニス

@Dennisキャンバスのサイズだけではありません。画像は右と下の両方で切り取られ、結果が不正確になります。
mbomb007

@デニスはい、そうです。手動で512 * 512ピクセルに設定しても、同じサイズにトリミングされます。それはちょうどJSフィドルであり、使用した
b64

data:;base64同様に動作します
Kritixi Lithos

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") 

データファイルが格納されているHERE

出力:

出力

元の:

元の

説明

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
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.