पृष्ठभूमि
एक एल-सिस्टम (या लिंडेनमेयर सिस्टम) एक समानांतर पुनर्लेखन प्रणाली है जो अन्य चीजों के अलावा, आसानी से फ्रैक्टल्स को मॉडल करने के लिए उपयोग किया जा सकता है। यह सवाल नियतात्मक, संदर्भ-मुक्त एल-सिस्टम की चिंता करता है । इनमें प्रतीकों की एक वर्णमाला, एक प्रारंभिक स्वयंसिद्ध स्ट्रिंग और फिर से लिखना नियमों का एक सेट होता है, जो प्रत्येक वर्णमाला प्रतीक को एक नए स्ट्रिंग में मैप करता है। नियमों को समानांतर में स्वयंसिद्ध के लिए लागू किया जाता है, एक नया स्ट्रिंग पैदा करता है। इस प्रक्रिया को फिर दोहराया जाता है।
उदाहरण के लिए, स्वयंसिद्ध "A" और रूल्स A = ABA; B = BBB के साथ सिस्टम "ABA", "ABABBBA", "ABABBBABABBBBBBBBBABABBABA" आदि स्ट्रिंग्स का क्रम उत्पन्न करता है, हम स्पष्टता के लिए स्पष्ट रूप से उल्लेख नहीं करते हैं। एल-सिस्टम को परिभाषित करते समय वर्णमाला। इसके अलावा, एक स्पष्ट पुनर्लेखन नियम के बिना किसी भी प्रतीक को अपरिवर्तित माना जाता है (यानी प्रतीक A के लिए डिफ़ॉल्ट नियम A = A है)।
कछुए ग्राफिक्स के एक रूप का उपयोग करके एल-सिस्टम की कल्पना की जा सकती है। अधिवेशन से, कछुआ दाईं ओर का सामना करना शुरू कर देता है। एक स्ट्रिंग को उसके प्रतीकों पर पुनरावृत्त करके खींचा जाता है: एक एफ का अर्थ है "एक इकाई को आगे बढ़ाएं", एक जी का अर्थ है "एक इकाई को आगे बढ़ाएं", एक + का अर्थ है "एक कोण को छोड़ दिया इकाई" और एक का अर्थ है - "सही एक कोण को चालू करें" इकाई "। स्ट्रिंग में अन्य सभी प्रतीकों को अनदेखा किया जाता है। इस प्रश्न के उद्देश्य के लिए, कोण इकाइयों को हमेशा 90 ° माना जाता है।
कार्य
किसी भी एल-सिस्टम के विनिर्देश और कई पुनरावृत्तियों को देखते हुए, आपके प्रोग्राम को बॉक्स-ड्राइंग वर्णों का उपयोग करके परिणामस्वरूप स्ट्रिंग (जैसा कि ऊपर वर्णित है) का एक ASCII प्रतिपादन करना चाहिए।
- पैरामीटर को अंतरिक्ष-पृथक स्ट्रिंग के रूप में पारित किया जाता है जिसमें स्वयंसिद्ध, पुन: लिखने के नियम (समीकरणों की -separated सूची) और पुन: लेखन पुनरावृत्तियों की संख्या शामिल होती है। उदाहरण के लिए, इनपुट "एफएफ = एफजीएफ; जी = जीजीजी 2" स्ट्रिंग "एफजीएफजीजीएफजीएफ" उत्पन्न करता है और इसलिए उपयुक्त अंतराल के साथ चार लाइनें खींचता है।
- एल-सिस्टम द्वारा उपयोग किए जाने वाले प्रतीक अंतरिक्ष और अर्धविराम के अलावा कोई भी ASCII वर्ण हो सकते हैं। प्रति प्रतीक में निर्दिष्ट एक सबसे स्पष्ट नियम है (डिफ़ॉल्ट पुनर्लेखन नियम के रूप में ऊपर वर्णित पहचान मानचित्रण)।
- आप मान सकते हैं कि आउटपुट में हमेशा कम से कम एक एफ होगा।
- विज़ुअलाइज़ेशन का प्रतिनिधित्व करने के लिए आउटपुट को निम्न UNICODE बॉक्स-ड्रॉइंग वर्णों का उपयोग करना चाहिए : U (U + 2500), 250 (U + 2502), ┌ (U + 250C), ┐ (U + 2510), └ (U + 2514) ,, (U + 2518), ┘ (U + 251C), U (U + 2524), 25 (U + 252C), ┴ (U + 2534), ┼ (U + 253C), ╴ (U + 2574), 25 (U + 2575), ╶ (U + 2576) और U (U + 2577)। उदाहरण के लिए नीचे देखें।
- आउटपुट में सबसे ऊपरी बॉक्स कैरेक्टर के ऊपर या बॉटलमोस्ट एक के नीचे की खाली लाइनें नहीं होनी चाहिए। इसमें बाईं ओर के बॉक्स चेज़र या दाईं ओर दाईं ओर कोई रिक्त स्थान नहीं होना चाहिए। अनुगामी स्थानों वाली रेखाएं जो सबसे सही बॉक्स वर्ण से आगे नहीं बढ़ती हैं, की अनुमति है।
आप STDIN (या निकटतम वैकल्पिक), कमांड-लाइन तर्क या फ़ंक्शन तर्क के माध्यम से इनपुट लेते हुए एक प्रोग्राम या फ़ंक्शन लिख सकते हैं। परिणामों को STDOUT (या निकटतम विकल्प) पर मुद्रित किया जाना चाहिए, एक फ़ाइल में सहेजा गया या एक स्ट्रिंग के रूप में लौटाया जा सकता है।
उदाहरण
# Cantor dust
>> "F F=FGF;G=GGG 0"
╶╴
>> "F F=FGF;G=GGG 1"
╶╴╶╴
>> "F F=FGF;G=GGG 2"
╶╴╶╴ ╶╴╶╴
>> "F F=FGF;G=GGG 3"
╶╴╶╴ ╶╴╶╴ ╶╴╶╴ ╶╴╶╴
# Koch curve
>> "F F=F+F−F−F+F 1"
┌┐
╶┘└╴
>> "F F=F+F-F-F+F 2"
┌┐
┌┘└┐
┌┘ └┐
┌┼┐ ┌┼┐
╶┘└┘ └┘└╴
आपके कार्यक्रम को शामिल करने के लिए अन्य उदाहरणों में शामिल हैं:
# Dragon curve
>> "FX X=X+YF+;Y=-FX-Y n"
# Hilbert curve
>> "A A=-BF+AFA+FB-;B=+AF-BFB-FA+ n"
# Sierpinski carpet
>> "F F=F+F-F-F-G+F+F+F-F;G=GGG n"
पहले दो जो निम्नानुसार दिखते हैं (@ edc65 के उत्तर का उपयोग करके निर्मित):
आप इस पृष्ठ पर किसी भी सिस्टम का परीक्षण कर सकते हैं ।
स्कोरिंग
सबसे छोटा कोड (बाइट्स में) जीतता है। मानक नियम लागू होते हैं।
Miscellania
यह चुनौती ड्रॉ के साथ रैंडम वॉक से प्रेरित थी । वास्तव में, एल-सिस्टम के रूप में एक यादृच्छिक चलना का प्रतिनिधित्व करना संभव है अगर हम प्रतिलेखन के दौरान गैर-नियतात्मक रूप से चुने गए विस्तार के साथ प्रति प्रतीक कई नियमों की अनुमति देने के लिए सिस्टम का विस्तार करते हैं । एक सूत्रीकरण है:
"F F=FF;F=F+F;F=F++F;F=F+++F"
एक और आम विस्तार, जिसका उपयोग अक्सर पौधों को मॉडलिंग करते समय, [] और चरित्रों की व्याख्या करने के लिए किया जाता है क्योंकि वर्तमान स्थिति और कोण को धकेलने और पॉप करने के रूप में। अधिकांश पौधे 90 ° से छोटे कोण का उपयोग करते हैं, लेकिन यहाँ एक उदाहरण है जो नहीं है:
"FAX X=[-FAX][FAX][+FAX];A=AFB;B=A"
इस चुनौती में न तो इन उदाहरणों का समर्थन किया जाना चाहिए।
यह चुनौती भी "माफ करना, जवान आदमी के समान है , लेकिन यह कछुए नीचे सभी तरह से है!" । हालाँकि, उस चुनौती ने ASCII के बजाय लाइन रेंडरिंग का इस्तेमाल किया और एक अधिक लचीली वाक्य रचना की अनुमति दी।