Recreación de la composición de Piet Mondrian

23

Buenas tardes,

Su objetivo es, en la menor cantidad de bytes de código fuente, recrear cualquiera de las pinturas de 'Composición' de Piet Mondrian (por ejemplo, Composición # 10 ).

La recreación puede usar los colores reales o reemplazarlos con los colores apropiados de la Paleta de 16 colores predeterminada de Windows.

Su recreación se puede generar en PNG, BMP o NetPBM, ya sea en un archivo o en STDOUT, o directamente en la pantalla.

Su recreación debe ser una resolución de 512x512 o superior.

Su recreación no debe acceder a internet. Si su programa requiere archivos de datos, entonces su tamaño se agregará al tamaño de su fuente.

Su puntaje será el tamaño de su archivo fuente en bytes.

Indique con su entrada qué pintura está recreando y proporcione un enlace al original y una imagen de su recreación.

Buena suerte.

lochok
fuente
Paso uno: encuentre un idioma con un codificador PNG, BMP o NetPBM incorporado.
John Dvorak
66
Relevante: Piet
Griffin
44
Es un lenguaje difícil de trabajar ... de vez en cuando intento hacer un Quine generando NetPBM ... pero sí. ¡Me impresionaría mucho si alguien puede recrear Piet Mondrian en Piet!
lochok
2
¿Podemos generar imágenes de personajes utilizando escapes de color de terminal y caracteres de dibujo en bloque? (ej. ▃▃▌) ¿O se plantea esto mejor como un desafío diferente?
Tobia
2
@lochok Ofrecería una recompensa por una respuesta de Piet si alguien estuviera realmente interesado en intentarlo.
Jerry Jeremiah

Respuestas:

14

Tikz, 175 bytes

Composición III en blanco y negro , 175 bytes

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

Verifíquelo en la Blogosfera

Esta es quizás una de las obras más minimalistas de Mondrian y me sorprende que nadie la haya encontrado todavía. Sin embargo, no es particularmente interesante, así que he incluido varias otras pinturas en mi respuesta.

Explicación

Hay un poco de envoltorio asociado con cada respuesta tikz. El contenedor es:

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

Una vez que pase el contenedor, hay algunas \defdeclaraciones que guardan bytes pero desafortunadamente ofuscan el código:

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

Si hacemos todas las sustituciones adecuadas, nuestro código se verá así:

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

El primer bit es un \clipy es muy importante, pero por el momento lo pasaremos por alto.

Ahora dibujamos la primera línea en el lienzo en blanco. Esta línea es bastante gruesa, por lo que usamos [line width=2mm]para configurar el grosor en 2mm:

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

Esto conecta un par de nodos y produce esta forma:

A continuación tenemos \drawun segundo trazo, sin embargo, este trazo es más delgado, por lo que debemos establecer el grosor de la línea en 1mm:

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

Ahora nuestra pintura se ve así:

Esto está cerca del original pero no del todo, así que aquí es donde \clipentra en juego. Usamos el \clippara eliminar todas las líneas adicionales de nuestro lienzo y establecer el lienzo en el tamaño correcto. Con el lienzo redimensionado obtenemos la imagen:

Composición III en blanco y negro


Composición con parche amarillo , 214 bytes

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

Evaluarlo en CyberSpace

Explicación por venir


Composición II en azul y amarillo , 225 bytes

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

¡Evalúelo a través de Webbernetz!

Explicación por venir


Composición B (No. 2) en rojo , 232 bytes

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

¡Intenta hacerlo en Internet!

Explicación

Primero, aquí está el código con saltos de línea insertados para hacerlo más legible:

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

El primer comando de interés es

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

Esto dibuja un rectángulo rojo con un contorno negro. Para la esquina superior izquierda de la pintura.

Luego dibujamos dos rectángulos más con interiores blancos y contornos negros para crear el patrón de cuadrícula en la pintura

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

Luego dibujamos una línea delgada

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

Y recorta la imagen al tamaño adecuado

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


Composición II en rojo, azul y amarillo , 251 bytes

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

¡Pruébelo en la World Wide Web!

Explicación

Primero insertaré algunos saltos de línea para que mi código sea legible

\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 primera línea de importancia es:

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

Esto dibuja la siguiente forma:

Esta extraña forma es el rectángulo amarillo en la esquina inferior derecha y las dos líneas que no son el borde de un rectángulo de color. A continuación, insertamos el cuadrado rojo y cubrimos las líneas adicionales hechas por la última forma:

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

Esto sale como:

Ahora insertamos nuestro cuadrado azul:

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

Ahora todo lo que queda es recortar todas las partes innecesarias de la imagen usando un \clip

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

Composición II en rojo, azul y amarillo


Composición II , 308 bytes.

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

Compruébalo en la autopista de información

Explicación por venir

Asistente de trigo
fuente
12

Mathematica 202 287 bytes.

¡Solo por diversión! 330 bytes: Mondrian con "Boogie Woogie" en su título

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]

ingrese la descripción de la imagen aquí


Envío real [287 bytes]

\[SpanFromLeft]y expresiones similares ocupan aproximadamente 85 bytes. En matemática, cada expresión tiene su símbolo de un carácter dedicado.

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

lado a lado

Salida a la izquierda; foto de Piet Mondrian, composición rojo azul amarillo a la derecha.

DavidC
fuente
3
Buen intento. No obtienes la recompensa tan fácilmente.
Wheat Wizard
11

Ruby, 112 (111) personajes

Piet Mondrian - composición en B (No. II) con rojo

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)

mi producción a la izquierda, la referencia ampliada a la derecha.

ingrese la descripción de la imagen aquí

Los colores se pueden ajustar ligeramente, hasta una precisión de 1/9, sin pérdida de puntaje ajustando el valor máximo en PPM. Elegí el enfoque de "color Win16 adecuado". El blanco 8/9 probablemente esté más cerca del color original del lienzo, pero el 9/9 está más cerca de la intención del autor.

Se puede guardar un personaje si lo reemplazamos "1 0 0 "con (w+b+b)(# F00 rojo). Creo que eso cuenta como "lo suficientemente cerca"

Versión de salida de archivo (no golfizada)

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
fuente
Una fácil: "0 "->b
Howard
@Howard maldita sea. Perdí este mientras minificando. Gracias
John Dvorak
Y algo más si cambias w="2 "a w="2 "*9y btambién.
Howard
umm ... entiendo esto (continúa para siempre)
Pomo de la puerta
@Doorknob guárdelo como un ppmarchivo y ábralo en un editor de imágenes
John Dvorak
9

SmileBASIC, 2774 1892 bytes

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

captura de pantalla

Cada una de las "líneas" en la imagen se almacena en este formato:

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

Todos los números se almacenan como CHR$(number+32), los colores se almacenan como un carácter; w, y, r, O b, y la dirección se almacena como |o-

Los rectángulos adicionales solo se almacenan como:

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

Del mismo modo.

12Me21
fuente
¡Agradable! Estaba pensando en hacer QBasic, pero no hay un modo de pantalla de 512x512.
DLosc
Tuve mucha suerte; Las páginas de gráficos de SmileBASIC son exactamente 512x512 píxeles
12Me21
7

SVG - 455 480- Composición Mondrian II en rojo, azul y amarillo

Si puede incrustar Javascript en SVG y hacerlo dinámico, es un lenguaje de programación. Ergo, este es un programa. Resulta que si falta un xo ycoord en SVG, su valor predeterminado es 0. ¡También redes más corto 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>

Bastante impreso:

<?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
fuente
Espera, pensé que la Composición B (No. II) con Red 1935 era la número 2
John Dvorak,
44
@ JanDvorak No lo sé, solo lo busqué en Wikipedia. Honestamente, Piet era un pintor muy vago. Todos ellos parecen iguales.
Creo que puede evitar la mayoría de las comillas dobles y seguir funcionando en la mayoría de los navegadores. Sin embargo, no estoy seguro del cumplimiento.
John Dvorak
@LegoStormtroopr Lazy? Eso es bastante rico, viniendo de un tipo que se junta en un sitio web dedicado a escribir programas cortos.
stand
1
@boothby Touche. Iba a argumentar que aprendí mucho del golf de código debido a su enfoque hiperminimalista. Pero ... lo mismo podría decirse del trabajo de Piet también.
3

SmileBASIC, 67 bytes

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

Elegí una fácil: Composición III en blanco y negro

Afortunadamente, la página de gráficos de SB tiene exactamente 512x512 píxeles, pero no cabe en la pantalla de 400x240, por lo que no puedo obtener una captura de pantalla fácilmente.

Explicado:

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
fuente
3

Procesamiento, 15,447 15,441 15,439 bytes

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

Fuerza bruta, y no he logrado encontrar una manera de eliminar la función de dibujar.

Es un error en el motor de procesamiento principal, creo que porque es demasiado grande como un b64. Puedes probarlo aquí .

Sin embargo, los violines JS lo recortan a 100 * 100px. Mi base64 funciona, pero el entorno en línea no. :(

Rɪᴋᴇʀ
fuente
Puedes jugar golf usando en su PImage x=loadImage(i);lugar
Kritixi Lithos
1
La pregunta exige una resolución de 512x512 o superior, pero el lienzo en su violín es de solo 100x100. ¿Es esto una peculiaridad de JSFiddle?
Dennis
@ Dennis No es solo el tamaño del lienzo. La imagen se corta tanto en la derecha como en la parte inferior, lo que hace que el resultado sea incorrecto.
mbomb007
@ Dennis Sí, lo es. Establecerlo manualmente en 512 * 512 px todavía lo recorta al mismo tamaño. Es solo el violín JS, y el b64 que utilicé es mayor que 512.
Rɪᴋᴇʀ
data:;base64funciona igual de bien
Kritixi Lithos
2

Love2D, 4956 + 395 + 1 = 5351 bytes

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

El archivo de datos se almacena AQUÍ

Salida:

Salida

Original:

Original

Explicación

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.

El codificador.

Este es solo el script que utilicé para codificar la imagen. Gif funcionó más comprimido, pero no me desafiaron a mostrar 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)

Sobre todo compitiendo por la recompensa. Probablemente haya mejores formas de hacerlo, pero pensé que sería interesante intentar usar una paleta simple y ejecutar la decodificación de longitud.

EDITAR: la imagen de entrada se simplificó, un poco menos precisa, pero una magnitud menos bytes.

Un taco
fuente
2
¿Por qué las partes de su salida parecen estar hechas de piezas de rompecabezas? ¿Es eso lo que quisiste decir con "un poco menos preciso, pero una magnitud menos bytes"? Me parece que las brechas resultantes en las tiras de color hacen que esto no sea una recreación válida.
DLosc