Tiny BASIC - Tiny BASIC

Tiny BASIC
РазработаноДеннис Эллисон
Впервые появился1975
Язык реализацииIL (интерпретирующий язык)
ЛицензияВсеобщее достояние
Диалекты
Denver Tiny BASIC, Enhanced 6800 Tiny BASIC, MINOL, Национальный промышленный базовый язык, Palo Alto Tiny BASIC, 6800 Tiny BASIC, TBI68K, Tiny BASIC Extended
Под влиянием
Дартмутский ОСНОВНОЙ, 8008 ОСНОВНОЙ
Под влиянием
Astro BASIC, Atari BASIC, Atom BASIC, BBC BASIC, Уровень I BASIC
Моноширинный шрифт гласит: «Крошечный базовый шрифт для Intel 8080, версия 2.0, автор Ли-Чен Ван, модифицированный и переведенный на мнемонику Intel Роджером Раусклобом, 10 октября 1976 г. @ Copyleft, All Wrongs Reserved».
Использование «Копилефта; все заблуждения защищены» в 1976 г.[1]

Tiny BASIC это семья диалекты из BASIC язык программирования который может поместиться в 4 или меньше КБ из объем памяти. Tiny BASIC был разработан в ответ на Открой письмо опубликовано Билл Гейтс жалуются на пользователей "пиратство " Альтаир БАЗОВЫЙ, который был продан за 150 долларов. Сначала был определен язык Tiny BASIC, а затем программисты были приглашены реализовать его для различных микропроцессоров и открыто поделиться своим исходным кодом. Доктор Ли-Чен Ван, автор книги Palo Alto Tiny BASIC, ввел термин "авторское лево ", чтобы описать это. Tiny BASIC - это пример бесплатно программное обеспечение проект, существовавший до движение за свободное программное обеспечение. Реакция сообщества на Tiny BASIC была настолько ошеломляющей, что то, что было запланировано в виде трех информационных бюллетеней, было возобновлено, когда Журнал доктора Добба, первое регулярное периодическое издание о программном обеспечении для микрокомпьютеров, которое выпускалось в печатном виде в течение 34 лет.

Небольшой размер и бесплатный исходный код сделали эти реализации бесценными в первые дни микрокомпьютеры в середине 1970-х, когда баран был дорогим, и типичный объем памяти составлял от 4 до 8 КБ. Хотя Altair BASIC также будет работать на машинах размером 4 КБ, для программ BASIC останется только 790 байт. Больше свободного места было значительным преимуществом Tiny BASIC.

Чтобы соответствовать этим строгим ограничениям размера, диалекты Tiny BASIC обычно отличались от других реализаций BASIC ключевыми способами:

  • Исходный код был доступен бесплатно как вводные программы
  • Математика была чисто целое число основан
  • Было доступно только 26 переменных с именами от A до Z; ПРОБЕГ не обязательно сбрасывал эти переменные до нуля
  • Аргументы ЕСЛИ и ИДТИ К могут быть числовые выражения:
    • ЕСЛИ выполнил свой последующий оператор для любого ненулевого значения
    • ИДТИ К и GOSUB может принимать выражение, а не номер строки, обеспечивая назначен GOTO а не оператор переключения из ON-GOTO / GOSUB структура более типична для BASIC.

Поскольку это был призыв сообщества к реализации BASIC, любой мог создать Tiny BASIC диалект, и эти диалекты сильно различались по структуре языка. Некоторые усеченные ключевые слова, некоторые разрешенные сокращения, некоторые предлагали нестандартные способы доступа к ОЗУ для решения проблемы отсутствия массивы и обработка строк.

Крошечные реализации BASIC все еще используются для программирования микроконтроллеры такой как Ардуино.

История

Деннис Эллисон, сотрудник факультета компьютерных наук Стэндфордский Университет, написал спецификацию для простой версии языка программирования BASIC.[2] Его убедили создать стандарт Боб Альбрехт из Домашний компьютерный клуб, кто видел BASIC на миникомпьютеры и чувствовал, что он идеально подходит для новых машин, таких как MITS Altair 8800, который был выпущен в январе 1975 года. Предложенная Эллисон конструкция использовала только целочисленную арифметику и не поддерживала массивы или манипуляции со строками. Задача заключалась в том, чтобы программа поместилась в памяти от 2 до 3 килобайт.

Общий дизайн Tiny BASIC был опубликован в сентябрьском выпуске журнала Народная компьютерная компания (PCC) информационный бюллетень вместе с исходным кодом на промежуточном языке. В бюллетене были ссылки на тексты компилятора и выделен UIUC BASIC.[3] В июне 1974 года Альфред Уивер, Майкл Тиндалл и Рональд Дэниэлсон из Иллинойсский университет в Урбана-Шампейн доказали, что можно создать «Интерпретатор языка BASIC для микропроцессора Intel 8008» в одноименной статье, хотя их приложение было развернуто на симуляторе 8008 для IBM 360/75 и требовалось 16кБ.[4]

Реализации Tiny BASIC, которые соответствовали критериям проектирования и часто превышали их, вскоре были отправлены в PCC, в первую очередь Tiny BASIC Extended от Дика Уиппла и Джона Арнольда, который работал с 3 КБ ОЗУ, добавлено ДЛЯ ... NXT циклы, и допускается единственный числовой массив. Дуэт написал Tiny BASIC Extended прямо в машинном коде, используя восьмеричный.[3]

Посыпались вопросы и комментарии, и к концу года Альбрехт («дракон») пообещал собрать их в отдельный информационный бюллетень и опубликовать как минимум три выпуска. Первое издание было опубликовано в январе 1976 года под названием «Крошечный БЕЙСИК-журнал доктора Добба: художественная гимнастика и ортодонтия, бегущий свет без избыточного байта». Он включал перепечатку оригинальной сентябрьской статьи Tiny BASIC Extended, а также множество примечаний и комментариев пользователей.

Ответ на первый выпуск был настолько впечатляющим, что во введении ко второму выпуску говорилось, что они уже решили продолжить публикацию нового информационного бюллетеня под названием Журнал доктора Добба. В течение следующих нескольких выпусков были опубликованы дополнительные версии языка, и аналогичные статьи начали появляться в других журналах, таких как Возраст интерфейса.

К середине 1976 года интерпретаторы Tiny BASIC были доступны для Intel 8080, то Motorola 6800 и Технология MOS 6502 процессоры. Это было предшественником совместной разработки сообщества свободного программного обеспечения до того, как Интернет позволил легко передавать файлы, и был примером проекта свободного программного обеспечения до движение за свободное программное обеспечение.[5] Любители компьютеров обменивались бы бумажными лентами, кассетами или даже перепечатывали файлы из распечатанных списков.[6]

Джим Уоррен, редактор Доктора Добба, писал в июле 1976 г. ACM Язык программирования информационный бюллетень о мотивах и методах этого успешного проекта. Он начал с этого: «Есть жизнеспособная альтернатива проблемам, поднятым Биллом Гейтсом в его разгневанном письмо компьютерным любителям по поводу "сдирания" софта. Когда программное обеспечение является бесплатным или настолько дешевым, что за него легче платить, чем копировать его, тогда оно не будет «украдено» ». Письмо Билла Гейтса было написано, чтобы сделать программное обеспечение товары. Альтернативный метод заключался в том, чтобы опытный профессионал сделал общий дизайн, а затем наметил стратегию реализации. Знающие любители реализовали бы дизайн для множества компьютерных систем. Уоррен предсказал, что эта стратегия будет продолжена и расширена.[6]

В майском выпуске 1976 г. Доктор Доббс имел Ли-Чен Ван Palo Alto Tiny BASIC для микропроцессора Intel 8080. Список начинался с обычного названия, имени автора и даты, но в нем также было "@COPYLEFT, ВСЕ НЕПРАВИЛЬНЫЕ ЗАЩИТЫ ЗАЩИЩЕНЫ".[7] Парень Домашний компьютерный клуб член, Роджер Раусколб, модифицировал и улучшил программу Ли-Чен Вана, и она была опубликована в декабрьском выпуске 1976 г. Возраст интерфейса журнал.[1] Роджер добавил свое имя и сохранил уведомление COPYLEFT.

Palo Alto Tiny BASIC был адаптирован для Sharp PC-1211 карманный компьютер. Другие реализации Tiny BASIC были позже разработаны для программируемые калькуляторы, но современные калькуляторы BASIC сильно отличаются от Tiny BASIC своим уникальным синтаксисом и множеством дополнительных функций. Последний остаток Tiny BASIC в этих реализациях - ограничение имен переменных (A-Z и один массив Z в Casio BASIC, похожий на TI-BASIC, который добавляет нумерованные строки и списки).

Описание

Базовые концепты

Видеть БЕЙСИК-переводчики

Tiny BASIC был разработан таким образом, чтобы использовать как можно меньше памяти, и это отражено в нехватке функций, а также в деталях его система переводчика. Ранним микрокомпьютерам не хватало оперативной памяти и вторичное хранилище для BASIC компилятор, что было более типично для систем с разделением времени.

Как и большинство BASIC того времени, Tiny Basic был интерактивным, когда пользователь вводил операторы в командную строку. Поскольку микрокомпьютеры той эпохи часто использовались с телетайпами или «тупыми» терминалами, прямое редактирование существующего текста было невозможно, и вместо этого редактор использовал выносные символы, часто обратную косую черту, чтобы указать, где пользователь делал резервную копию для редактирования существующего текста.

Если пользователь ввел оператор в командную строку, система проверила его, чтобы увидеть, начинается ли оно с числа. Если этого не произошло, строка немедленно анализировалась и обрабатывалась, потенциально генерируя вывод через РАСПЕЧАТАТЬ. Это было известно как «прямой режим».

Если строка была введена с ведущим числом, число было преобразовано из десятичного формата, например "50", и преобразовано в 8-битное значение, в данном случае 32 доллара США. шестнадцатеричный. Это число использовалось в качестве индекса в множество -подобная область хранения, где остальная часть строки хранилась в том формате, в котором она была набрана. Когда пользователь набрал СПИСОК в командную строку система будет перебирать массив, преобразовывать номер строки обратно в десятичный формат, а затем распечатывать остальной текст в строке.

Когда программа присутствует в памяти и пользователь вводит ПРОБЕГ команда, система переходит в «непрямой режим». В этом режиме устанавливается указатель на первую строку программы, например, 10 ($ 0A в шестнадцатеричной системе). Исходный текст для этой строки затем извлекается из хранилища и запускается, как если бы пользователь только что набрал его в прямом режиме. Затем указатель переместится на следующую строку, и процесс продолжится.

Формальная грамматика

Грамматика приведена ниже в Форма Бэкуса-Наура, почти в точности так, как указано в примечании к дизайну.[8] В списке звездочка ("*") обозначает ноль или более объектов слева от него - за исключением первой звездочки в определении"срок", который является оператором умножения; круглые скобки группируют объекты; и эпсилон ("ε") означает пустое множество. Как это часто бывает в грамматических обозначениях компьютерного языка, вертикальная черта ("|") различает альтернативы, так как они перечислены в отдельных строках. Символ"CR"обозначает возврат каретки (обычно генерируется клавишей «Enter» на клавиатуре). ПЕРЕРЫВ с консоли прервет выполнение программы.

    линия ::= номер утверждение CR | утверждение CR     утверждение ::= РАСПЕЧАТАТЬ expr-list                  ЕСЛИ выражение перевернуть выражение ТОГДА утверждение                  ИДТИ К выражение                  ВХОД список переменных                  ПОЗВОЛЯТЬ вар = выражение                  GOSUB выражение                  ВОЗВРАЩАТЬСЯ                  ЧИСТО                  СПИСОК                  ПРОБЕГ                  КОНЕЦ     expr-list ::= (нить|выражение) (, (нить|выражение) )*     список переменных ::= вар (, вар)*     выражение ::= (+ | - | ε) срок ((+|-) срок)*     срок ::= фактор ((*|/) фактор)*     фактор ::= вар | номер | (выражение)     вар ::= А | B | C ... | Y | Z номер ::= цифра цифра*     цифра ::= 0 | 1 | 2 | 3 | ... | 8 | 9     перевернуть ::= < (>|=| ε) | > (<|=| ε) | =    нить ::= "(|! | # | $ ... - |. | / | цифра |: ... @ | A | B | C ... | X | Y | Z) *"

Обратите внимание, что строка не была определена в примечаниях к дизайну.

Этот синтаксис, каким бы простым он ни был, добавил одно новшество: ИДТИ К и GOSUB может принимать выражение, а не просто номер строки, обеспечивая назначен GOTO[9] а не оператор переключения из GOTO / GOSUB ... OF ..., структура затем поддерживается в БАЗОВЫЙ HP с разделением времени и предшествующий ВКЛ ... НАЙТИ. Синтаксис, позволяющий IF-THEN заявление (в отличие от просто номера строки для перехода) еще не поддерживался в Dartmouth BASIC, как на этот раз, но был введен Digital[10] и скопирован Microsoft.

Реализация на виртуальной машине

В конструкторской записке указывается виртуальная машина, в котором Tiny BASIC устный переводчик сам запускается на интерпретаторе виртуальной машины. Идея разработчика использовать виртуальную машину приложения восходит к Валу Шорру (с МЕТА II, 1964) и Гленни (синтаксическая машина). Выбор подхода виртуальной машины позволил сэкономить место в памяти и усилия по реализации, хотя программы BASIC, выполняемые на ней, выполнялись несколько медленно.[11]

Диалекты, которые использовали виртуальную машину, включают Tiny BASIC Extended, Tom Pittman's Tiny BASIC.[12] и НИБЛ. Другие диалекты, такие как Denver Tiny BASIC (DTB) и Palo Alto Tiny BASIC, были прямыми переводчиками. Некоторые программисты, такие как Фред Гриб с DTB, рассматривали программу IL (интерпретирующий язык) как псевдокод для алгоритм реализовать на ассемблере; Denver Tiny BASIC не использовал виртуальную машину, но внимательно следил за программой IL.

Это типичный отрывок из 120-строчной программы IL:

S1:  TST     S3,'ИДТИ'       ; ПЕРЕЙТИ ИЛИ ГОСУБ?     TST     S2,'К'       ; ДА ... К, ИЛИ ... ПОД     ВЫЗОВ    EXPR          ; ПОЛУЧИТЬ ЭТИКЕТКУ     СДЕЛАНО                  ; ОШИБКА, ЕСЛИ CR НЕ СЛЕДУЕТ     XFER                  ; УСТАНОВИТЬ И ПрыгатьS3:  TST     S8,'РАСПЕЧАТАТЬ'    ;РАСПЕЧАТАТЬ.

Распространенным шаблоном в программе является проверка ключевого слова или части ключевого слова, а затем обработка этой информации. Каждый тест - это утверждение, что будет следующим в строковом буфере. Если утверждение не выполняется, элемент управления переходит к следующей метке (обычно в поисках нового ключевого слова или токена). Здесь система перемещает свой буферный курсор на любые пробелы и проверяет наличие ИДТИ и если он не может его найти, то переходит к строке S3. Если он его находит, выполнение продолжается со следующей команды IL. В этом случае система проводит следующую проверку на К, переход к строке S2 если это не удается (тест на SUB, чтобы узнать, не является ли это GOSUB команда). Если он проходит, контроль продолжается; в этом случае вызов подпрограммы IL, которая начинается с метки EXPR, который анализирует выражение. В Tiny BASIC, GOTO X * 10 + 100 (вычисленное GO TO) так же законно, как GOTO 100 и является альтернативой ON-GOTO более крупных реализаций BASIC. Подпрограмма EXPR помещает результат выражения в арифметический стек (в данном случае номер строки). СДЕЛАНО проверяет, что за выражением не следует другой текст, и выдает ошибку, если это так. XFER извлекает номер из стека и передает выполнение (ПЕРЕХОДИТ) на соответствующий номер строки, если он существует.

В следующей таблице приведен неполный список из 32 команд виртуальной машины, на которой был написан первый интерпретатор Tiny BASIC.[13]

TST фунт, нить
Если нить соответствует строке BASIC, переместите курсор на нить и выполнить следующую инструкцию IL; если тест не пройден, выполните инструкцию IL на метке фунт
ВЫЗОВ фунт
Выполните подпрограмму IL, начиная с фунт; сохранить IL-адрес после CALL в стеке управления
СДЕЛАНО
Сообщить о синтаксической ошибке, если после удаления начальных пробелов курсор не позиционируется для достижения возврата каретки
XFER
Проверить, чтобы значение наверху стека AE было в пределах ranqe. Если нет, сообщите об ошибке. Если да, попытайтесь поместить курсор в эту строку. Если он существует, начните интерпретацию там; если нет, сообщите об ошибке.
ПРЫГАТЬ фунт
Продолжить выполнение IL на указанной метке
РТН
Вернитесь в расположение IL, указанное наверху стека элементов управления
ССН
Печатать символы из текста BASIC до закрывающей кавычки, но не включая ее
PRN
Вывести число, полученное выталкиванием вершины стека выражений
SPC
Вставьте пробелы, чтобы переместить печатающую головку в следующую зону
NLINE
Вывести CRLF[14] к принтеру

Том Питтман, обсуждая IL, говорит: «Интерпретатор TINY BASIC был разработан Деннисом Эллисоном как парсер рекурсивного спуска. Часть элегантной простоты этого дизайна была потеряна из-за добавления синтаксического сахара к языку, но основная форма осталась. IL особенно подходит для анализа TINY BASIC с рекурсивным спуском из-за общей рекурсивной природы его процедур и простоты токенов TINY BASIC. Язык IL эффективно оптимизирован для интерпретации TINY. Опыт показал, что сложность добавления новых функций в язык несоизмерима с природой этих функций. Обычно для поддержки новых функций необходимо добавлять дополнительные подпрограммы на машинном языке. Часто сложность перевешивает преимущества ".[15]

Отклонения от дизайна

Определяя Tiny BASIC для Homebrew Computer Club, Питтман писал: «Tiny BASIC - это правильное подмножество Dartmouth BASIC, состоящее только из следующих типов операторов: LET, PRINT, INPUT, IF, GOTO, GOSUB, RETURN, END, CLEAR, LIST. , RUN. Арифметика в 16-битных целых числах только с операторами + - * / и вложенными круглыми скобками. Имеется только 26 однобуквенных имен переменных A, B, ... Z и нет функций. Нет строк или массивов ... Tiny BASIC определяет номера строк меньше 256. "[16] Затем он описал свою реализацию: «Этот язык был дополнен функциями RND, USR, PEEK и POKE, предоставляя пользователю доступ ко всем его системным компонентам в 6800 из программы BASIC».

Многие разработчики привнесли свой собственный опыт работы с БАЗОВЫЙ HP с разделением времени или же DEC BASIC-PLUS к их дизайну и смягчили формальную спецификацию языка Tiny BASIC. Из семи известных реализаций, опубликованных к 1977 году:

  • Все добавили какую-то функцию случайных чисел, обычно RND (). Хотя это и не было включено в спецификацию, в статье информационного бюллетеня до Design Note для Tiny BASIC запрашивалась только эта функция.
  • Все включено ПОЗВОЛЯТЬ быть необязательным, и большинство выражений let в операторах присваивания содержат реляционные операторы.
  • Все, кроме 6800 ТБ, поддерживали разделители операторов в строках, обычно : хотя ТВХ использовал $ и PATB использовали ;.
  • В ЕСЛИ операторы, все, кроме MINOL, устранили необходимость в выражениях, содержащих операторы отношения (например, ЕСЛИИксТОГДАПОЗВОЛЯТЬY=Икс был действителен). Удаленные реализации ТОГДА полностью или сделал его необязательным или поддержал только для подразумеваемых ИДТИ К.
  • Многие модифицированные РАСПЕЧАТАТЬ для поддержки зон печати, используя , перейти в следующую зону и ; чтобы не продвигать курсор.
  • Добавлены все, кроме 6800 ТБ и DTB НОВЫЙ.
  • Все, кроме 6800TB и MINOL, добавили функцию для возврата размера памяти: TBX имел SZE, DTB и PATB имели РАЗМЕР, L1B имел MEM, а у NIBL ВЕРХ.
  • Четыре реализации добавили массивы, будь то один безразмерный массив в PATB и L1B или Тусклыйподходящие массивы в TBX и DTB.
  • Четыре реализации добавили REMзаявление ковчега.
  • Четыре реализации добавили ЗА цикл: предлагаются PATB, NIBL ​​и L1B ДЛЯ ШАГА / СЛЕДУЮЩЕГО, а TBX не поддерживает ШАГ и использовал ключевое слово NXT чтобы завершить цикл.
  • Только NIBL ​​одобрял структурное программирование, ДЕЛАТЬ / ДО, несмотря на причитания Эллисон в Выпуске 2 о проблемах с BASIC.

В качестве альтернативы токенизации для экономии RAM, TBX,[17] DTB,[18] и MINOL[19] усеченные ключевые слова: PR за РАСПЕЧАТАТЬ, В за ВХОД, RET за ВОЗВРАЩАТЬСЯ. Полные традиционные ключевые слова не принимаются. В отличие от этого, PATB разрешал общепринятые традиционные ключевые слова, но также позволял сокращать любое ключевое слово до его минимальной уникальной строки с завершающей точкой. Например, РАСПЕЧАТАТЬ можно набрать П., несмотря на то что PR. и другие варианты тоже работали. Эта система была сохранена в Уровень I BASIC для TRS-80, который использовал PATB, а также позже был обнаружен в Atari BASIC и БЕЙСИК различных Карманные компьютеры Sharp.[20]

Диалекты

Наиболее известными диалектами Tiny BASIC были оригинальная Design Note, Tiny BASIC Extended, Palo Alto Tiny BASIC и 6800 Tiny BASIC. Однако существовало много других версий Tiny BASIC.

Список известных диалектов

Tiny BASIC впервые был опубликован в информационном бюллетене Народная компьютерная компания, информационный бюллетень, который стал Журнал доктора Добба, долгоживущий компьютерный журнал. В журнале было опубликовано около десяти версий.

Выдающиеся диалекты Tiny BASIC (в журнале доктора Добба)
Дата публикацииПроблемаДиалектАвторПроцессорРазмер
Декабрь 1975 г.1[21]Примечание по дизайнуДеннис ЭллисонНет данныхНет данных
Февраль 1976 г.2[17]Tiny BASIC Extended (TBX)Дик Уиппл и Джон Арнольд80802,9 тыс.
Март 1976 г.3[18]Денвер Tiny BASIC (DTB)Фред Гриб80802,75 тыс.
Март 1976 г.3[22]6800 Tiny BASIC (6800 ТБ)Том Питтман68002K[23]
Апрель 1976 г.4[19]MINOLЭрик Т. Мюллер80801,75 тыс.
Май 1976 г.5[24]Palo Alto Tiny BASIC (PATB)Ли-Чен Ван80801,77 тыс.
Ноябрь 1976 г.10[25]Национальный промышленный базовый язык (NIBL)Марк Александр и Стив ЛейнингерSC / MP4K
Октябрь 1980 г.49[26]Улучшенный 6800 Tiny BASICРоберт Хадсон6800Нет данных
Февраль 1985 г.100[27]TBI68KГордон Брэндли68000Нет данных
Январь 2006 г.351[28]Возвращение Tiny BASICТом ПиттманН / Д (C )Нет данных

TBX также был известен как Texas Tiny BASIC.[29]

Обе СКЕЛБАЛ[30] и 6800 Tiny BASIC были анонсированы в журнале, но не опубликовали их исходный код.

Palo Alto Tiny BASIC

Palo Alto Tiny BASIC
РазработчикЛи Чен Ван
Впервые появился1976
ЛицензияВсеобщее достояние
Диалекты
3K Control Basic
Под влиянием
Tiny BASIC Design Note, Tiny BASIC Extended
Под влиянием
Astro BASIC, Уровень I BASIC, Sharp PC-1211 ОСНОВНОЙ

Одной из самых популярных из множества версий Tiny BASIC была Palo Alto Tiny BASIC, или сокращенно PATB. Ли-Чен Ван. PATB впервые появился в мае 1976 г. Доктор Доббс, написано на заказ язык ассемблера с нестандартной мнемоникой. Это привело к появлению дополнительных портов, которые работали с обычными сборщиками на 8080.[20] Первая версия интерпретатора занимала 1,77 килобайты памяти и предполагал использование Телетайп (TTY) для пользователя ввод, вывод. Ошибка в исходной статье появилась в июньском / июльском выпуске журнала Доктора Добба (Том 1, № 6). Эта статья также включала информацию о добавлении дополнительных устройств ввода-вывода с использованием кода для VDM отображение видео Процессорная технология В качестве примера.

Ван был одним из первых, кто употребил слово авторское лево. В уведомлении о распространении Palo Alto Tiny BASIC он написал: «@COPYLEFT, ВСЕ ОШИБКИ ЗАЩИЩЕНЫ».[31] Tiny BASIC не распространялся ни в какой формальной форме с условиями распространения авторского лева, но был представлен в контексте, когда исходный код распространялся и изменялся. Фактически, Ван ранее вносил правки в Tiny BASIC Extended, прежде чем написать свой собственный интерпретатор.[17] Он призвал других адаптировать его исходный код и публиковать свои адаптации, как в случае с версией PATB Роджера Раусколба, опубликованной в Возраст интерфейса.[1] Сам он опубликовал третью версию в Справочник PCC по персональным и домашним компьютерам.[32]

Одним из наиболее заметных изменений в PATB является добавление FOR ... NEXT цикл. В исходном TB петли могли быть реализованы только с использованием ЕСЛИ и ИДТИ К. Как в Microsoft BASIC, верхняя и нижняя границы цикла были установлены при входе в цикл и не изменились во время цикла, поэтому, если одна из границ была основана на выражении переменной, изменение переменной не привело к изменению границы. В ШАГ модификатор был необязательным, как в MS.[20]

Еще одним существенным изменением стала возможность размещать несколько операторов в одной строке. По не объясненным причинам PATB использовал точку с запятой ; для разделения операторов, а не уже общего двоеточия :.

Другие изменения включают добавление одного числового массива с именем переменной. @, ОСТАНОВКА в добавление к КОНЕЦ, и использование # для не равных в сравнении, в отличие от <>.[20][а]

PATB использовал слова для сообщений об ошибках вместо чисел. Чтобы уменьшить объем требуемой памяти, было всего три сообщения, и они состояли из отдельных слов. Система ответит КАКИЕ? для синтаксических ошибок, КАК? для ошибок времени выполнения, таких как переход к несуществующей строке или числовое переполнение, и ИЗВИНИТЕ для проблем нехватки памяти.[20]

Ван также написал ЗВЕЗДНЫЙ ПУТЬ в его Tiny BASIC, опубликованном в июльском выпуске журнала Информационный бюллетень народной компьютерной компании.[33][34]

Позже он адаптировал язык в 3K Control Basic для Cromemco, добавляя имена переменных в форме буква-цифра (например, A0 к Z9), логические функции (И(), ИЛИ ЖЕ(), XOR ()), а ВЫЗОВ команда для выполнения программ на машинном языке и др. РАСПЕЧАТАТЬ-параметры форматирования и др. (ПОЛУЧАТЬ() и ПОЛОЖИТЬ() вместо PEEK и POKE; Функции порта ввода / вывода).[35]

Palo Alto Tiny BASIC был адаптирован для многих других реализаций, включая Уровень I BASIC (1977), BASIC для Sharp PC-1211 карманный компьютер (1980), и Astro BASIC (1982, автор Джейми Фентон ).[36]

MINOL

Написанная учеником старшей школы, MINOL была единственной реализацией, которая не поддерживала полную версию Design Note, в ней отсутствовала приоритет оператора, имея только три повторения (<, =, #), исключая GOSUB и ВОЗВРАЩАТЬСЯ. Он поддерживает только 8-битную точность без знака (в отличие от 16-битной точности со знаком для любой другой реализации) и номера строк от 0 до 254.

Использование пробелов не допускается, кроме строк; ! возвращает случайное число, $ перед тем, как выражение загрузит строку по этому адресу; Операционные системы возвращается в операционную систему. Память была адресуемой, как если бы она была двумерным массивом старших и младших байтов (например, от «(0,0)» до «(255,255)»); ВЫЗОВ выполняет подпрограмму на машинном языке.[19]

Разные диалекты

Многие диалекты появились в различных других публикациях.

В майском выпуске 1977 года была представлена ​​дискета, содержащая MICRO-BASIC.

Вдохновленный призывом PCC к Tiny BASIC, Роберт Уитервик написал MICRO BASIC 1.3 для SWTPC6800 system), который SWTPC опубликовал в выпуске бюллетеня SWTPC за июнь 1976 года. Уитервик написал язык от руки на планшете. Позже он расширил язык до 4K, добавив поддержку плавающей запятой; эта реализация была уникальной среди интерпретаторов BASIC тем, что использовала Десятичное число с двоичным кодом с точностью до 9 цифр, с диапазоном до 10E99, и публикуется бесплатно как вкладыш журнала "Floppy ROM". Версия 8K добавила строковые переменные и тригонометрия функции. Обе версии 4K и 8K продавались SWTPC. В январе 1978 года Уитервик продал права на исходный код компании Motorola.[37][38]

Томас Ф. Вайтман написал Tiny BASIC в 1976 году для терминалов Hewlett-Packard HP-2640 и HP-2645 (в которых использовались процессоры Intel 8008 и 8080), который был опубликован в Журнал Hewlett-Packard.

Опубликовано в декабрьском выпуске 1976 г. Возраст интерфейса был LLL (Лаборатория Лоуренса Ливермора ) BASIC, первый черновик которого был разработан Стивом Лейнингером из спецификации Эллисон до ухода Лейнингера. National Semiconductor за Корпорация Тэнди. Окончательный интерпретатор был разработан Джоном Дикенсоном, Джерри Барбером и Джоном Титером в Университет Айдахо по контракту с LLL. Принимая 5K, он включал пакет с плавающей запятой, разработанный Дэвидом Мидом, Хэлом Брэндом и Фрэнком Олкеном. Программа была размещена в открытом доступе компанией LLL, которая разработала систему под эгидой США. Управление энергетических исследований и разработок.[39]

4K BASIC

Альтаир БАЗОВЫЙ, 4K BASIC, может работать в машине с 4 КБ RAM, оставляя только около 790 байт для программного кода.[40][41] Инициатива Tiny BASIC началась в ответ на плату в 150 долларов за Altair 4K BASIC.

В 1975 году Стив Возняк присоединился к недавно сформированной Домашний компьютерный клуб, в которую входили Ли-Чен Ван (Palo Alto Tiny BASIC) и Том Питтман (6800 Tiny BASIC). Возняк пришел к выводу, что его машина придется иметь собственный БЕЙСИК, который, надеюсь, станет первым для Технология MOS 6502 процессор. Поскольку языку требовалось 4 КБ ОЗУ, он сделал это минимальным объемом памяти для дизайна.[42] Целое число BASIC изначально был опубликован Компактная кассета в 1976 г.

В 1977 г. Radio Shack (как тогда называли) выпустили свой первый компьютер, TRS-80, а Z80 система с Уровень I BASIC в ПЗУ объемом 4 КБ. Тэнди - Сотрудник Стив Лейнингер написал первый проект переводчика NIBL ​​(National Industrial Basic Language) для SC / MP во время работы в National Semiconductor.[25] Не имея возможности взять с собой исходный код, он адаптировал Ли-Чен Ван Palo Alto Tiny BASIC для оригинального прототипа TRS-80 Model I. Он тщательно переработал интерпретатор, добавив поддержку операций с плавающей запятой, простую черно-белую графику и ЧТЕНИЕ / ДАННЫЕ / ВОССТАНОВЛЕНИЕ заявления.[43]

Первоначально разработан в 1979 году, Sinclair 4K BASIC, написанная Джоном Грантом, использовала в качестве определения языка 1978 г. Американский национальный институт стандартов (ANSI) Минимальный стандарт BASIC, но сам был неполной реализацией 4Kb только с целочисленной арифметикой.[44]

Диалекты микроконтроллера

Крошечные реализации BASIC были адаптированы для управления процессором и для микроконтроллеры такой как Ардуино:

  • Стивен А. Несс написал XYBASIC для компании Mark Williams в 1977 году, целочисленную реализацию 4K. Язык часто использовался для приложений управления процессами.[45]
  • Arduino BASIC - адаптирован из 68000 Tiny BASIC Гордона Брэндли, перенесен на C Майком Филдом.
  • Tiny Basic Plus - адаптировано из Arduino BASIC Скоттом Лоуренсом.[46]
  • Half-Byte Tiny Basic - адаптировано из Arduino BASIC.[47]
  • Tiny Basic на Micro: Bit - адаптировано из Palo Alto Tiny BASIC.[48]

Более поздние реализации

В 2002 году Эммануэль Шайю, Паскаль Манури и Бруно Пагано опубликовали Tiny BASIC (без GOSUB/ВОЗВРАЩАТЬСЯ) в Разработка приложений с помощью Objective Caml В качестве примера Цель Caml заявление.[49]

В 2013 году Alex Yang опубликовал реализацию в Python.[50]

В 2019 году Сергей Кузнецов опубликовал версию в Рубин.[51]

Сравнение диалектов

В следующей таблице сравниваются особенности языка реализаций Tiny BASIC с другими известными BASIC, которые им предшествовали.

Сравнение реализаций BASIC - Tiny BASIC и другие BASIC
Дата
Опубликовано
ДиалектПрограммист (ы)ПроцессорТипВХОДПОЗВОЛЯТЬРАСПЕЧАТАТЬИДТИ КЕСЛИ ... ТОGOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОКЧИСТОНОВЫЙREMFOR / NEXTЧТЕНИЕ / ДАННЫЕ / ВОССТАНОВЛЕНИЕДобавлены ОСНОВНЫЕ командыНастройкиВыраженияперевернутьФункцииRNDФункция памятиНомера строкРазделитель операторовОшибкиТочностьАрифметикаПеременныеМассивыСтруны
Октябрь,
1964
DTSS Dartmouth BASIC (версия 2)[52](Дартмутские студенты)GE-225Скомпилировать и начатьN / A [!]LET var = выражениеПЕЧАТЬ expr-list {, /; /}ПЕРЕЙТИ К номеруIF выражение relop выражение THEN номер строкиНомер GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОК - началоНОВИНКА [запрашивает название программы]REMFOR / TO / STEP / NEXTЧИТАТЬ, ДАННЫЕОСТАНОВКАНет данныхприоритет, ^< <= = >= > <>INT, SIN, COS, TAN, ATN, EXP, LOG, ABS, SQR, DEF FNRND (0) 0..11 до 99999Никто22 определены9 цифр± 999 999 999; База обозначений E 2 от -256 до +255 (E ± 76).А-Я, А0-Я9DIM (название из одной буквы, два измерения); если опущено, предполагается, что будет от 0 до 10; до 1500 элементов во всех массивахНикто
Февраль,
1970
DEC BASIC-8[53](Сотрудники ОИК)PDP-8Скомпилировать и начатьINPUT список переменныхLET var = выражениеПЕЧАТЬ expr-list {, /; /}ПЕРЕЙТИ К номеруIF выражение relop выражение [THEN / GO TO] номер строкиНомер GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОК (первый (, последний))НОВИНКА [запрашивает название программы]REMFOR / TO / STEP / NEXTЧТЕНИЕ, ДАННЫЕ, ВОССТАНОВЛЕНИЕОСТАНОВИТЬ, СТАРЫЙ, СОХРАНИТЬ, ОТМЕНИТЬУДАЛИТЬ (первый (, последний)), ПОКАприоритет, ^< <= = >= > <>INT, SGN, SIN, COS, TAN, ATN, EXP, LOG, ABS, SQR, DEF FNRND (0) 0..11 к 2045 г.Никто23 определены?± 134 217 727; 14E-38 А-Я, AA-Z9DIM (название из одной буквы, два размера)Никто
Июнь,
1974
UIUC BASIC[54]Альфред Уивер, Майкл Тиндалл, Рональд Дэниэлсон8008Устный переводчикINPUT <переменная> {, <переменная>} *LET var = формулаПЕЧАТЬ <строка> / <формула> {, <строка> / <формула>} *ПЕРЕЙТИ К номеруIF выражение THEN номер строкиНомер GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГне задокументированоне задокументированоне задокументированоREMFOR / TO / STEP / NEXTDEF FN, СТОПНет данныхприоритет, ^<<= => => # И ИЛИ НЕFNA..Z, SIN, COS, LOG, SQR, EXP, ATNОт 0 до 999Никтоне задокументировано4-байтовая мантисса и 1-байтовая экспонента [Datapoint 2200 арифметический пакет с плавающей запятой]не задокументированоА-Я, А0-Я9DIM (название из одной буквы, три измерения)Никто
1975
Альтаир 4K БАЗОВЫЙ[55]Билл Гейтс, Пол Аллен, Монте Давидофф8080Устный переводчикINPUT ("строка";) список-переменных(LET) var = выражениеПЕЧАТЬ expr-list {, /; }GOTO номерIF выражение THEN номер строки / операторНомер GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОК (начало)НОВЫЙREMFOR / TO / STEP / NEXTЧТЕНИЕ, ДАННЫЕ, ВОССТАНОВЛЕНИЕОСТАНОВКАприоритет< <= = >= > <>ABS, INT, SGN, SQR, TAB, USRRND (X) <0, новый с использованием X в качестве начального числа; = 0, повторить; > 0, далее1 до 65535:12 определены40-битный плавающий операнд??DIM (одно измерение)Никто
Декабрь,
1975
Примечание по дизайну[56]Деннис ЭллисонНет данныхУстный переводчикINPUT список переменныхLET var = выражениеПЕЧАТЬ expr-listGOTO выражениеIF выражение relop выражение THEN statementВыражение GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОК[экв. в NEW]приоритет< <= = >= > <> ><НиктоНиктоОт 1 до 255Никто8 определены16 бит± 32767А-ЯНиктоНикто
Февраль,
1976
Tiny BASIC Extended[57]Дик Уиппл и Джон Арнольд8080Устный переводчикВ(LET) var = выражение;}ИДТИ КIF выражение [no THEN] инструкцияПЕРЕЙТИRETКОНЕЦПРОБЕГLST (первый (, последний))НОВЫЙFOR-NXT (без ШАГА)DTA (массив LET)приоритет< <= = >= > <> ><TB () пробелы в печатиRN (случайный 0-10000)SZE1 до 65535$14 определены16 бит± 32767А-ЯDIM, 1- или 2-размерный, 255x255 макс.Никто
Марш,
1976
Денвер Tiny BASIC[58]Фред Гриб8080Устный переводчикВ(LET) var = выражение;}ИДТИ КIF выражение [no THEN] инструкцияGOSUBRETКОНЕЦПРОБЕГСПИСОК (первый последний)[экв. в NEW]ЛЕНТА [СОХРАНИТЬ], ЗАГРУЗИТЬCLRS [CLS]приоритет< <= = >= > <> ><RND (0), RND (1)РАЗМЕРОт 2 до 255:20 определены16 бит± 32767A – Z, от A1 до A6 до Z6DIM, 1 размерНикто
Марш,
1976
6800 Tiny BASIC[58]Том Питтман6800Устный переводчикINPUT (выражение) список переменныхLET var = выражениеПЕЧАТЬ expr-list {, /; }GOTO выражениеIF выражение relop выражение THEN statementВыражение GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОК (первый последний)[экв. в NEW]REMприоритет< <= = >= > <> ><USR ()RND ()1 до 65535Никто53 определены16 бит± 32767А-ЯНиктоНикто
Апреля,
1976
MINOL[59]Эрик Т. Мюллер8080Устный переводчикВ(LET) var = выражениеPR expr-list {;}[GOTO 0 возвращается к началу прямой инструкции]IF выражение relop expression; утверждениеНет данныхНет данныхКОНЕЦПРОБЕГСПИСОКCLEAR [только переменные]НОВЫЙИспользование пробелов не допускается, кроме строкНет приоритета оператора< = #$ [CHR $]! [RND]От 1 до 254:6 определены8 битОт 0 до 255А-Я(H, L) ячейка памятиодиночный символ
Май,
1976
Palo Alto Tiny BASIC[60]Ли-Чен Ван8080Устный переводчикINPUT [(выражение) var] *(LET) var = выражениеПЕЧАТЬ expr-listGOTO выражениеIF выражение [no THEN] инструкцияВыражение GOSUBВОЗВРАЩАТЬСЯОСТАНОВКАПРОБЕГСПИСОК (начало)НОВЫЙREMFOR / TO / STEP / NEXTОСТАНОВКАприоритет< <= = >= > #АБС ()RND ()РАЗМЕР1 к 32767;3 определены16 бит± 32767А-Я@ (1 массив из 1 измерения)Никто
Ноябрь,
1976
НИБЛ[61]Марк Александр и Стив ЛейнингерSC / MPУстный переводчикINPUT ($) var(LET) var = выражениеPR / PRINT expr-listGOTO выражениеIF выражение (THEN) инструкцияВыражение GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОК (начало)ОЧИСТИТЬ [переменные и стек]НОВЫЙREMFOR / TO / STEP / NEXTДЕЛАТЬ / ДОАдресация памяти (@ [PEEK / POKE], STAT, PAGE)приоритет< <= = >= > <>МОД (), И, ИЛИ, НЕ,RND (A, Z)ВЕРХОт 0 до 32767:13 четырехзначных символов16 бит± 32767А-Яадресация памятиINPUT $, PRINT $, $ exp = exp
Август,
1977
Уровень I BASIC[62]Стив ЛейнингерZ80Устный переводчикINPUT (#digit) [(выражение) var] *(LET) var = выражениеПЕЧАТЬ (# цифра) список-выраженийGOTO номерIF выражение THEN выражениеНомер GOSUBВОЗВРАЩАТЬСЯКОНЕЦRUN (начало)СПИСОК (начало)НОВЫЙREMFOR / TO / STEP / NEXTЧТЕНИЕ, ДАННЫЕ, ВОССТАНОВЛЕНИЕSTOP, CONT, ON-GOTO / GOSUBCLOAD, CSAVE, CLS, SET, СБРОС,приоритет< <= = >= > <> ><ABS (), INT (), MEM, ТОЧКА (X, Y)RND ()MEM1 к 32767:3 определены16 бит± 32767А-ЯA (1 массив 1 измерения)A $, B $
Июнь,
1976
МИКРО БАЗОВЫЙ 1.3[63]Роберт Уитервик6800Устный переводчикINPUT список переменных(LET) var = выражениеПЕЧАТЬ expr-list {, /; }GOTO выражениеIF выражение relop выражение THEN statementВыражение GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОК (первый (, последний))НОВЫЙFOR / TO / NEXT (без ШАГА)TAB ()приоритет< <= = >= > <> ><RND, РАЗМЕРRND [возвращает 1-32762]SIZE (инструкция, которая печатает использованные байты и свободные байты)1 до 65535Никто17 определены16 бит [более поздний BCD!]± 32767А-ЯDIM (два измерения, максимальный размер 255)Никто
Июнь,
1976
SC Scientific Элементарный базовый язык (SCELBAL)[64]Марк Арнольд и Нат Уодсворт8008Устный переводчикINPUT список переменных(LET) var = выражениеПЕЧАТЬ expr-list {, /; /}GOTO номерТО заявлениеНомер GOSUBВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОКЦарапать]REMFOR / TO / STEP / NEXTСОХРАНИТЬ ЗАГРУЗИТЬUDF [USR]приоритет, ^< <= = >= > <>INT, SGN, ABS, SQR, CHR [используется только в PRINT], TABRND (0) 0..11 до 999999Никто18 определены32-битный операнд с плавающей или фиксированной точкой± 134 217 727; 14E-38 ?DIM (одно буквенное имя, одно измерение; до 4 массивов до 64 записей всего)Никто
Октябрь,
1976
Apple I BASIC[65]Стив Возняк6502Устный переводчикINPUT ("строка";) список-переменных(LET) var = выражениеПЕЧАТЬ expr-list {, /; }GOTO выражениеIF выражение relop expression THEN номер строки / операторВыражение GOSUBВОЗВРАЩАТЬСЯКОНЕЦRUN (начало)СПИСОК (первый (, последний))SCRREMFOR / TO / STEP / NEXTАВТО, УДАЛЕНИЕ, ТОЧКАTAB (команда), ВЫЗОВприоритет<<= => => <> # И ИЛИ НЕ МОДИФИКАЦИЯSGN, ABS, PEEK (), LEN ()RND (X) 0..X (или X..0!)ХИМЕМ, ЛОМЕМ1 к 32767Нет [ранняя версия, то:]16 определены16 бит± 32767A-Z, за которыми следует любое количество буквенно-цифровыхDIM (одно измерение)размерный
Декабрь,
1976
LLL BASIC[66](Сотрудники Университета Айдахо)8080Устный переводчикINPUT список переменных(LET) var = выражениеПЕЧАТЬ expr-list {, /;}ПЕРЕЙТИ К номеруIF выражение выражение relop выражение (THEN) операторGO SUB номерВОЗВРАЩАТЬСЯКОНЕЦПРОБЕГСПИСОКSCRREMFOR / TO / NEXT (без ШАГА)ОСТАНОВКАВЫЗОВ, ПОЛУЧИТЬ (), ПОЛУЧИТЬ ()приоритет< <= = >= > <> ><Нет RND?От 0 до 32767:14 определены32-битный операнд с плавающей запятой?А-Я, А0-Я9DIM (только целые числа, одно буквенное имя, одно измерение, максимальный размер 255)Никто

Смотрите также

Примечания

  1. ^ Хеш также использовался для неравных в БАЗОВЫЙ HP с разделением времени.

Рекомендации

  1. ^ а б c Раусколб, Роджер (декабрь 1976 г.). "Пало-Альто Крошечный БЕЙСИК доктора Ванга". Возраст интерфейса. 2 (1): 92–108. Исходный код начинается со следующих девяти строк:
    ; ******************************** ;; МАЛЕНЬКАЯ ОСНОВА ДЛЯ INTEL 8080; ВЕРСИЯ 2.0; ЛИ-ЧЕН ВАНГ; ИЗМЕНЕНЫ И ПЕРЕВЕДЕНЫ; В INTEL MNEMONICS; BY ROGER RAUSKOLB; 10 OCTOBER,1976; @COPYLEFT; ALL WRONGS RESERVED;;*********************************
  2. ^ Allison, Dennis (July 1976). "Design notes for TINY BASIC". Уведомления SIGPLAN. ACM. 11 (7): 25–33. Дои:10.1145/987491.987494. В ACM Special Interest Group on Programming Languages (SIGPLAN) reprinted the Tiny Basic design notes from the January 1976 Tiny BASIC Journal.
  3. ^ а б "TB Code Sheet". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (1). Декабрь 1975 г.
  4. ^ A BASIC Language Interpreter for the Intel 8008 Microprocessor. Department of Computer Science, University of Illinois at Urbana-Champaign (published 1974). June 1974.
  5. ^ "Open hardware: How and why it works". The open software movement was founded by Dennis Allison in his release of Tiny BASIC in 1975
  6. ^ а б Warren, Jim C. (July 1976). "Correspondence". Уведомления SIGPLAN. ACM. 11 (7): 1–2. ISSN  0362-1340.
  7. ^ Wang, Li-Chen (Май 1976 г.). "Palo Alto Tiny BASIC". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (5): 12–25. Source code begins with the following six lines.
    TINY BASIC FOR INTEL 8080VERSION 1.0BY LI-CHEN WANG10 JUNE, 1976@COPYLEFTALL WRONGS RESERVED
    The June date in the May issue is correct. The magazine was behind schedule, the June and July issues were combined to catch up.
  8. ^ Allison, Dennis (1976). "Build Your Own BASIC". Журнал доктора Добба. Vol. 1 шт. 1. п. 9.
  9. ^ Allison, Dennis (1976). "Quick Reference Guide for Tiny BASIC". Журнал доктора Добба. Vol. 1 шт. 1. п. 6.
  10. ^ Руководство по языку BASIC-PLUS (PDF). Мейнард, Массачусетс: Digital Equipment Corporation. 1972. pp. 3–13.
  11. ^ Allen, Dennis. "TINY BASIC". Народная компьютерная компания. 4 (3).
  12. ^ Veit, Holger. "Tom Pittman's 6800 tiny BASIC". Получено 2 мая 2017.
  13. ^ Журнал доктора Добба, Volume 1, Number 1, 1976, p. 12.
  14. ^ В CRLF there symbolizes a carriage return followed by a перевод строки.
  15. ^ Pittman, Tom. "Tiny BASIC Experimenter's Kit". Получено 9 августа, 2020.
  16. ^ (PDF) https://archive.computerhistory.org/resources/access/text/2015/02/102740021-05-14-acc.pdf. Получено 13 августа 2020. Отсутствует или пусто | название = (помощь)
  17. ^ а б c "Tiny BASIC Extended". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (2). February 1976.
  18. ^ а б "Denver Tiny BASIC". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (3). Март 1976 г.
  19. ^ а б c "MINOL". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (4). Апрель 1976 г.
  20. ^ а б c d е Rauskolb, Roger (December 1976). "Dr. Wang's Palo Alto Tiny BASIC" (PDF). Возраст интерфейса. pp. 92–108.
  21. ^ "Design Note". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (1). Декабрь 1975 г.
  22. ^ "6800 Tiny BASIC". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (3). Март 1976 г.
  23. ^ "TINY BASIC User Manual+".
  24. ^ Wang, Li-Chen (Май 1976 г.). "Palo Alto Tiny BASIC". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (5): 12–25.
  25. ^ а б "NIBL". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (10). Ноябрь 1976 г.
  26. ^ "Enhanced & Modified 6800 Tiny BASIC". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. October 1980.
  27. ^ "TBI68K". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. February 1985.
  28. ^ "Return of Tiny BASIC". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. Январь 2006 г.
  29. ^ "Texas Tiny BASIC (TBX) Marries TV-Cassette Operating System (TVCOS)". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (5): 28–31. Май 1976 г.
  30. ^ Arnold, Mark; Wadsworth, Nat (February 1976). "SCELBAL - A Higher Level Language for 8008/8080 Systems". Журнал доктора Добба. С. 30–53.
  31. ^ Wang, Li-Chen (Май 1976 г.). "Palo Alto Tiny BASIC". Dr. Dobb's Journal of Computer Calisthenics & Orthodontia, Running Light Without Overbyte. 1 (5): 12–25. (NB. Source code begins with the following six lines. "TINY BASIC FOR INTEL 8080; VERSION 1.0; BY LI-CHEN WANG; 10 JUNE, 1976; @COPYLEFT; ALL WRONGS RESERVED". The June date in the May issue is correct. The magazine was behind schedule, the June and July issues were combined to catch up.)
  32. ^ McCabe, Dwight [editor] (July 1, 1977). PCC's Reference Book of Personal and Home Computing (1-е изд.). Menlo Park, CA: People's Computer Company. п. 248. ISBN  0-918790-02-6.CS1 maint: дополнительный текст: список авторов (связь)
  33. ^ "People's Computer Company" (PDF). Получено 25 декабря 2019.
  34. ^ Turnbull, Pete. "Startrek.asc". Получено 25 декабря 2019.
  35. ^ «Базовое руководство по эксплуатации 3K Control» (PDF). Cromemco. Архивировано из оригинал (PDF) в 2013-12-22. Получено 2013-02-18.
  36. ^ Эйнсворт, Дик (1982). Astro BASIC. Astrocade, Inc. стр. 3.
  37. ^ "Robert Uiterwyk's BASIC".
  38. ^ "Robert Uiterwyk's Micro Basic".
  39. ^ "Part 1 Of LLL 8080 BASIC Interpreter" (PDF).
  40. ^ "4 Altair Language Systems". Altair BASIC.
  41. ^ Altair BASIC (PDF). MITS. 25 August 1975.
  42. ^ Wozniak, Steven (1 May 2014). "How Steve Wozniak Wrote BASIC for the Original Apple From Scratch". Gizmodo.CS1 maint: ref = harv (связь)
  43. ^ Welsh, David; Welsh, Theresa (2007). Priming the Pump: How TRS-80 Enthusiasts Helped Spark the PC Revolution. п. 7.
  44. ^ "ZX80 – 8K BASIC ROM UPGRADE".
  45. ^ Ness, Stephen. "XYBASIC". Ness Software. Получено 4 августа 2020.
  46. ^ "TinyBasicPlus".
  47. ^ "It's here! Half-Byte Tiny Basic 2 for Arduino and compatibles".
  48. ^ "Running Tiny Basic on the Micro: Bit".
  49. ^ Chailloux, Emmanuel; Manoury, Pascal; Pagano, Bruno (2002). Developing Applications with Objective Caml. France: O'Reilly. ISBN  2841771210.
  50. ^ "aleozlx/tinybasic". Получено 2020-09-20.
  51. ^ "PaloAltoTinyBasic". Получено 2020-09-20.
  52. ^ "BASIC" (PDF).
  53. ^ "TSS/8 TIME-SHARING SYSTEM USER'S GUIDE" (PDF).
  54. ^ "A BASIC LANGUAGE INTERPRETER FOR THE INTEL 8008 MICROPROCESSOR" (PDF).
  55. ^ "MITS ALTAIR BASIC REFERENCE MANUAL" (PDF).
  56. ^ "Dr. Dobb's Journal of Computer Calisthenics and Orthodontia: Running Light Without Overbyte" (PDF).
  57. ^ "Dr. Dobb's Journal of Computer Calisthenics and Orthodontia: Running Light Without Overbyte" (PDF).
  58. ^ а б "Dr. Dobb's Journal of Computer Calisthenics and Orthodontia: Running Light Without Overbyte" (PDF).
  59. ^ "Dr. Dobb's Journal of Computer Calisthenics and Orthodontia: Running Light Without Overbyte".
  60. ^ «Возраст интерфейса».
  61. ^ "Dr. Dobb's Journal of Computer Calisthenics and Orthodontia: Running Light Without Overbyte" (PDF).
  62. ^ "Help for TRS-80 Level I BASIC".
  63. ^ "Robert Uiterwyk's MICRO BASIC".
  64. ^ "SCELBAL - A HIGHER LEVEL LANGUAGE FOR 8008/8080 SYSTEMS" (PDF).
  65. ^ "PRELIMINARY APPLE BASIC USERS MANUAL" (PDF).
  66. ^ «Возраст интерфейса» (PDF).

внешняя ссылка