Brainfuck

מתוך המכלול, האנציקלופדיה היהודית
קפיצה לניווט קפיצה לחיפוש

Brainfuck ובקיצור BF, היא שפת תכנות אזוטרית המורכבת משמונה פקודות בלבד, אך יחד עם זאת ממָמשת מכונת טיורינג אוניברסלית, ובנוסף, פונקציות קלט ופלט. את השפה פיתח אורבן מילר, בשנת 1993. השפה לא נועדה לשרת צורך מעשי כלשהו, אלא למטרת שעשוע והדגמה של מינימליזם.

מטעמי נימוס, השפה מכונה גם ***Brainf או Brainf*ck.

המכונה שעליה פועלת שפת BF כוללת:

  • זיכרון לאחסון התוכנית.
  • זיכרון נפרד לאחסון הנתונים שעליהם פועלת התוכנית. זהו מערך של תאים, שגודל כל אחד מהם בית אחד והערך ההתחלתי של כל אחד מהם הוא 0.
  • מצביע על התא הנוכחי בזיכרון הנתונים. בערכו ההתחלתי המצביע מצביע על התא הראשון בזיכרון הנתונים.
  • מחרוזת קלט.
  • מחרוזת פלט.

הפקודות של BF

הפקודה המשמעות
< קדם את המצביע לתא הבא
> החזר את המצביע תא אחד לאחור
+ הוסף 1 לתא הנוכחי
- חסר 1 מהתא הנוכחי
, קרא תו ממחרוזת הקלט והכנס את ערך ה-ASCII שלו לתוך התא הנוכחי
. כתוב את ערך ה-ASCII של התא הנוכחי למחרוזת הפלט
] דלג קדימה לפקודה שאחרי ה-[ המתאים אם התא הנוכחי שווה ל-0
[ דלג אחורה לפקודה שאחרי ה-] המתאים אם התא הנוכחי שונה מ-0
כל תו אחר כל תו אחר, כולל רווחים ושורות חדשות, נחשב להערה, ופרשן או מהדר השפה מתעלם ממנו

ניתן להוכיח ששפת תכנות זו מממשת מכונת טיורינג אוניברסלית שלמה (במידה ויש מספר אינסופי של תאים או שאין הגבלה על גודל התא). אוצר הפקודות הדל של השפה, ופשטותן של הפקודות, עושים את התכנות באמצעותה למשימה מייגעת (עניין המסביר את שמה).

דוגמה לתוכנית Hello world (כמובן, זו לא הדרך היחידה לייצר פלט זה):

+++++ +++++             מאתחל את האוגר (תא מס' 0) ב 10
[                       משתמש בלולאה כדי להוסיף לכל אחד מהתאים הבאים את הערכים 7/10/3/1
    > +++++ ++              מוסיף 7 לתא מס' 1
    > +++++ +++++           מוסיף 10 לתא מס' 2 
    > +++                   מוסיף 3 לתא מס' 3
    > +                     מוסיף 1 לתא מס' 4
    <<<< -                  מחזיר את הרגיסטר לתא מס' 0
]
                            :לאחר 10 מעברים על הלולאה שבשורות 2–8 תאים 1–4 מכילים את הערכים הבאים
                            תא מס' 1 מכיל 70
                            תא מס' 2 מכיל 100
                            תא מס' 3 מכיל 30
                            תא מס' 4 מכיל 10
                            
> ++ .                  מדפיס 'H'   מוסיף לתא 1 שמכיל 70 עוד 2 ומדפיס את קוד האסקי 72 שהוא האות
> + .                   מדפיס 'e'   המצביע מתקדם לתא 2 שמכיל 100 מוסיף לו 1 ומדפיס את קוד האסקי 101 שהוא האות
+++++ ++ .              מדפיס 'l'   מוסיף 7 ומדפיס את קוד אסקי 108
.                       מדפיס 'l'   קוד אסקי 108
+++ .                   מדפיס 'o'   קוד אסקי 111
> ++ .                  עובר לתא 3 שמכיל 30 מוסיף לו 2 ומדפיס את קוד אסקי 32 ומדפיס רווח 
<< +++++ +++++ +++++ .  מדפיס 'W'   
> .                     מדפיס 'o'   
+++ .                   מדפיס 'r'
----- - .               מדפיס 'l'
----- --- .             מדפיס 'd'
> + .                   מדפיס '!'
> .                     יורד שורה

כאמור, רווחים, שורות חדשות, וכל תו פרט לשמונת התווים המרכיבים את השפה נחשב להערה. את אותה תוכנית ניתן לרשום, בלי כל ההערות, כך:

++++++++++[>+++++++>++++++++++>+++>+<<<<-]>++.>+.+++++++..+++.>++.<<+++++++++++++++.>.+++.------.--------.>+.>.


ניתן "לתרגם" בין שפת BF ובין חלק משפת C לפי הטבלה הבאה:

Brainfuck שפת C שפת
> ++ptr;
< --ptr;
+ ++*ptr;
- --*ptr;
, *ptr = getchar();
. putchar(*ptr);
[ while (*ptr) {
] }

כמובן שתרגום זה איננו מלא, ולא ניתן ליצור כך תוכנית תקינה בשפת C.

גם לשפת סף ניתן לתרגם בקלות חלק מהפקודות, למשל:


inc bx ; > כאשר bx מצביע למיקום התא הנוכחי
dec bx ; < 
inc [bx] ; + 
dec [bx] ; -

לשאר הפקודות צריכים לכתוב מקרו מתאים.



ראו גם

קישורים חיצוניים

ויקישיתוף מדיה וקבצים בנושא Brainfuck בוויקישיתוף
הערך באדיבות ויקיפדיה העברית, קרדיט,
רשימת התורמים
רישיון cc-by-sa 3.0

Brainfuck34712085Q244627