Recréation de Piet Mondrian Composition

23

Bonne après-midi,

Votre objectif est de recréer, dans le moins d'octets de code source, l'une des peintures «Composition» de Piet Mondrian (par exemple, Composition # 10 ).

La récréation peut soit utiliser les couleurs réelles, soit la remplacer par les couleurs appropriées de la palette de couleurs Windows par défaut 16.

Votre récréation peut être sortie en PNG, BMP ou NetPBM, soit dans un fichier, soit dans STDOUT, soit directement sur l'écran.

Vos loisirs doivent avoir une résolution de 512x512 ou plus.

Vos loisirs ne doivent pas accéder à Internet. Si votre programme nécessite des fichiers de données, leur taille sera ajoutée à la taille de votre source.

Votre score sera la taille de votre fichier source en octets.

Veuillez indiquer avec votre entrée la peinture que vous recréez et fournir un lien vers l'original et une photo de votre récréation.

Bonne chance.

lochok
la source
Première étape: trouver une langue avec un encodeur PNG, BMP ou NetPBM intégré.
John Dvorak
6
Pertinent: Piet
Griffin
4
C'est une langue difficile à travailler ... de temps en temps j'essaie de faire un Quine avec NetPBM ... mais oui. Je serai très impressionné si quelqu'un peut recréer Piet Mondrian à Piet!
lochok
2
Pouvons-nous produire des illustrations de personnages en utilisant des sorties de couleurs terminales et des personnages de dessin en bloc? (par exemple. ▃▃▌) Ou est-ce mieux posé comme un défi différent?
Tobia
2
@lochok J'offrirais une prime pour une réponse Piet si quelqu'un était sérieusement intéressé à essayer.
Jerry Jeremiah

Réponses:

14

Tikz, 175 octets

Composition III en noir et blanc , 175 octets

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

Vérifiez-le dans la blogosphère

C'est peut-être l'une des œuvres les plus minimalistes de Mondrian et je suis surpris que personne ne l'ait encore trouvée. Ce n'est cependant pas particulièrement intéressant donc j'ai inclus plusieurs autres tableaux dans ma réponse.

Explication

Il y a un peu d'un wrapper qui est associé à chaque réponse tikz. L'emballage est:

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

Une fois que vous avez dépassé le wrapper, il y a quelques \definstructions qui économisent des octets mais obscurcissent malheureusement le code:

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

Si nous faisons toutes les substitutions appropriées, notre code se présente comme suit:

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

Le premier bit est un \clipet est très important, mais nous allons le sauter pour le moment.

Maintenant, nous dessinons la première ligne sur la toile vierge, cette ligne est plutôt épaisse, nous utilisons donc [line width=2mm]pour définir l'épaisseur à 2mm:

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

Cela relie quelques nœuds et produit cette forme:

Ensuite, nous avons \drawun deuxième trait, mais ce trait est plus fin, nous devons donc définir l'épaisseur de la ligne sur 1mm:

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

Maintenant, notre peinture ressemble à:

C'est proche de l'original mais pas tout à fait, c'est donc là que le jeu \clipentre en jeu. Nous utilisons le \clippour supprimer toutes les lignes supplémentaires de notre toile et définir la toile à la bonne taille. Avec la toile redimensionnée, nous obtenons l'image:

Composition III en noir et blanc


Composition avec patch jaune , 214 octets

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

Évaluez-le dans CyberSpace

Explication à venir


Composition II en bleu et jaune , 225 octets

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

Évaluez-le sur le Webbernetz!

Explication à venir


Composition B (n ° 2) en rouge , 232 octets

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

Essayez-le sur Internet!

Explication

Voici d'abord le code avec des sauts de ligne insérés pour le rendre plus lisible:

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

La première commande d'intérêt est

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

Cela dessine un rectangle rouge avec un contour noir. Pour le coin supérieur gauche du tableau.

Nous dessinons ensuite deux autres rectangles avec des intérieurs blancs et des contours noirs pour créer le motif de la grille sur la peinture

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

On trace ensuite une fine ligne

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

Et recadrez l'image à la bonne taille

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


Composition II en rouge, bleu et jaune , 251 octets

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

Testez-le sur le World Wide Web!

Explication

Je vais d'abord insérer des sauts de ligne pour rendre mon code lisible

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

La première ligne d'importance est:

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

Cela dessine la forme suivante:

Cette forme étrange est le rectangle jaune dans le coin inférieur droit et les deux lignes qui ne sont pas le bord d'un rectangle coloré. Ensuite, nous insérons le carré rouge et couvrons les lignes supplémentaires faites par la dernière forme:

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

Cela ressemble à ceci:

Maintenant, nous insérons notre carré bleu:

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

Il ne reste plus qu'à recadrer toutes les parties inutiles de l'image à l'aide d'un \clip

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

Composition II en rouge, bleu et jaune


Composition II , 308 octets

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

Découvrez-le sur l' Information-Super-Highway

Explication à venir

Assistant de blé
la source
12

Mathematica 202 287 octets.

Juste pour le fun! 330 octets: Mondrian avec "Boogie Woogie" dans son titre

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]

entrez la description de l'image ici


Soumission réelle [287 octets]

\[SpanFromLeft]et les expressions similaires occupent environ 85 octets. En mathématique, chacune de ces expressions a son propre symbole à un caractère.

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

cote à cote

Sortie à gauche; photo de Piet Mondrian, composition rouge bleu jaune à droite.

DavidC
la source
3
Bien essayé. Vous n'obtenez pas la prime aussi facilement.
Wheat Wizard
11

Rubis, 112 (111) caractères

Piet Mondrian - composition en B (n ° II) avec rouge

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)

ma production à gauche, la référence upscalée à droite.

entrez la description de l'image ici

Les couleurs peuvent être légèrement modifiées - jusqu'à une précision de 1/9 - sans perte de score en modifiant la valeur maximale en PPM. J'ai choisi l'approche "couleur Win16 appropriée". Le blanc 8/9 est probablement plus proche de la couleur d'origine de la toile, mais le 9/9 est plus proche de l'intention de l'auteur.

Un caractère peut être enregistré si nous le remplaçons "1 0 0 "par (w+b+b)(# F00 rouge). Je crois que ça compte comme "assez proche"

fichier version ouptut (non golfé)

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
John Dvorak
la source
Une tâche facile: "0 "->b
Howard
@Howard putain. Manqué celui-ci lors de la minification. Merci
John Dvorak
Et encore plus si vous changez w="2 "en w="2 "*9et baussi.
Howard
euh ... j'ai compris (ça continue pour toujours)
Poignée de porte
@ Doorknob enregistrez-le en tant que ppmfichier et ouvrez-le dans un éditeur d'images
John Dvorak
9

SmileBASIC, 2774 1892 octets

Broadway Boogie Woogie

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

capture d'écran

Chacune des "lignes" de l'image est stockée dans ce format:

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

Tous les nombres sont stockés en tant que CHR$(number+32), les couleurs sont stockées en un seul caractère; w, y, r, Ou b, et la direction est stockée sous forme |ou-

Les rectangles supplémentaires sont simplement stockés sous la forme:

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

De la même manière.

12Me21
la source
Agréable! Je pensais à faire QBasic, mais il n'y a pas de mode d'écran 512x512.
DLosc
J'ai eu beaucoup de chance; Les pages graphiques de SmileBASIC sont exactement 512x512 pixels
12Me21
7

SVG - 455 480- Mondrian Composition II en rouge, bleu et jaune

Si vous pouvez intégrer Javascript dans SVG et le rendre dynamique, c'est un langage de programmation. Ergo, c'est un programme. S'avère si un xou ycoord est manquant dans SVG, il est par défaut à 0. Est également redplus court que #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>

Assez imprimé:

<?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>
Timwi
la source
Attendez, je pensais que Composition B (No.II) avec Red 1935 était # 2
John Dvorak
4
@JanDvorak Je ne sais pas, je viens de le chercher sur Wikipédia. Honnêtement, Piet était un peintre assez paresseux. Ils se ressemblent tous.
Je pense que vous pouvez éviter la plupart des guillemets doubles et continuer à fonctionner dans la plupart des navigateurs. Pas sûr de la conformité, cependant.
John Dvorak
@LegoStormtroopr Lazy? C'est assez riche, venant d'un gars qui traîne sur un site Web consacré à l'écriture de programmes courts.
boothby
1
@boothby Touche. J'allais dire que j'ai beaucoup appris du golf de code en raison de son approche hyperminimaliste. Mais ... on pourrait en dire autant du travail de Piet.
3

SmileBASIC, 67 octets

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

J'en ai choisi une facile: Composition III en noir et blanc

Heureusement, la page graphique de SB fait exactement 512x512 pixels, mais elle ne tient pas toutes sur l'écran 400x240, donc je ne peux pas obtenir une capture d'écran facilement.

Expliqué:

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
12Me21
la source
3

Traitement, 15 447 15 441 15 439 octets

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

Force brute, et je n'ai pas réussi à trouver un moyen de supprimer la fonction de dessin.

Il y a des erreurs dans le moteur de traitement principal, je pense parce que c'est trop gros d'un b64. Vous pouvez le tester ici .

JS fiddles le recadre cependant, à 100 * 100px. Mon base64 fonctionne, mais pas l'environnement en ligne. :(

Rɪᴋᴇʀ
la source
Vous pouvez PImage x=loadImage(i);
jouer
1
La question nécessite une résolution de 512x512 ou plus, mais la toile de votre violon n'est que de 100x100. Est-ce une bizarrerie de JSFiddle?
Dennis
@Dennis Ce n'est pas seulement la taille de la toile. L'image est coupée à droite et en bas, ce qui rend le résultat incorrect.
mbomb007
@ Dennis Ouais, ça l'est. Le définir manuellement à 512 * 512 px le recadre toujours à la même taille. C'est juste du violon JS, et le b64 que j'ai utilisé est supérieur à 512.
Rɪᴋᴇʀ
data:;base64fonctionne aussi bien
Kritixi Lithos
2

Love2D, 4956 + 395 + 1 = 5351 octets

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

Le fichier de données est stocké ICI

Sortie:

Sortie

Original:

Original

Explication

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.

L'encodeur.

Ce n'est que le script que j'ai utilisé pour encoder l'image. Gif a fonctionné plus compressé, mais je n'ai pas été mis au défi d'afficher un 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)

En compétition pour la prime. Il y a probablement de meilleures façons de le faire, mais j'ai pensé qu'il serait intéressant d'essayer d'utiliser une simple palette et un décodage de longueur.

EDIT: l'image d'entrée a été simplifiée, légèrement moins précise, mais d'une amplitude inférieure aux octets.

ATaco
la source
2
Pourquoi certaines parties de votre sortie semblent-elles constituées de pièces de puzzle? Est-ce ce que vous entendiez par "un peu moins précis, mais une amplitude de moins en octets"? Il me semble que les lacunes qui en résultent dans les bandes de couleur en font une récréation non valable.
DLosc