Neuerstellung von Piet Mondrian Composition

23

Guten Nachmittag,

Ihr Ziel ist es, in möglichst wenigen Quellcode-Bytes ein Bild von Piet Mondrians „Komposition“ (z. B. Komposition 10 ) nachzubilden .

Die Neuerstellung kann entweder die tatsächlichen Farben verwenden oder durch die entsprechenden Farben aus der Windows-Standardfarbpalette 16 ersetzen .

Ihre Neuerstellung kann in PNG, BMP oder NetPBM entweder in einer Datei oder in STDOUT oder direkt auf dem Bildschirm ausgegeben werden.

Ihre Erholung muss eine Auflösung von 512x512 oder höher haben.

Ihre Erholung darf nicht auf das Internet zugreifen. Wenn für Ihr Programm Datendateien erforderlich sind, wird deren Größe zur Größe Ihrer Quelle hinzugefügt.

Ihre Punktzahl entspricht der Größe Ihrer Quelldatei in Byte.

Bitte geben Sie mit Ihrer Eingabe an, welches Gemälde Sie nachbilden, und geben Sie einen Link zum Original und ein Bild Ihrer Nachbildung an.

Viel Glück.

Lochok
quelle
Schritt eins: Finden Sie eine Sprache mit einem eingebauten PNG-, BMP- oder NetPBM-Encoder.
John Dvorak
6
Relevant: Piet
Griffin
4
Es ist eine schwierige Sprache, in der ich hin und wieder versuche, eine Quine-Ausgabe von NetPBM zu machen ... aber ja. Ich bin sehr beeindruckt, wenn jemand Piet Mondrian in Piet nachbauen kann!
Lochok
2
Können wir Zeichengrafiken mithilfe von Endfarbenausblendungen ausgeben und Zeichnungszeichen blockieren? (zB ▃▃▌) Oder ist dies die beste Herausforderung?
Tobia
2
@lochok Ich würde ein Kopfgeld für eine Piet-Antwort anbieten, wenn jemand ernsthaft daran interessiert wäre, es zu versuchen.
Jerry Jeremiah

Antworten:

14

Tikz, 175 Bytes

Komposition III in Schwarz und Weiß , 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}

Überprüfen Sie es in der Blogosphäre

Dies ist vielleicht eines von Mondrians minimalistischsten Werken und ich bin überrascht, dass noch niemand es gefunden hat. Es ist jedoch nicht besonders interessant, weshalb ich mehrere andere Bilder in meine Antwort aufgenommen habe.

Erläuterung

Zu jeder Tikz-Antwort gehört ein Wrapper. Der Wrapper ist:

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

Sobald Sie am Wrapper vorbeigekommen sind, gibt es einige \defAnweisungen, die Bytes sparen, aber den Code leider verschleiern:

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

Wenn wir alle richtigen Ersetzungen vornehmen, sieht unser Code folgendermaßen aus:

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

Das erste Bit ist ein \clipund ist sehr wichtig, aber wir werden es vorerst überspringen.

Jetzt zeichnen wir die erste Linie auf die leere Leinwand. Diese Linie ist ziemlich dick, daher stellen wir [line width=2mm]die Dicke ein auf 2mm:

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

Dies verbindet ein paar Knoten und erzeugt diese Form:

Als nächstes haben wir \draweinen zweiten Strich, dieser Strich ist jedoch dünner, so dass wir die Liniendicke einstellen müssen auf 1mm:

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

Jetzt sieht unser Bild so aus:

Dies kommt dem Original sehr nahe, ist aber nicht ganz so. Hier \clipkommt das ins Spiel. Wir verwenden das \clipSymbol, um alle zusätzlichen Zeilen von unserer Zeichenfläche zu entfernen und die richtige Größe für die Zeichenfläche festzulegen. Mit der Größe der Leinwand erhalten wir das Bild:

Komposition III in Schwarz und Weiß


Komposition mit gelbem Fleck , 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}

Bewerten Sie es in CyberSpace

Erklärung zu kommen


Zusammensetzung II in Blau und Gelb , 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}

Bewerte es über das Webbernetz!

Erklärung zu kommen


Zusammensetzung B (Nr. 2) in Rot , 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}

Versuchen Sie es im Internet!

Erläuterung

Hier ist zunächst der Code mit Zeilenumbrüchen eingefügt, um die Lesbarkeit zu verbessern:

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

Der erste Befehl von Interesse ist

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

Dies zeichnet ein rotes Rechteck mit einem schwarzen Umriss. Für die linke obere Ecke des Gemäldes.

Anschließend zeichnen wir zwei weitere Rechtecke mit weißem Interieur und schwarzen Konturen, um das Gittermuster auf dem Gemälde zu erstellen

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

Wir zeichnen dann eine dünne Linie

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

Und beschneiden Sie das Bild auf die richtige Größe

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


Zusammensetzung II in Rot, Blau und Gelb , 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}

Testen Sie es im World Wide Web!

Erläuterung

Zuerst werde ich einige Zeilenumbrüche einfügen, um meinen Code lesbar zu machen

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

Die erste wichtige Linie ist:

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

Dies zeichnet die folgende Form:

Diese seltsame Form ist das gelbe Rechteck in der unteren rechten Ecke und die beiden Linien, die nicht die Kante eines farbigen Rechtecks ​​sind. Als nächstes fügen wir das rote Quadrat ein und vertuschen die zusätzlichen Linien der letzten Form:

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

Das sieht so aus:

Nun fügen wir unser blaues Quadrat ein:

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

Jetzt müssen Sie nur noch alle unnötigen Teile des Bildes mit a ausschneiden \clip

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

Komposition II in Rot, Blau und Gelb


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

Probieren Sie es auf dem Information-Super-Highway aus

Erklärung zu kommen

Weizen-Assistent
quelle
12

Mathematica 202 287 Bytes.

Nur zum Spaß! 330 Bytes: Mondrian mit "Boogie Woogie" im Titel

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]

Bildbeschreibung hier eingeben


Tatsächliche Einreichung [287 Bytes]

\[SpanFromLeft]und ähnliche Ausdrücke belegen ungefähr 85 Bytes. In Mathematica hat jeder dieser Ausdrücke ein spezielles Symbol mit einem Zeichen.

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

Seite an Seite

Ausgang links; Foto von Piet Mondrian, rot blau gelb Komposition rechts.

DavidC
quelle
3
Netter Versuch. Du bekommst das Kopfgeld nicht so leicht.
Weizen-Zauberer
11

Ruby, 112 (111) Zeichen

Piet Mondrian - Komposition in B (Nr. II) mit Rot

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)

Meine Produktion links, die hochskalierte Referenz rechts.

Bildbeschreibung hier eingeben

Die Farben können leicht angepasst werden - bis zu einer Genauigkeit von 1/9 -, ohne dass die Punktzahl verloren geht, indem der Maximalwert in PPM angepasst wird. Ich habe den Ansatz "Geeignete Win16-Farbe" gewählt. 8/9 Weiß ist wahrscheinlich näher an der ursprünglichen Leinwandfarbe, aber 9/9 ist näher an der Absicht des Autors.

Ein Zeichen kann gerettet werden , wenn wir ersetzen "1 0 0 "mit (w+b+b)(# F00 rot). Ich glaube, das zählt als "nah genug"

Dateiausgabeversion (nicht golfen)

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
quelle
Eine einfache: "0 "->b
Howard
@Howard verdammt. Habe das beim Minimieren verpasst. Vielen Dank
John Dvorak
Und noch einiges mehr, wenn Sie w="2 "zu w="2 "*9und bauch wechseln .
Howard
ähm ... ich verstehe das (es geht für immer weiter)
Türklinke
@Doorknob als ppmDatei speichern und in einem Bildbearbeitungsprogramm öffnen
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

Bildschirmfoto

Jede der "Zeilen" im Bild wird in diesem Format gespeichert:

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

Alle Zahlen werden gespeichert als CHR$(number+32), Farben werden als ein Zeichen gespeichert; w, y, r, Oder b, und die Richtung wird gespeichert , wie |oder-

Die zusätzlichen Rechtecke werden wie folgt gespeichert:

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

Auf die gleiche Weise.

12Me21
quelle
Nett! Ich habe überlegt, QBasic zu machen, aber es gibt keinen 512x512-Bildschirmmodus.
DLosc
Ich hatte sehr viel Glück. Die Grafikseiten von SmileBASIC sind genau 512
x
7

SVG - 455 480- Mondrian Komposition II in Rot, Blau und Gelb

Wenn Sie Javascript in SVG einbetten und es dynamisch gestalten können, ist es eine Programmiersprache. Ergo, das ist ein Programm. Stellt sich heraus, wenn ein xoder eine yKoordinate in SVG fehlt, ist der Standardwert 0. Ist auch redkürzer als #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>

Ziemlich gedruckt:

<?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
quelle
Warten Sie, ich dachte, Zusammensetzung B (Nr. II) mit Rot 1935 war # 2
John Dvorak
4
@ JanDvorak Ich weiß nicht, ich habe ihn gerade bei Wikipedia nachgeschlagen. Ehrlich gesagt war Piet ein ziemlich fauler Maler. Alle sehen gleich aus.
Ich denke, Sie können die meisten doppelten Anführungszeichen vermeiden und trotzdem in den meisten Browsern arbeiten. Ich bin mir jedoch nicht sicher, ob die Richtlinien eingehalten werden.
John Dvorak
@LegoStormtroopr Faul? Das ist ziemlich reichhaltig und kommt von einem Typ, der auf einer Website rumhängt, die sich dem Schreiben von Kurzprogrammen widmet.
Stand
1
@boothby Touche. Ich wollte argumentieren, dass ich aufgrund seines hyperminimalistischen Ansatzes viel von Codegolf gelernt habe. Aber ... dasselbe könnte man auch von Piets Werk behaupten.
3

SmileBASIC, 67 Bytes

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

Ich habe mir ein einfaches ausgesucht: Komposition III in Schwarz und Weiß

Glücklicherweise ist die Grafikseite von SB genau 512x512 Pixel groß, aber es passt nicht alles auf den 400x240-Bildschirm, so dass ich keinen Screenshot einfach bekommen kann.

Erklärt:

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

Verarbeitung, 15.447, 15.441 , 15.439 Bytes

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

Brute Force, und ich habe es nicht geschafft, die Zeichenfunktion zu entfernen.

Es gibt Fehler in der Hauptverarbeitungs-Engine, ich denke, weil es von einem b64 zu groß ist. Sie können es hier testen .

JS Fiddles beschneidet es allerdings auf 100 * 100px. Mein base64 funktioniert, die Online-Umgebung jedoch nicht. :(

Rɪᴋᴇʀ
quelle
Sie können dies Golf, indem Sie PImage x=loadImage(i);stattdessen
Kritixi Lithos
1
Die Frage erfordert eine Auflösung von 512x512 oder höher, aber die Leinwand in Ihrer Geige ist nur 100x100. Ist das eine Eigenheit von JSFiddle?
Dennis
@Dennis Es geht nicht nur um die Leinwandgröße. Das Bild wird rechts und unten abgeschnitten, wodurch das Ergebnis falsch wird.
mbomb007
@ Tennis Ja, das ist es. Durch manuelles Festlegen auf 512 * 512 px wird es immer noch auf dieselbe Größe zugeschnitten. Es ist nur JS Geige, und die B64, die ich verwendet habe, ist größer als 512.
Rɪᴋᴇʀ
data:;base64funktioniert genauso gut
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") 

Die Datendatei wird HIER gespeichert

Ausgabe:

Ausgabe

Original:

Original

Erläuterung

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.

Der Encoder.

Dies ist nur das Skript, mit dem ich das Bild codiert habe. Gif wurde komprimierter, aber ich wurde nicht aufgefordert, ein Gif anzuzeigen.

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)

Meist im Wettbewerb um das Kopfgeld. Es gibt wahrscheinlich bessere Möglichkeiten, dies zu tun, aber ich hielt es für interessant, eine einfache Palette zu verwenden und die Lauflänge zu dekodieren.

BEARBEITEN: Das Eingabebild wurde vereinfacht, etwas ungenauer, aber um eine Größenordnung kleiner.

Ein Taco
quelle
2
Warum sehen Teile Ihrer Ausgabe so aus, als bestünden sie aus Puzzleteilen? Ist es das, was Sie mit "etwas weniger genau, aber eine Größenordnung weniger Bytes" gemeint haben? Es scheint mir, dass die resultierenden Lücken in den Farbstreifen dies nicht zu einer gültigen Neuerstellung machen.
DLosc