NAR 1 - NAR 1

NAR 1 немесе жай NAR (Серб Naставни Rачунар, kk Оқу компьютері) математика факультеті құрған компьютердің теориялық моделі болды Белград университеті профессор Неделько Парезанович (Серб тілінде: Недељко Парезановић). Ол үшін қолданылған Ассамблея тілі және Компьютер архитектурасы курстар.

Техникалық сипаттамалары

NAR 1 процессор 5-бит мекен-жайы бар автобус (32 байт және 8-биттік адрестік жады) деректер шинасы. Машина нұсқаулық үш байт байт болды ең маңызды биттер көрсету опкод және 5 ең аз бит параметр - жад мекен-жайы. Жалғыз 8 биттік аккумуляторлық регистр қол жетімді болды және жоқ жалаулар немесе жалауша регистрлері. Тек абсолютті мекен-жай режимі қол жетімді болды, ал басқаларына қол жеткізілді өзін-өзі өзгертетін код.

Бұл тек теориялық компьютер болса да, келесі физикалық сипаттамалар берілген:

  • Жад циклі: 1 мкв
  • Арифметикалық операция (SABF) циклі: 0,9μs (900ns)
  • Басқару тақтасы қуатты қосуды және өшіруді, жад деректерін енгізу мен оқуды, нұсқаулықтың есептегішін енгізуді және бағдарламаның орындалу режимін немесе басқару тақтасының режимін таңдауды жеңілдетеді.

Нұсқаулықтың кодталуы және жиынтығы

  • SABF (001ааааа, сер. Сабeri u Fиксном зарезу, kk Added Fixed point) мекен-жай параметрімен көрсетілген жадының орналасу мазмұнын жүктейді, оны аккумулятордың ағымдағы мәніне қосады және нәтижені аккумуляторға сақтайды
  • PZAF (010ххххх, сер. Pромени Знақ Akumulatora u Fиксном зарезу, kk Аккумулятордың белгісін қозғалмайтын нүктеде өзгерту) Аккумулятордағы бекітілген нүкте (бүтін сан сияқты) мәнін теріске шығарады
  • AUM (011аааааа, сер. Aкумулятор U Мэмориу, kk Аккумулятор Into Memory) аккумулятордың мазмұнын мекен-жай параметрімен белгіленген жад орнына сақтайды
  • MUA (100ааааа, сер. Мэмория U Aкумулятор, kk Memory Into Accumulator) мекен-жай параметрімен көрсетілген жадтың орналасу мазмұнын аккумуляторға жүктейді
  • NES (101ааааа, сер. Негативни Sкөк, kk Жағымсыз секіру) орындайды а шартты секіру егер аккумулятордың ағымдағы мәні теріс болса, параметрмен көрсетілген адреске
  • ZAR (110ххххх, сер. Заустави Računar, kk Компьютерді тоқтату) одан әрі өңдеуді тоқтатады.

Тағы екі нұсқаулық көрсетілмеген, бірақ көбінесе тренажерларда болатын және 000aaaaa және 111aaaaa нұсқау кодтарын алды:

  • BES (сер. Болуызусловни Sкөк, kk Сөзсіз секіру) орындайды сөзсіз секіру параметрмен көрсетілген мекен-жайға
  • NUS (сер. Жоқла-Sкөк, kk Zero Jump) орындайды а шартты секіру параметрімен көрсетілген адреске, егер аккумулятордың ағымдағы мәні нөлге тең болса

Бағдарламалардың мысалы

8 биттік бүтін сандар жиынын шығаратын бағдарлама үлгісі:

00:     0         ; кіріс: 0 немесе мән 22, шығу: нәтиже01..21: 0,0,0...  ; кіріс: мәндер 1..2122:     MUA  0    ; Бағдарламаның басталуы; Аккумуляторды 0 мекенжайдан жүктеңіз23:     SABF 1    ; Аккумуляторға 1-мекен-жайдан мән қосыңыз24:     AUM  0    ; Аккумуляторды 0 мекен-жайы бойынша сақтаңыз25:     MUA  23   ; Нұсқаулықты 23 мекен-жай бойынша жүктеу (SABF)26:     SABF 31   ; 31 (+1) мекен-жайынан аккумуляторға мән қосыңыз27:     AUM  23   ; Аккумуляторды 23 мекен-жайға дейін сақтаңыз (SABF нұсқауын өзгертеді)28:     SABF 30   ; Аккумуляторға 30 мекен-жайдан құндылық қосыңыз29:     NES  22   ; Егер аккумулятор мәні теріс болса, 22-ге оралыңыз30:     ZAR  10   ; Компьютерді тоқтатыңыз. Аргумент бұл байтты - (SABF 22) = -54 мәніне ие етеді.31:     1         ; Әр итерацияда адреске қосылатын мән

Жоғарыда аталған бағдарлама 22 мекен-жай бойынша орындалатын болса, 22-ге дейін 8-биттік мәндерді қосады:

  • 1-21 мәндері 1-21 орындарында сақталады
  • 22 мәні 0 тұрақты орнында емес, 0 орнында сақталады және нәтижемен ауыстырылады

NAR 1 бағдарламалары әдетте өзін-өзі өзгертеді. Кейбір басқа архитектуралардан айырмашылығы, бұл «қулық» емес. Жадты регистр арқылы шешуге болмайтындықтан, жад деректерін динамикалық басқарудың жалғыз әдісі - жадымен манипуляциялау нұсқауларын өзгерту. Жоғарыда мысалда жадыны үнемдеуге арналған әдеттегі қулық бар - нұсқаулық (30 мекен-жай бойынша) басқа нұсқаулықпен (28 мекен-жай бойынша) деректер ретінде қайта пайдаланылады.

Егер аккумулятордың бастапқы мәнін басқару тақтасынан басқаруға болатын болса, онда 23-ші мәнді сақтауға болады. Жоғарыда аталған бағдарламаны сәл ғана өзгерту керек - 23 мекен-жайдағы SABF 1 нұсқауын SABF 0-ге өзгерту керек және бағдарламаны 22-ден емес, осы мекен-жайдан (23) орындау керек.

Келесі мысалда көрсетілгендей нұсқаулар өзгертілгеннен кейін белгінің өзгеруін қолданудың басқа амалдары да болды:

00..21: 0,0,0...  ; кіріс мәндері 22-ден 1-ге дейін22:     0         ; кіріс: 0 немесе мән 23, шығу: нәтиже23:     MUA  21   ; бағдарламаның басталуы; Мәнді жүктеу (келесі)24:     SABF 22   ; Аккумуляторға 22-дегі қосынды қосыңыз25:     AUM  22   ; Жаңа жиынтықты 22-ге дейін сақтаңыз26:     MUA  23   ; Нұсқаулықты 23 аккумуляторға салыңыз27:     SABF 31   ; Төмендету туралы нұсқаулық 128:     AUM  23   ; Нұсқаулықты жаңартыңыз29:     NES  23   ; Нұсқаулық әлі де теріс болса, қайталаңыз30:     ZAR       ; Әйтпесе, компьютерді тоқтатыңыз31:     -1        ; 27-де нұсқаулық үшін үнемі қажет

Мұнда 23 мекен-жайдағы «MUA 21» нұсқауында 10010101 екілік мәні бар, ол таңбалы бүтін сан ретінде қабылданғанда -107 ондық болып табылады екеуінің толықтауышы. 26, 27 және 28 мекен-жайларындағы нұсқаулар әр қайталанған сайын осы мәнді 1-ге азайтады. Бұл адресті көрсететін ең аз 5 битті өзгертеді және нұсқаулық MUA 0 болғанға дейін нұсқауды көрсететін үш битке әсер етпейді (10000000 екілік = -128 ондық, теріс). Бір рет азайтылғаннан кейін ол 01111111 (+127 ондық) болады, ол бұдан былай теріс болмайды және 29-да «компьютерді тоқтату» үшін 29-да секіру-if-теріс командаларының өтуіне әкеледі.

Жоғарыда айтылғандай, бұл бағдарлама 22-ден 24-ке дейінгі мәндерді қоса алады, бұл 22 мекен-жайы кіріс және шығыс үшін пайдаланыла алатындығына және аккумулятордың бастапқы мәні кіріс ретінде қолданыла алатындығына байланысты (содан кейін бағдарлама 24 мекен-жайынан орындалуы керек) 23-тегі нұсқаулық MUA 22 болуы керек).

Егер белгілі бір іске асыру компьютерді тоқтатады, егер ол белгісіз опкодқа тап болса немесе «111aaaaa» opcode бар қосымша сөзсіз секіру нұсқауын орындайтын болса, онда мұндай әрекетті келесідей қолдануға болады:

00..22: 0,0,0...  ; 23-тен 1-ге дейінгі мәндер23:     0         ; кіріс: 0 немесе мән 24, шығыс: нәтиже24:     MUA  22   ; бағдарламаның басталуы; Мәнді жүктеу (келесі)25:     SABF 23   ; Аккумуляторға 23-ке аралық қосыңыз26:     AUM  23   ; Жаңа жиынтықты 23-ке дейін сақтаңыз27:     MUA  24   ; 24 нұсқаулықты аккумуляторға салыңыз28:     SABF 31   ; Төмендету туралы нұсқаулық 129:     AUM  24   ; Нұсқаулықты жаңартыңыз30:     NES  24   ; Нұсқаулық әлі де теріс болса, қайталаңыз31:     -1        ; BES 31 немесе жарамсыз нұсқаулық және 28-ге нұсқау үшін тұрақты

Жоғарыда, 31-мекен-жайдан табылған «-1» мәні компьютердің тоқтауына әкелетін жарамсыз нұсқаулық немесе сол мекен-жайға сөзсіз секіру (BES 31) ретінде қарастырылуы мүмкін, нәтижесінде нәтижеге әсер етпейтін шексіз цикл пайда болады (басқару оны көрсету үшін панельді пайдалануға болады).

Сонымен, егер компьютер жадының соңына жетсе, бағдарламаның орындалуын тоқтатады (31 мекен-жайы, 0 мекен-жайына оралмайды) деген шешімге байланысты, жоғарыда келтірілген бағдарламаны қажет етпеу арқылы тағы бір мән алу үшін қайта құруға болады. «компьютерді тоқтату» нұсқаулығы келесідей:

00..22: 0,0,0...  ; 23-тен 1-ге дейінгі мәндер23:     0         ; кіріс: 0 немесе мән 24, шығыс: нәтиже24:     -1        ; 29-да нұсқаулық үшін үнемі қажет25:     MUA  22   ; бағдарламаның басталуы; Мәнді жүктеу (келесі)26:     SABF 23   ; Аккумуляторға 23-ке аралық қосыңыз27:     AUM  23   ; Жаңа жиынтықты 23-ке дейін сақтаңыз28:     MUA  25   ; Нұсқаулықты 25 аккумуляторға салыңыз29:     SABF 24   ; Төмендету туралы нұсқаулық 130:     AUM  25   ; Нұсқаулықты жаңартыңыз31:     NES  25   ; Нұсқаулық әлі де теріс болса, қайталаңыз; ------------- жадының аяқталуы

Ұсақ-түйек

  • «Нар» сөзі білдіреді Компьютерлік модельді оқыту
  • Көптеген NAR 1 тренажерлері жасалды. Біреуі «Шлива» деп аталды (kk алхоры ) сол жеміс өседі Сербия, ал «нар» жоқ.
  • Жиі берілген тапсырмалардың бірі - бағдарламамен бірге 32 байтты жадыда сақталатын мүмкіндігінше көп сандарды қосатын бағдарлама құру.
  • Ассемблер тілінің кейбір хаттамалары NAR1 хулил кодынан алынған

Сондай-ақ қараңыз

Проф. Доктор Неделько Парезанович (серб тілінде)