पीट मोंड्रियन रचना का मनोरंजन


23

नमस्कार,

आपका लक्ष्य स्रोत कोड बाइट्स की कम से कम मात्रा में, पीट मोंड्रियन की 'रचना' चित्रों में से किसी को फिर से बनाना है (उदाहरण के लिए, रचना # 10 )।

मनोरंजन या तो वास्तविक रंगों का उपयोग कर सकता है, या इसे विंडोज डिफ़ॉल्ट 16 कलर पैलेट से उपयुक्त रंगों से बदल सकता है

आपका मनोरंजन PNG, BMP या NetPBM में फ़ाइल या STDOUT में या सीधे स्क्रीन पर आउटपुट किया जा सकता है।

आपका मनोरंजन 512x512 या उच्चतर का एक संकल्प होना चाहिए।

आपके मनोरंजन के लिए इंटरनेट का उपयोग नहीं करना चाहिए। यदि आपके प्रोग्राम को डेटा फ़ाइलों की आवश्यकता है, तो उनका आकार आपके स्रोत के आकार में जोड़ दिया जाएगा।

आपका स्कोर बाइट्स में आपके स्रोत फ़ाइल का आकार होगा।

कृपया अपनी प्रविष्टि के साथ बताएं कि आप किस पेंटिंग को फिर से बना रहे हैं, और मूल और आपके मनोरंजन की एक तस्वीर के लिए एक लिंक प्रदान करें।

शुभ लाभ।


एक कदम: एक भाषा में एक अंतर्निहित PNG, BMP या NetPBM एनकोडर के साथ खोजें।
जॉन ड्वोरक

6
प्रासंगिक: पीट
ग्रिफिन

4
यह काम करने के लिए एक कठिन भाषा है ... हर अब और फिर मैं NetPBM का उत्पादन करने के लिए काफी प्रयास करता हूं ... लेकिन हाँ। मैं बहुत प्रभावित होगा अगर कोई पीट मोंड्रियन को पीट में फिर से बना सकता है!
lochok

2
क्या हम टर्मिनल कलर से बचकर और ड्रॉइंग कैरेक्टर्स का उपयोग करके कैरेक्टर आर्ट का उत्पादन कर सकते हैं? (जैसे। eg) या यह एक अलग चुनौती के रूप में सबसे अच्छा है?
टोबिया

2
@lochok अगर किसी को गंभीरता से प्रयास करने में दिलचस्पी थी, तो मैं पीट जवाब के लिए एक इनाम की पेशकश करूंगा।
जेरी जेरेमिया

जवाबों:


14

टिक्ज़, 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 में सत्यापित करें

यह शायद मोंड्रियन के सबसे अतिसूक्ष्म कार्यों में से एक है और मुझे आश्चर्य है कि कोई भी इसे अभी तक नहीं मिला है। यह विशेष रूप से दिलचस्प नहीं है, इसलिए मैंने अपने उत्तर में कई अन्य चित्रों को शामिल किया है।

व्याख्या

थोड़ा सा रैपर है जो हर टिक्ज़ के जवाब से जुड़ा है। आवरण है:

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

पहला बिट एक है \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}

साइबरस्पेस में इसका मूल्यांकन करें

आने की व्याख्या


ब्लू और येलो में रचना 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 पर इसका आकलन करें!

आने की व्याख्या


रचना बी (नंबर 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);

यह एक काले रंग की रूपरेखा के साथ एक लाल आयत खींचता है। पेंटिंग के ऊपरी बाएं हाथ के कोने के लिए।

फिर हम पेंटिंग पर ग्रिड पैटर्न बनाने के लिए सफेद अंदरूनी और काले रंग की रूपरेखा के साथ दो और आयतों को आकर्षित करते हैं

\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

गणितज्ञ 202 287 बाइट्स।

सिर्फ मनोरंजन के लिए! 330 बाइट्स: मोंड्रियन अपने शीर्षक में "बूगी वूगी" के साथ

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 बाइट्स लेते हैं। गणित में प्रत्येक ऐसी अभिव्यक्ति का अपना एक समर्पित प्रतीक होता है।

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

बाईं ओर मेरा उत्पादन, दाईं ओर बढ़ा संदर्भ।

यहाँ छवि विवरण दर्ज करें

पीपीएम में अधिकतम मूल्य को कम करके स्कोर के नुकसान के बिना रंगों को 1/9 की परिशुद्धता तक थोड़ा - थोड़ा बढ़ाया जा सकता है। मैंने "उपयुक्त Win16 रंग" दृष्टिकोण चुना है। 8/9 सफेद शायद कैनवास के मूल रंग के करीब है, लेकिन 9/9 लेखक के इरादे के करीब है।

यदि हम (# F00 लाल) से प्रतिस्थापित "1 0 0 "करते हैं, तो एक वर्ण को बचाया जा सकता है (w+b+b)। मेरा मानना ​​है कि "काफी पास" के रूप में गिना जाता है

फ़ाइल ouptut संस्करण (गोल्फ नहीं)

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
हावर्ड

@ हावर्ड लानत है। इसे छोटा करते हुए याद किया। साभार
जॉन ड्वोरक

और कुछ और अगर आप और भी बदल w="2 "जाते हैं। w="2 "*9b
हावर्ड

उम्म ... मैं इस (इस पर हमेशा के लिए चला जाता है)
दरवाज़े

@Doorknob ppmएक छवि संपादक के रूप में एक फ़ाइल के रूप में सहेजें और खोलें
जॉन ड्वोरक

9

स्माइलबासिक, 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), रंगों को एक वर्ण के रूप में संग्रहीत किया जाता है; w, y, r, या b, और दिशा के रूप में संग्रहीत किया जाता है |या-

अतिरिक्त आयतों को केवल इस प्रकार संग्रहीत किया जाता है:

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

उसी तरह से।


अच्छा! मैं QBasic करने के बारे में सोच रहा था, लेकिन 512x512 स्क्रीन मोड नहीं है।
DLosc

मैं बहुत भाग्यशाली हो गया; SmileBASIC के ग्राफिक्स पृष्ठ बिल्कुल 512x512 पिक्सेल हैं
12M2121

7

एसवीजी - 455 480- रेड, ब्लू और येलो में मैंडरियन कंपोजिशन II

यदि आप जावास्क्रिप्ट को एसवीजी में एम्बेड कर सकते हैं और इसे गतिशील बना सकते हैं, तो यह एक प्रोग्रामिंग भाषा है। एर्गो, यह एक कार्यक्रम है। यह पता चलता है कि SVG में कोई निर्देशांक xया 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 के साथ रचना बी (सं।) # 2
जॉन ड्वोरक

4
@JanDvorak मुझे नहीं पता, मैंने उसे विकिपीडिया पर देखा। ईमानदारी से, पीट एक बहुत आलसी चित्रकार था। वे सभी एक ही दिखते हैं।

मुझे लगता है कि आप अधिकांश दोहरे उद्धरण चिह्नों से बच सकते हैं और अभी भी अधिकांश ब्राउज़रों में काम कर सकते हैं। अनुपालन के बारे में निश्चित नहीं है, हालांकि।
जॉन ड्वोरक

@LegoStormtroopr आलसी? यह बहुत समृद्ध है, एक ऐसे व्यक्ति से आ रहा है जो एक वेबसाइट पर लटका हुआ है जो छोटे कार्यक्रमों को लिखने के लिए समर्पित है।
बूथ

1
@ बाथबी टौच। मैं तर्क देने वाला था कि मैंने अपने हाइपरमिनिमलिस्ट दृष्टिकोण के कारण कोड गोल्फ से बहुत कुछ सीखा है। लेकिन ... वही पीट के काम के लिए भी तर्क दिया जा सकता है।

3

स्माइलबासिक, 67 बाइट्स

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

मैंने एक आसान उठाया: ब्लैक एंड व्हाइट में संरचना III

सौभाग्य से एसबी का ग्राफिक्स पेज बिल्कुल 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 fiddles इसे क्रॉप करता है, हालांकि, 100 * 100px तक। मेरा बेस 64 काम करता है, लेकिन ऑनलाइन वातावरण नहीं करता है। :(


आप PImage x=loadImage(i);इसके बजाय
इसका

1
प्रश्न 512x512 या उच्चतर रिज़ॉल्यूशन की मांग करता है, लेकिन आपके फ़िडल में कैनवास केवल 100x100 है। क्या यह JSFiddle का एक चुटकुला है?
डेनिस

@ डेनिस यह केवल कैनवास का आकार नहीं है। छवि सही और निचले दोनों पर काट दी जाती है, जिससे परिणाम गलत हो जाता है।
mbomb007

@ डेनिस हाँ, यह है। मैन्युअल रूप से इसे 512 * 512 पीएक्स पर सेट करना अभी भी इसे उसी आकार में फसल देता है। यह सिर्फ JS फिडेल है, और b64 जो मैंने इस्तेमाल किया है वह 512 से अधिक है।
R '

data:;base64बस के रूप में अच्छी तरह से काम करता है
Kritii Lithos

2

लव 2 डी, 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
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.