



# 00 informatica 4

# SISTEM ZA ŠALTERSKO POSLOVANJE V BANKAH IN NA POŠTAH



®  
**računalniški sistemi delta**

Sistem za šaltersko poslovanje je sodobna računalniška oprema za delo v bankah in na poštah, opremljen z ustreznim programskim opremom.

Sistem omogoča samostojno ažurno poslovanje – od posameznih operativnih del na šalterjih do zajema podatkov za nadaljnjo obdelavo. Deluje lahko povsem samostojno ali v povezavi z glavnim računalnikom (prenos informacij je mogoč prek stalno najetih ali navadnih telefonskih linij). Delovanje sistema tudi ni odvisno od razpoložljivosti računalniških kapacetov glavnega računalnika.

Sistem nadomešča raznovrstno opremo, ki se uporablja pri šalterskem poslovanju – od klasičnih mehanografskih strojev, pisalnih strojev do kalkulatorjev in deloma mikročitalnikov.

Sistem za šaltersko poslovanje je savremena računarska oprema za rad u bankama i poštama, opremljen sa odgovarajućom programskom opremom.

Sistem omogućava samostalno ažurno poslovanje – od pojedinih operativnih poslova na šalterima do zahvata podataka za dalju obradu. Može da radi sasvim samostalno, ili da komunicira sa glavnim računarom (prenos informacija je moguć preko stalno iznajmljenih ili običnih telefonskih linija). Rad sistema je takođe nezavisan od raspoložljivosti računarskih kapaciteta glavnog računara.

Sistem zamjenjuje raznovrstnu opremu, koja se upotrebljava u šalterskom poslovanju – od klasičnih mehanografskih mašina, pisalih mašina do kalkulatora i delimično čitača mikrofiševa.

# informatica

Časopis izdaja Slovensko društvo Informatika,  
61000 Ljubljana, Parmova 41, Jugoslavija

## Uredniški odbor:

T. Aleksić, Beograd; D. Bitrakov, Skopje; P. Dragojlović, Rijeka; S. Hodžar, Ljubljana; B. Horvat, Maribor; A. Mandžić, Sarajevo; S. Mihalić, Varaždin; S. Turk, Zagreb

Glavni in odgovorni urednik:  
prof. dr. Anton P. Železnikar

## Tehnični urednik :

dr. Rudolf Murn

## Založniški svet:

T. Banovac, Zavod SR Slovenije za statistiko,  
Vožarski pot 12, 61000 Ljubljana;  
A. Jerman-Blažič, DO Iskra Delta, Parmova 41,  
61000 Ljubljana;  
B. Klemenčič, Iskra Telematika, 64000 Kranj;  
S. Saksida, Institut za sociologijo Univerze  
Edvarda Kardelja, 61000 Ljubljana;  
J. Virant, Fakulteta za elektrotehniko, Tržaška  
25, 61000 Ljubljana.

## Uredništvo in uprava:

Informatika, Parmova 41, 61000 Ljubljana,  
telefon (061) 312 988; telex 31366 YU Delta.

Letna naročnina za delovne organizacije znaša  
5900 din, za zasebne naročnike 1590 din, za  
študente 490 din; posamezna številka 2000 din.

Številka širo računa: 50101-678-51841

Pri financiranju časopisa sodeluje Raziskovalna  
skupnost Slovenije

Na podlagi mnenja Republiškega komiteja za  
informiranje št. 23-85, z dne 29. 1. 1986, je  
časopis oproščen temeljnega davka od prometa  
proizvodov.

Tisk: Tiskarna Kresija, Ljubljana

Grafična oprema: Rasto Kirn

## ČASOPIS ZA TEHNOLOGIJO RAČUNALNIŠTVA IN PROBLEME INFORMATIKE ČASOPIS ZA RAČUNARSKU TEHNOLOGIJU I PROBLEME INFORMATIKE SPISANIE ZA TEHNOLOGIJA NA SMETANJETO I PROBLEMI OD OBLASTA NA INFORMATIKATA

YU ISSN 0350-5596

## LETNIK 10, 1986 - ŠT. 4

### V S E B I N A

|                                            |    |                                                                                         |
|--------------------------------------------|----|-----------------------------------------------------------------------------------------|
| M. Radovan                                 | 3  | Logika i procesiranje znanja                                                            |
| B. Robič<br>J. Silc                        | 18 | Razvrstitev novogeneracijskih računalniških arhitektur                                  |
| M. Jenko<br>A. Vodopivec                   | 33 | Možnosti, ki jih ponuja mikroelektronika sistemskim načrtovalcem                        |
| S. Mavrič<br>B. Mihočilović<br>P. Kolbezen | 44 | Povezovalna mreže večprocesorskih sistemov                                              |
| A. Novak                                   | 51 | Ladijski informacijski sistem in računalniško tovorjenje ladij                          |
| N. Pavešić<br>S. Ribarič                   | 60 | Paralelni sustav za razpoznavanje znakova                                               |
| J. J. Dujmović<br>M. Levnaić               | 68 | PLOT5 - Jedan jednostavni programski sistem za grafičke terminalne i koordinatne crtače |
| J. Silc<br>B. Robič                        | 74 | Procesor s podatkovno pretočkovno arhitekturo                                           |
| B. Mihočilović<br>S. Mavrič<br>P. Kolbezen | 81 | Transputer - osnovni gradnik večprocesorskih sistemov                                   |
| I. Tvrđy                                   | 85 | Okolje novih telematskih storitev in ISDN                                               |
| S. Prešern                                 | 98 | Advanced Microprocessors... (Poročilo)                                                  |
|                                            | 97 | Pisma bralcev                                                                           |

# INFORMATIKA

Published by Informatika, Slovene Society for Informatics, Parmova 41, 61000 Ljubljana, Yugoslavia

## JOURNAL OF COMPUTING AND INFORMATICS

### Editorial Board

T. Aleksić, Beograd; D. Bitrakov, Skopje; P. Dragojlović, Rijeka; S. Hodžar, Ljubljana; B. Horvat, Maribor; A. Mandžić, Sarajevo; S. Mihalić, Varaždin; S. Turk, Zagreb

YU ISSN 0350-5596

Editor-in-Chief :  
Prof. Dr. Anton P. Zeleznikar

VOLUME 10, 1986 - No. 4

### Executive Editor :

Dr. Rudolf Hurn

### CONTENTS

Publishing Council:  
T. Banovec, Zavod SR Slovenije za statistiko, Vojašarski pot 12, 61000 Ljubljana;  
A. Jerman-Blažič, DO Iskra Delta, Parmova 41, 61000 Ljubljana;  
B. Klementič, Iskra Telematika, 64000 Kranj;  
S. Saksida, Institut za sociologijo Univerze Edvarda Kardelja, 61000 Ljubljana  
J. Virant, Fakulteta za elektrotehniko, Tržaška 25, 61000 Ljubljana.

### Headquarters:

Informatika, Parmova 41, 61000 Ljubljana, Yugoslavia. Phone: 61 31 29 88. Telex: 31366 yu delta

Annual Subscription Rate: US\$ 22 for companies, and US\$ 10 for individuals

Opinions expressed in the contributions are not necessarily shared by the Editorial Board

Printed by: Tiskarna Kresija, Ljubljana

Design: Rasto Kirn

|                |                                                                 |
|----------------|-----------------------------------------------------------------|
| M. Radovan     | 3 Logic and Knowledge Processing                                |
| B. Robič       | 18 Classification of New Generation Computer Architectures      |
| J. Šilc        |                                                                 |
| M. Jenko       | 33 Possibilities Offered to Microelectronic System Designer     |
| A. Vodopivec   |                                                                 |
| S. Mavrič      | 44 The Interconnection Network in a Multiprocessor System       |
| B. Mihovilović |                                                                 |
| P. Kolbezen    |                                                                 |
| A. Novak       | 51 Ship's Information System and Loading by Computer            |
| N. Pavešić     | 68 The Parallel Character Recognition System                    |
| S. Ribarić     |                                                                 |
| J. J. Dujmović | 74 PLOTS - A Simple Software for Graphic Terminals and Plotters |
| M. Levnajč     |                                                                 |
| J. Šilc        | 74 Data Flow Architecture Based Processor                       |
| B. Robič       |                                                                 |
| B. Mihovilović | 81 Transputer - The Basic Component of Multiprocessor Systems   |
| S. Mavrič      |                                                                 |
| P. Kolbezen    |                                                                 |
| I. Tvrđy       | 85 New Telematic Services Environment and ISDN                  |
| S. Prešern     | 98 Advanced Microprocessors... (A Review)                       |
|                |                                                                 |
|                | 97 Letters                                                      |

UDK 001:681.3.04

Mario Radovan  
Sveučilište Rijeka, SET Pula  
Univerza Ljubljana, IJS Ljubljana

U članku je data analiza mogućnosti koje logika pruža u okviru problematike predstavljanja i procesiranja znanja. Rezultati su sabrani u cijelovit prijedlog modela logičke baze znanja, koji je definiran u terminima logike i realiziran sredstvima logičkog programiranja. U kontekstu predloženog modela dati su i prijedlozi rješenja dvaju problema nepotpunosti sistema klausalne logike sa SLDNF-resolucijom kao metodom dedukcije.

Znanja su podjeljena na pozitivna, negativna te definiciju hijerarhije entiteta u bazi. Dati su načini predstavljanja tih znanja i njihova uloga u procesu dedukcije, naslijedivanja svojstava i održavanja integriteta baze znanja.

Model je implementiran u Prologu, a rad sistema ilustriran je primjerima. Pokazan je način obrađivanja uspješnih kao i neuspjelih pokušaja dedukcije (izračunavanja) odgovora na upite postavljane sistemu.

**LOGIC AND KNOWLEDGE PROCESSING:** The article presents an analysis of the possibilities which logic offers to the problems of representing and processing knowledge. The results are collected in a proposal of an integral model of a knowledge base, defined in terms of logic and realised through logic programming means. Within the model, solutions are proposed for two incompleteness problems of systems of clausal logic with SLDNF-resolution as a deduction method.

Knowledge is classified into positive and negative knowledge and definitions of hierarchies of entities in the knowledge base. Ways of representing these types of knowledge and their role in the process of deduction, property inheritance and maintenance of the integrity of the knowledge base are given.

The model was implemented in PROLOG, and a few examples of its behavior are included here. They illustrate the manner in which the attempts at deducing (computing) the answers to queries are explained.

## 1. UVOD

Cesto se ističe da je problem predstavljanja znanja centralni problem tehnologije znanja, a time i razvoja sistema zasnovanih na znanju, odnosno ekspertnih sistema. U ovom članku dat je prijedlog sistema za predstavljanje i procesiranje znanja, koji smo nazvali modelom logičke baze znanja. Model je definiran u terminima matematičke logike odnosno logičkog programiranja, kao osnovnog sredstva ali i jedinstvenog metodološkog pristupa problematici predstavljanja i procesiranja znanja.

Odlikama logike (prvoga reda), a time i razlozima za njenu primjenu, u datom kontekstu smatramo:

- Deklarativnost semantike jezika logike. Znanja izražena u jeziku logike (prvoga reda) direktno su "čitljiva", za razliku od znanja predstavljenih u proceduralnim jezicima, gdje se "što" (tj. logika) zagubi u "kako" (tj. proceduri).
- Precizna sintaksa i semantika jezika, čime se izbjegava problem višečnačnosti, svojstven prirodnom jeziku.
- Postojanje metoda za automatsku dedukciju (izračunavanje) ispravnih odgovora iz datog skupa premissa (tj. baze znanja), datih u (pod)jeziku logike prvoga reda.

Iako je logika prvoga reda potpuna (tj. svaka logička konsekvenca skupa premissa je i deducibilna), ne postoji (općenit) algoritam kako tu logičku konsekvencu deducirati. Kao rezultat traženja jezika, za koji postoji efikasan algoritam za (automatsko) deduciranje logičkih konsekvenci iz datog skupa premissa definiran je jezik prvoga reda koji smo nazvali jezikom definitnih klausula.

### DEF 1.1.

Definitnom klausulom nazivamo formulu oblike

$$A \leftarrow B_1 \wedge \dots \wedge B_n$$

gdje je A atom (tj. atomarna formula), a  $B_1, \dots, B_n$  su literalni (pozitivni ili negativni). Pritom atom A nazivamo glavom (head) klausule a konjunkciju literala  $B_1, \dots, B_n$  tijelom (body) klausule. Definitnu klausulu oblike

$$A \leftarrow$$

nazivamo činjenicom.

Pojam definitne klausule uveo je van Emden u (End 78), ali u ujem značenju pojma (bez negativnih literala u tijelu), nego što to ovdje bismo.

Razlog za posebno bavljenje jezikom definitnih kauzula jeste u tome što te kauzule, pored uobičajene deklarativne semantike (značenja, "čitanja"), imaju i prikladnu proceduralnu semantiku, što ih čini pogodnim da budu uzete kao jezik za predstavljanje znanja, ali ujedno i kao kompjutacijski jezik. Naime, definitnu kauzulu

$$A \leftarrow B_1 \wedge \dots \wedge B_n \quad (1)$$

možemo deklarativno shvatiti (čitati) kao pravilo koje kaže da istinitost literala  $B_1, \dots, B_n$  implicira istinitost atomarne formule  $A$ . No, istu kauzulu možemo interpretirati i proceduralno, tj. kao instrukciju, koja kaže: zadatok  $A$  izvršavamo tako da izvršimo sve zadatke  $B_1, \dots, B_n$ .

#### Kauzulu oblika

$$A_1 \vee \dots \vee A_m \leftarrow B_1 \wedge \dots \wedge B_n \quad (2)$$

nazivamo nedefinitnom kauzulom. Deklarativno, kauzula (2) kaže da istinitost (svih) literalova  $B_1, \dots, B_n$  implicira istinitost bar jednog (ma da ne znamo kojeg i kolikih), literalova od  $A_1, \dots, A_m$ . Međutim, proceduralna interpretacija, a posebno implementacija automatske dedukcije kod nedefinitnih kauzula je znatno kričnija. Tako npr. u <Yah 85> nalazimo zaključak da je nedefinitnost kauzula "vrlo nepoželjno svojstvo", zato što predstavlja znatno kompleksniji problem za automatsku dedukciju.

#### DEF 1.2.

##### Zapis (formulu) oblika

$$\leftarrow B_1 \wedge \dots \wedge B_n$$

gdje su  $B_1, \dots, B_n$  literali, nazivamo ciljem.

Formule navedene u definicijama (1.1) i (1.2) jesu zapravo samo matrice formula logike prvoga reda, koje bi zajedno sa implicitno mišljenim kvantifikacijskim prefiksima glasile:

##### a) definitna kauzula iz definicije (1.1):

$$\forall x_1 \dots \forall x_j (A \leftarrow B_1 \wedge \dots \wedge B_n)$$

odnosno, činjenica:

$$\forall x_1 \dots \forall x_j (A)$$

gdje su  $x_1, \dots, x_j$  sve varijable koje sejavljaju u atomu  $A$  i/ili literalima  $B_1, \dots, B_n$ . Dakle, svaka varijabla, koja nastupa u definitnoj kauzuli, implicitno je vezana univerzalnim kvantifikatorom.

##### b) cilj iz definicije (1.2), tj.:

$$\leftarrow B_1 \wedge \dots \wedge B_n$$

čitamo: "nije istina da  $B_1 \wedge \dots \wedge B_n$ ". Dakle,

$$\forall x_1 \dots \forall x_j (\neg(B_1 \wedge \dots \wedge B_n)) \quad (3)$$

ili - a što je u kontekstu daljnog rada pogodnije - na logički ekvivalentan način:

$$\neg(\exists x_1 \dots \exists x_j (B_1 \wedge \dots \wedge B_n)) \quad (4)$$

Formule (3) i (4) su logički ekvivalentne.

Razlog za predstavljanje cilja kao negirane ('n')

egzistencijalno kvantificirane tvrdnje jeste u tome, što metodom SLDNF-resolucije pokušavamo iz nekog skupa premissa  $S$  deducirati dati cilj tako, da pokazemo nekonsistentnost skupa  $S \cup \{G\}$ , gdje je  $G$  zapravo negirana tvrdnja iz cilja. U praktičkim terminima rečeno, SLDNF-resolucija, kao metoda automatske dedukcije, provjerava deducibilnost nekog cilja  $G$  iz datog skupa premissa (tj. definitnih kauzula). Pritom da bi se deducirao odgovor na upit oblikas:

$$\text{"Koji su sve } x \text{ takovi da ... ?"} \quad (5)$$

upit biva transformiran u tvrdnju:

$$\text{"Ne postoji } x \text{ takav da ... ."} \quad (6)$$

dakle, u cilj iz definicije (1.2), kako je eksplioiran (shvaćen) u formuli (4). Sada pak SLDNF-resolucija pokušava pokazati nekonsistentnost skupa premissa kojem je dodana negirana egzistencijalno kvantificirana tvrdnja (6). Ukoliko takav dokaz (zovemo ga SLDNF-opovrgnude) uspije, onda su one vrijednosti varijable  $x$  iz (6), za koje je dokaz uspio, ujedno i odgovori na upit (5). Dakle, iako je uobičajeno govoriti o "dedukciji odgovora", ovdje se zapravo radi o "izračunavanju odgovor supstitucije", za dati upit, a ne o dedukciji (općenitih) formula, u standardnom značenju toga pojma. Više o tome rečeno je u odjeljku (3.4).

Opis same procedure SLDNF-opovrgnude (resolucije) dat je u <Llo 84>, gdje su ujedno date definicije temeljnih pojmova iz logičkog programiranja, koje ovdje koristimo.

## 2. O POTPUNOSTI SLDNF-RESOLUCIJE

Sistem kauzalne logike smatramo potpunim ukoliko je za dati skup premissa  $S$  i cilj  $G$ , svaka ispravna odgovor supstitucija ujedno i izračunata (odnosno izračunljiva) odgovor supstitucija.

U <Llo 84>, str.84 - 85, nalazimo primjer skupa definitnih kauzula (premissa):

- (a)  $p(x) \leftarrow$
- (b)  $q(a) \leftarrow$
- (c)  $r(b) \leftarrow$

i cilja:

$$\leftarrow p(x) \wedge n(q(x)). \quad (1)$$

Pomoću tog primjera Lloyd pokazuje nepotpunitost SLDNF-resolucije za jezik definitnih kauzula, napominjući pritom da je nalaženje "nekog oblike potpunosti" od "urgentne prioritete". Naime, obzirom da u jeziku kauzalne logike izračavamo znanja u bazi, razumljivo je da je potpunost sistema od esencijalnog značaja za njegovu upotrebljivost.

Nepotpunitost dedukcije za dati primjer slijedi iz toga što je supstitucija  $\{x/b\}$  ispravna odgovor supstitucija, ali ne i izračunata odgovor supstitucija. Dakle vrijedi:

$$\text{comp}(S) \models p(b) \wedge n(q(b)) \quad (2)$$

ali na upit (1) ne uspijevamo dobiti izračunatu odgovor supstituciju  $\{x/b\}$ , iz čega bi proizšlo da u kauzalnom sistemu sa SLDNF-resolucijom kao metodom deduciranja, ne vrijedit:

$$S \vdash p(b) \wedge n(q(b)). \quad (3)$$

Obrazložimo ukratko tvrdnje (2) i (3). Iz definicije jezika definitnih klauzula očito je da iz same teorije S ne može biti deducibilan nijedan negativan literal. Stoga je pri SLDNF-resoluciji je za dedukciju negativnih literala usvojeno nemonotonu pravilo izvođenja nazvano "negacija kao konačan neuspjeh dedukcije" (negation as finite failure - NF). Prema tom pravilu, ako je za dati skup klauzula S i cilj ' $\neg p$ ' pripadno SLDNF-drvo konačno i bez i jedne grane uspjeha, onda zaključujemo  $S \vdash \neg(p)$ . Međutim, kako sama teorija S, data u klauzalnom jeziku, ne može imati negativne literale za logičke posljedice, pouzdanost pravila 'NF' "spašava" se uvođenjem nadopune (completition)  $\text{comp}(S)$  za teoriju S. Grubo rečeno,  $\text{comp}(S)$  nastaje iz teorije S tako da sve što iz S nije deducibilno dodamo teoriji kao negirano (tj. neistinito); za formalnu definiciju  $\text{comp}(S)$  vidi npr. [Llo 84].

U promatranoj primjeru, cilj ' $\neg q(b)$ ' nije deducibilan iz teorije S. Utoliko i vrijedi  $S \vdash \neg(\neg q(b))$ , a isto tako i

$$\text{comp}(S) \vdash \neg(\neg q(b)) \quad (4)$$

S druge strane, vrijedi i  $S \vdash p(x)$  jer je  $p(x)$  element skupa S. Odatle (na nivou logike prvoga reda) slijedi i  $S \vdash p(b)$ , a time i

$$\text{comp}(S) \vdash p(b). \quad (5)$$

Rezultati (4) i (5) zajedno, potvrđuju tvrdnju (2) o ispravnoj odgovor supstituciji  $(x/b)$  za cilj (1) i dati skup premissa S.

Pogledajmo sada zašto SLDNF-resolucija tu ispravnu odgovor supstituciju ne uspijeva izračunati. Prema definiciji SLDNF-derivacije, ako literal 'A' iz negativnog literalu ' $\neg(n(A))$ ' ima opovrgnuće (a u načelu primjera je to literal ' $\neg(q(x))$ ' i ima opovrgnuće), onda se iz cilja ' $\neg(n(A))$ ' ne derivira novi cilj. Utoliko i ne možemo stići do prazne klauzule za polazni cilj ' $\neg(p(x) \wedge \neg(q(x)))$ ' (tj. do opovrgnuda i izračunate odgovor supstitucije za taj cilj), već pokutaj SLDNF-opovrgnuda (tj. izračunavanja odgovor supstitucije), završava neuspjehom. A odatle i slijedi iznad iznešena tvrdnja (3), o nededucibilnosti promatranoj cilja.

U nastavku dajemo prijedlog rješenja tog problema. Smatramo da razlog nemogućnosti izračunavanja ispravne odgovor supstitucije u promatranoj primjeru leži u klauzuli ' $p(x) \neg$ ' iz skupa premissa S. Naište, činjenica je ali nije temeljna, jer sadrži varijablu x, te se utoliko njenim uspješnim resolviranjem (ista) varijabla x iz negativnog literalu ' $\neg(q(x))$ ' nije instancirala. Nadalje, obzirom da SLDNF-derivacija pri resolviranju sa negativnim literalima kao najopćenitiji unifikator uzima supstituciju identitete e, niye ni moguće očekivati da za postavljeni upit (1) izračunata odgovor supstitucija bude  $(x/b)$ .

Obzirom da problem leži u klauzuli ' $p(x) \neg$ ', za samu problematiku predstavljanja znanja važno je pogledati što ta klauzula zapravo "znači" (predstavlja, kazuje).

Striktno govoreći, ta klauzula ne "kazuje" ništa, već je to samo dobro oblikovana klauzula (formula), prema definiciji (1.1). Do uobičajenog značenja te klauzule, tj. "svaki x posjeduje svojstvo p" ili pak "za svaki x vrijedi  $p(x)$ " dolazimo tek njenom interpretacijom. No, za interpretaciju su nam potrebne struktura i asignacija. Nadalje, definicija strukture temelji na odabiru nepraznog skupa kao domene (tj. prostora, svijeta) D. Tada pak i "svaki x ..." biva interpretiran (shvaćen) - u skladu sa semantičkom definicijom simbola 'V' - kao "svaki x iz domene D ...".

Prema 'teorija - model' paradigmu u kontekstu problematike predstavljanja znanja, skup klauzula smatrao se teorijom kojom težimo opisati neku strukturu kao dio realnog ili hipotetičkog svijeta. Obzirom da u tom slučaju pri formiranju teorije znamo o čemu govorimo - tj. struktura je unaprijed data - izražavanje znanja pomoću netemeljnih činjenica ne samo da dovodi do nepotpunosti deduktivnog sistema, već izgleda i neprimjernim. Naime, mi promatranoj klauzuli ' $p(x) \neg$ ' zacijselo nismo željeli izraziti znanje da "svi" posjeduju svojstvo p, već da to svojstvo posjeduju "svi iz strukture" koju teorijom opisuјemo. Utoliko i znanje izraženo klauzulom ' $p(x) \neg$ ' možemo - bar sa aspekta predstavljanja znanja - adekvatnije predstaviti u slijedećoj formi:

$$p(x) \neg \text{element\_strukture}(x)$$

tj. "Svaki element, ako je iz domene strukture onda posjeduje svojstvo p." (U predloženom modelu logičke baze znanja učinjeno je to na prikladniji ali analogan način.)

Pokazani način transformacije netemeljnih činjenica u pravila navodi nas na definiciju podjezika jezika definitnih klauzula, u kojem će spomenuti princip ved vrijediti. Takav jezik nazvali smo ovde jezikom regularnih klauzula.

#### DEF 2.1.

##### Definitnu klauzulu

$$A \neg B_1 \wedge \dots \wedge B_n$$

nazivamo regularnom ukoliko zadovoljava sljedeće uvjete:

- a) Ako je  $n = 0$ , tj. klauzula je činjenica, onda je to temeljni atom.
- b) Ako je  $n > 0$  onda:
  - 1) svaka varijabla koja se javlja u glavi klauzuli javlja se i u bar jednom literalu tijela klauzule;
  - 2) svaka varijabla koja se javlja u negativnom literalu  $B_i$  tijela klauzule, javlja se i u bar jednom pozitivnom literalu  $B_j$  tijela klauzule, tako da literal  $B_j$  prethodi literalu  $B_i$ .

#### DEF 2.2.

##### Cilj

$$\neg B_1 \wedge \dots \wedge B_n$$

je regularan ako svaka varijabla koja se javlja u negativnom literalu  $B_i$  iz cilja, javlja se i u bar jednom pozitivnom literalu  $B_j$  iz cilja, tako da literal  $B_j$  prethodi literalu  $B_i$ .

Da bi pokazali da zahtjev po regularnosti jezika ne ograničava njegove izražajne mogućnosti već da samo zahtjeva pravilniju formulaciju (izražavanje) znanja, osvrnimo se ponovo na Lloydov primjer. Za dati primjer, svaka moguća supstitucija oblike  $(x/?)$  - osim, naravno, supstitucija  $(x/a)$  - je i ispravna odgovor supstitucija. Naime, obzirom da činjenice

$$q(c), q(d), \dots$$

nisu deducibilne iz skupa premissa S, deducibilni su negativni literali

$$\neg(q(c)), \neg(q(d)), \dots \quad (6)$$

S druge strane, iz (neregularne) činjenice ' $p(x)$ ' slijedi i

$p(c), p(d), \dots$  (7)

a time - iz (7) i (6) - slijedi da su supstitucijske

$\{x/c\}, \{x/d\}, \dots$

ispravne (ali opet ne i izračunate!) odgovor supstitucije.

U jeziku regularnih klausula, promatrani primjer izrazili bismo na slijedeći način:

```
p(x) <-- element_strukture(x)
q(a) <--
q(b) <--
element_strukture(a) <-- element_strukture(b) <--
```

Ispravne odgovore supstitucije  $\{x/b\}$ , koja za isto znanje - tj. premise, ali izražene u jeziku definitnih klausula - nije bila izrađenljiva, sada jeste izračunata odgovor supstitucije. Stotinu, prelaskom na regularnu formu klausula i ciljeva, supstitucije  $\{x/c\}, \{x/d\}, \dots$ , više nisu niti ispravne odgovore supstitucije, niti izračunate odgovore supstitucije. To pak držimo isto tako povoljnim (i poželjnim) efektom uvođenja jezika regularnih klausula, jer se konstante c, d, ... u teoriji S ne javljaju, pa prema tome ne označavaju niti elemente iz strukture koju teorijom S želimo opisati. Ukoliko pak želimo da to postanu, tj. ukoliko želimo u teoriji S izredi neka nova saznanja o promatranoj strukturi, onda to možemo učiniti dodavanjem teorije klausula

```
element_strukture(c) <-- element_strukture(d) <--
```

Adekvatnost primjene regularnih klausula ilustrirajmo slijedećim primjerom.

Neka struktura M, koju teorijom želimo opisati bude 'svijet živih bića'. Znanje da "sva živa bića diđu", možemo izraziti na dva načina:

(a) definitnom (ali ne i regularnom klausulom)

$\text{diže}(x) <--$

(b) regularnom klausulom

$\text{diže}(x) <-- \text{je_zivo_bide}(x)$

Smatramo da regularnaklausula (b) naprosto adekvatnije (prirodnije) izražava naše znanje o strukturi M, izraženo u prirodnom jeziku rečenicom "Sva živa bića diđu".

U [\(Kow 79\)](#), str. 220, dat je primjer (drugačije prirode), kojim se pokazuje drugi slučaj (vid) nepotpunitosti SLDNF-resolucije, kao metode izvođenja u sistemu klausulne logike. Pogledajmo taj slučaj.

Neka skup formula logike prvoga reda S bude:

$\{ n(p(a)) \rightarrow p(a) \}$  (8)

Logičkom transformacijom (jedine) formule iz skupa S, dobivamo

$\{ n(n(p(a))) \vee p(a) \}$

a odakle i

$\{ p(a) \}$

Prema (8) vrijedi dakle, i

$S \vdash p(a)$  (9)

No, predstavimo li formulu iz skupa S u klausulnoj formi, tj. kao klausulu

$p(a) <-- n(p(a))$  (10)

onda iz te klausule (uzete kao premise), prema SLDNF-resoluciji, ' $p(a)$ ' nije deducibilno!

No, ovaj slučaj (oblik) nepotpunitosti bitno se razlikuje od ranije razmotrenog (Lloydovog) slučaja. Naime, dok je u prijašnjem primjeru pokušaj dedukcije bio konačan, dajući pritom pogrešan odgovor "ne", ovde je pokušaj deduciranja cilja ' $p(a) <--$ ' (tj. pokušaj SLDNF-opovrgnuća za taj cilj i klausulu (10)), uopće ne završava, jer pripadno SLDNF-drvo nije konačno. Naime, pokušaj dedukcije cilja ' $<-- p(a)$ ' dovodi do generiranja izvedenog cilja ' $<-- n(p(a))$ ', koji se opet svodi na pokušaj dedukcije cilja ' $<-- p(a)$ ', itd. Pored same neobičnosti znanja, koje izražava (interpretirana) formula iz skupa (8), tj. da:

Ako entitet 'a' ne posjeduje svojstvo 'p' onda entitet 'a' posjeduje svojstvo 'p'.

Obito je da se ovdje radi i o cirkularnom načinu definiranja i izražavanja znanja. Jer svojstvo 'p' za entitet 'a' definirano je u terminima tog istog svojstva za taj isti entitet.

Prijedlog rješenja problema konačnosti SLDNF-drva (i kompjutacije), dat je u [\(Llo 85\)](#). Prema tom prijedlogu, sva svojstva (predikatni simboli), koji se javljaju u teoriji (tj. skupu klausula S), razvrstavaju se u hijerarhijske nivoje. Pritom, u tijelu klausula iz skupa S smiju nastupati samo svojstva (predikatni simboli) koji su nižeg nivoa od svojstava koje se javlja u glavi klausuli. U tom slučaju cirkularnost definicije u skupu klausula S je savsim onemoguđena, tako da je svaki pokušaj SLDNF-opovrgnuća (tj. izračunavanja odgovor supstitucije) konačan, i završava uspjehom ili neuspjehom.

Međutim, takvo ograničenje postavljeno na jezik skupa premisa (klausula) - iako garantira konačnost kompjutacije - izgleda isuviše restriktivnim. Naime, njime se isključuje mogućnost rekurzivnog definiranja (opisivanja), koje pak smatramo izrazito značajnim za predstavljanje znanja. Ilustrirajmo to primjerom.

Neka znanje, koje želimo predstaviti u jeziku regularnih klausula bude:

Krvnu grupu nasljeđuje se od oca (11)

U jeziku regularnih klausula to možemo učiniti sa:

$\text{krv_grupa_od}(x,y) <-- \text{otac_od}(x,z) \wedge \text{krv_grupa_od}(z,y)$  (12)

U jeziku logičke baze znanja, sintaktički smo poljepšali jezik regularnih klausula, tako da bi znanje (11) bilo predstavljeno kao pravilo:

$\text{krv_grupa_od}(X;Y) \text{ ako } \text{otac_od}(X;Z) \text{ i } \text{krv_grupa_od}(Z;Y)$  (13)

U jeziku sa hijerarhijskim uređenjem predikatnih simbola takvu tvrdnju ne bismo mogli izreći, jer se predikatni simbol 'krv\_grupa\_od' iz glave klausule (pravila) javlja i u tijelu klausule, što hijerarhijsko uređenje svojstava (predikata) ne dopušta. No, mogućnost rekurzivne definicije izgleda isuviše značajna da bismo ju jednostavno

zabranili. Jer "teoretska čistota" modela (tj. garantirana konačnost svakog pokušaja SLDNF-opovrgnuća), koju zabranas rekurzivne definicije postizemo, izgleda ipak preslabom nadoknadem za izgubljene operativne mogućnosti baze znanja.

Zaključimo razmatranje iz ovog odjeljka opisom rješenja usvojenog (i implementiranog) u modelu logičke baze znanja, koji ovdje predlažemo.

Prilikom svake izmjene sadržaja logičke baze znanja - tj. upisa/brisanja pravila/činjenica - (automatski) se provjerava da li je time stvorena mogućnost postavljanja upita (tj. cilja) za koji bi pripadno SLDNF-drvo imalo beskonačnu granu. Ukoliko je takova mogućnost zaista stvorena, onda već u toku same provjere postojanja te mogućnosti, dolazi do prekoraćenja raspoložive memorije na sistemu, što nam ujedno i služi kao znak postojanja beskonačne (ili barem operativno prevelike) grane. U implementaciji modela logičke baze, ilustriranoj primjerima u odjeljku (4), razvijena je naredba 'loop', pomoći koje prilikom nastupa prekoraćenja, od sistema dobivamo odgovor koji je to cilj za koji bi, u ažuriranoj bazi znanja, pripadno SLDNF-drvo imalo beskonačnu granu. Na slijedeći upit - 'sh\_loop' - sistem eksplioira (pokazuje) tu granu (odnosno, pokušaj SLDNF-opovrgnuća, koji ju slijedi), i to do dubine koju sami zahtjevamo. Tada je na kreatoru baze znanja (koji upis/brisanje vrši), da odludi je li zaista riječ o "čisto beskonačnoj" grani SLDNF-drvena, (tj. cirkularnoj definiciji), ili pak bi bilo vrijedno ponoviti pokušaj SLDNF-opovrgnuća sa vedom raspoloživom memorijom. Ukoliko potonje nije slučaj (a u pravilu nije!), onda se zahtjeva preformulacija znanja u bazi, tako da se cirkularnost izbjegne, a time i postigne konačnost svake moguće grane SLDNF-drvena odnosno svakog pokušaja SLDNF-opovrgnuća za neki dati cilj (upit) postavljenu skupu premisa (tj. logičkoj bazi znanja).

Problem cirkularnosti definiranja je jedan od važnih (i otvorenih) problema logičkog programiranja, posebno u kontekstu značaja koji ima rekurzija (ali i potpunost!). Držimo, da ovdje dato operativno rješenje jeste zadovoljavajuće, posebno u kontekstu problematike predstavljanja i dedukcije znanja. Naime, njime se zadržava mogućnost rekurzivnog definiranja a ujedno i smješta otkriva i eksplioira eventualno postojanje beskonačne (točnije: prevelike) grane. Više od toga (osim isuviše rigoroznim restrikcijama jezika!), u kontekstu neodlučivosti logike te primjene pravila "negacija kao konačan-neuspjeh dedukcije", ne izgleda dosežnica.

### 3. MODEL LOGIČKE BAZE ZNANJA

Modelom logičke baze znanja dat je cijelovit prijedlog načina predstavljanja znanja u jeziku logičke baze znanja, sa SLDNF-resolucijom, kao metodom deduciranja (odnosno izračunavanja) odgovora iz baze. Da bi (formalna) dedukcija u bazi (implicitno) sadržanih znanja bila moguća, moraju znanja u bazi biti data u jeziku precizne sintakse i semantike. S druge strane, obzirom da se u tom jeziku izražavaju znanja koja potjeđu od čovjeka i čovjeku služe, pošefljno je da taj jezik bude ujedno i blizak prirodnom jeziku. Stoga smo jezikom logičke baze nazvali jezik regularnih klausula u kojem su izvršene izmjene na nivou sintakse (točnije: abecede), i to sa ciljem da se jezik učini bliži prirodnom jeziku. U tu svrhu smo logičke simbole iz jezika

regularnih klausula zamjenili njihovim uobičajenim ekvivalentima (interpretacijama) u prirodnom jeziku. U nastavku ćemo, kada bude riječ o 'znanju', govoriti u terminima i notaciji jezika logičke baze znanja. Kada pak budemo nad tim 'znanjem' izvodili neke logičke transformacije (dedukcije, dokaze), ćiniti ćemo to u notaciji i terminologiji jezika regularnih klausula.

U jezik logičke baze znanja uvodimo i disjunkciju, i to na slijedeći način: Neka su

'glava' ako 'tijelo\_1' (1)

i

'glava' ako 'tijelo\_2' (2)

pravila iz jezika logičke baze znanja. Tada je i

'glava' ako 'tijelo\_1' ili 'tijelo\_2' (3)

pravilo jezika logičke baze znanja. Drugim riječima, disjunkciju u jezik logičke baze uvodimo kao skraćenu notaciju za dva (ili više) pravila sa identičnim glavama. Da je zaista riječ samo o notacijskoj varijanti siljdi iz toga što je konjunkcija pravila (1) i (2) logički ekvivalentna pravilu (3).

Za predstavljanje atomarnih znanja predlažemo slijedeću shemu:

Svojstvo(Entityt:Vrijednost) (4)

U shemi (4) 'Svojstvo' ima istu ulogu kao i dvo-mjesni predikativni simbol u logici prvega reda, odnosno 'ime relacije' u relacijskoj shemi. U <Rad 86b>, umjesto izraza 'svojstvo' korišten je izraz 'opis' (description), uz napomenu da taj izraz "zvuči suviše sintaktički". U stvari, držimo da bi, na nivou samoga jezika (sintakse), termin 'opis' izgledao prikladnijim, dok na nivou modela (strukture), koju tim jezikom opisuјemo, adekvatnijim izgleda termin 'svojstvo'. Obzirom da je cilj logičke baze znanja (kao teorije), da opiše unapred danu strukturu, možemo smatrati da su predikativni simboli iz jezika ved a priori interpretirani, te nam govoriti u terminima 'svojstava' izgleda prikladnijim.

U ulozi 'Entiteta' može se pojaviti bilo koji pojam koji označava neki entitet iz strukture, kojeg želimo opisati u terminima pridruženih mu svojstava i pripadnih vrijednosti.

'Vrijednost' iz sheme izražava vrijednost promatranoj svojstva za dati entitet. Vrijednost može biti izražena numerički ili nekim atributom (pojamom, jezičkim izrazom). Na primjer u

broj\_kotača\_od(auto:4)

vrijednost svojstva 'broj\_kotača\_od' za entitet 'auto' data je numerički. S druge strane, u primjerima

pušač(petaristrastven)  
pušač(ivansumjeren)

vrijednosti su date jezičkim izrazima.

Analizom razloga upotrebe upravo (i samo) binarnih predikata (svojstava) ovdje se ne bavimo; prikaz osnove te problematike dat je u <Kow 79>.

### 3.1. Sadržaj baze znanja

Sadržaj logičke baze znanja sačinjavaju tri komponente:

- pozitivno znanje
- hijerarhija entiteta
- negativno znanje

Sve tri komponente čine informacijski sadržaj logičke baze, tj. sadržavaju iskaze baze znanja, shvađene kao logičke teorije. Podjela sadržaja baze u tri komponente uvjetovana je kako samon različitočcu iskazu (znanja) tako i specifičnostima SLDNF-resolucijske, kao metoda deduciranja pomolu koje se generiraju (deduciraju) odgovori iz baze znanja.

#### a) Pozitivno znanje

Pozitivno znanje sačinjavaju ona znanja koja su izrazljiva pravilima i činjenicama iz jezika logičke baze znanja. Tako bismo na primjer (hipotetičku) zakonitost:

Svatko nosiće boju očiju od majke

u jeziku logičke baze mogli predstaviti (izreći) pravilom:

$\text{boja\_oči\_od}(X;Y) \text{ ako } \text{majka\_od}(X;Z) \text{ i } \text{boja\_oči\_od}(Z;Y).$  (5)

Nadalje, činjenice poput:

Ana ima smeđe oči

možemo u jeziku logičke baze izraziti sa:

$\text{boja\_oči\_od}(\text{Ana};\text{smeđa}).$

Znanja, koja na analogan način izražavamo pomolu pravila i činjenica u jeziku logičke baze, nazvali smo pozitivnim znanjima. Ta znanja iskažuju neka svojstva entiteta, tj. iskazivanjem takovih znanja entitetima pridružujemo svojstva sa datim vrijednostima, čime se entiteti pozitivno određuju.

Napomenimo da smo u pravilu (5), u skladu sa zahtjevima standardnog Prolog interpretatora u kojem je model implementiran, varijable predstavili velikim slovima (X,Y,Z).

#### b) Hijerarhija entiteta

Hijerarhijska struktura definirana je tzv. tipizacijom entiteta, čime je stvorena mogućnost naslijedivanja svojstava među entitetima u strukturi. Entitete tipiziramo upotrebom svojstva 'vrsta\_čod'. Na primjer, činjenicu (pozitivno znanje) da:

Ivan je čovjek (6)

predstaviti čemo u jeziku baze činjenicama:

$\text{vrsta\_od}(\text{ivan};\text{čovjek}).$

Svojstvo 'vrsta\_čod' mora za svaki entitet iz baze znanja biti jedinstveno, stime da ugradnja entiteta u hijerarhijsku strukturu nije obavezna, tj. svojstvo 'vrsta\_čod' ne mora biti uopće dato za entitet. Naravno, u tom slučaju netipizirani entitet neće naslijediti nikakva svojstva, jer za njega u bazi znanja formalno i ne postoji viših entiteta. Svojstvom 'vrsta\_čod' uređuju se entiteti "po vrstama", što ulogu toga

svojstva čini specifičnom. Stoga i znanje:

Ivan je vozač

koje - na nivou prirodnog jezika - može izgledati analogno znanju (6), nećemo izražavati u terminima svojstva 'vrsta\_čod', već npr. sa:

$\text{zanimanje\_od}(\text{ivan};\text{vozač})$

Pored svojstva 'vrsta\_čod', na hijerarhijsko uređenje entiteta odnosi se i svojstvo 'je', kojeg je ovdje dalo nezavisno i različito značenje od svojstva 'je', korištenog u formalizmu semantičkih mreža. Ovdje je to svojstvo definirano (i implementirano na sistemu), na slijedeći način:

a)  $\text{je}(e;e)$

za svaki entitet e iz baze znanja;

b)  $\text{je}(e1;e2)$

ako postoji takav entitet e3, da  
 $'vrsta\_od(e1;e3)' i 'je(e3;e2)'$ .

Drugim riječima, svaki entitet 'je' on sam isto tako, svaki entitet ei ima svojstvo da 'je' i e2, ako se entitet e2 nalazi u hijerarhiji iznad entiteta ei.

Svojstvo 'je' koristimo kod izražavanja pravila poput:

$\text{diše}(X;\text{ida}) \text{ ako } \text{je}(X;\text{živo\_biće}).$

Čime u logičkoj bazi iskazujemo (predstavljamo) znanje:

Svako živo biće (a i  
"živa bića općenito") diše

U implementaciji modela svojstvo 'je' nazivamo rezerviranim jer se ono ne definira eksplicitno za pojedini entitet već je to svojstvo implicitno dano posredstvom definicija svojstava 'vrsta\_čod'.

#### c) Negativno znanje

Znanja, kojima se odriču neka svojstava entiteta, nazvali smo negativnim znanjima. Takova znanja nisu izrazljiva pravilima i/ili činjenicama iz jezika logičke baze znanja. Na primjer, znanje:

Nitko nema crvene oči

(7)

ne možemo direktno izraziti definitnom (ni regularnom) klausulom. Naime, znanje (7) možemo u jeziku logike prvoga reda izraziti kao:

$n(\text{Ex}(\text{boja\_oči\_od}(x,\text{crvena})))$

(8)

dakle,

Ne postoji takav individual x, za koji bi vrijedilo da je boja njegovih očiju crvena.

Međutim, formula (8) egzistencijalno je kvantificirana, te ju - na putu prema klausalnoj formuli - moramo preformulirati tako da ju prevedemo u univerzualno kvantificiranu formulu. Formula (8) logički je ekvivalentna formuli

$Vx(n(\text{boja\_oči\_od}(x,\text{crvena})))$

(9)

Izostavljanjem (eksplicitno datog) univerzalnog kvantifikatora iz (9) dobivamo

n(boja\_obi\_od(x,crvena)) (10)

Međutim, prema definiciji (1.1), izraz (10) nije definitna klausula jer je to negativan literal.

Mogućnost da se takova (tj. negativna) znanja ipak izraže u jeziku logičke baze jeste da se to učini pomoću cilja (upita). Naime, prema definiciji (1.2) i pripadnom obrazloženju, formula (8) ima točno oblik cilja. Stoga ćemo znanje (7) izraženo formulom (8) izražiti regularnim ciljem (odnosno upitom) iz jezika logičke baze:

?- boja\_obi\_od(X:crvena) (11)

Upit (11) jest regularan jer u njemu negacija uopće ne nastupa.

Istaknimo ovdje razliku između 'negativnog znanja' i 'neznanja'. Obzirom da je u SLDNF-resoluciji za negaciju već usvojeno pravilo izvođenja nazvano "konačan neuspjeh dedukcije", negativna znanja ne bi ni trebalo predstavljati u bazi znanja.

Naime, na upit

?- boja\_obi\_od(X:crvena). (12)

postavljen bazi znanja - po SLDNF-resoluciji - odgovor će glasiti "ne", obzirom da za nijedan entitet c (kao moguću instancu varijable X), iz baze znanja nije deducibilno:

boja\_obi\_od(c:crvena).

Drugim riječima, za (neko dato) stanje baze znanja i u upit (11), ne postoji ispravna odgovor supstitucija, pa stoga ni izrađunata odgovor supstitucija. Međutim, ukoliko bismo u toku razvoja (azuriranja) baze znanja unijeli, na primjer znanje

boja\_obi\_od(marko:crvena) (13)

onda bi odgovor na upit (11) glasio "marko".

No, ako znamo da "nitičko nema crvene oči" (tj. (7) odnosno (8)), onda - u kontekstu toga znanja - znanje (13) nije smjelo biti uneseno u bazu. Jer baza znanja, koja sadrži znanja (8) i (13) jeste - kao logička teorija - nekonsistentna. Naime, iz (13) bi slijedilo:

Ex(boja\_obi\_od(x,crvena)) (14)

što zajedno sa (8) dokazuje nekonsistentnost logičke baze kao teorije, jer je iz nje deducibilno A i n(A), tj. formule (8) i (14).

Kako navedeni primjer pokazuje, iako je samo 'neznanje' (tj. neizražavanje znanja) dovoljno za generiranje negativnih odgovora, ono nije dovoljno i za spriječavanje da se u logičku bazu unese znanja, koja to nisu! - tj. greške, poput "znanja" (13). S druge strane, izražavanje negativnih znanja u logičkoj bazi (u obliku ciljeva (upita)), omogućava da unos (ili uopće deducibilnost) pogrešnih "znanja" (tj. grešaka) učini logičku bazu znanja (tj. teoriju), nekonsistentnom. Negativna znanja, izražena pomoću upita, smatrati ćemo stoga uvjetima integriteta logičke baze znanja. Ta znanja ne učestvuju pri samoj dedukciji odgovora (jer je negacija kao 'konačan neuspjeh dedukcije' za to dovoljna), već štite bazu znanja pred takovim promjenama (azuriranjima), koje bi istu učinila logički nekonsistentnom.

Općenito, uvjeti integriteta, izraženi kao upiti, iskazuju negativna znanja (formule)

oblikat

n(Ex1Ex2...Exj ('elementi cilja')) (15)

Formula oblika (15) istinita je u strukturi koju znanjem iz logičke baze opisujemo, ako i samo ako ne postoji instance varijabli x1,x2, ..., xj, za koje bi formula 'elementi cilja' bila istinita u promatranoj strukturi.

Formula oblika (15), tj. uvjet integriteta, općenito izražavamo u bazi znanja (upitom):

?- 'elementi cilja' (16)

Tada zadovoljivost upita (16) - dakle, bilo koja izrađunata odgovor supstitucija različita od "ne" - ujedno implicira deducibilnost formule 'elementi cilja', i to za one instance varijabli koje su dobivene kao izrađunata odgovor supstitucija za upit (16). To pak, onda općenito znači i deducibilnost formule:

Ex1Ex2 ... Exj ('elementi cilja') (17)

što zajedno sa formulom (15) pokazuje nekonsistentnost baze znanja, promatrana kao logičke teorije. Na taj način je i pojam integriteta baze znanja konzistentno preveden u logičku terminologiju, i sveden na pojam konsistentnosti teorije.

Primjerom logičke baze znanja, datom u odjeljku (4), ilustrirani su neki od mogućih načina i slučajeva izražavanja negativnih znanja kao uvjeta integriteta.

Radi ilustracije, samoga principa predstavljanja znanja pomoći uvjeta integriteta, pokazimo ovdje kako možemo njihovom upotrebom adekvatno i jednostavno rješiti (famoznii!) problem predstavljanja znanja:

Sve ptice lete osim pingvina (18)

Pozitivno znanje sadržano u rečenici (18) - tj. da sve ptice koje nisu pingvini, lete. - izraziti ćemo u jeziku logičke baze pravilom:

leti(X)da ako je(X:ptica) i  
ni\_je(X:pingvin). (19)

Pri tome je svojstvo 'ni\_je' (po definiciji) ekvivalentno negaciji svojstva 'je' (tj. 'nije je') - a dato je kao način sintaktičkog uljevanja jezika.

Negativno znanje, tj. da "svaka ptica, koja je pingvin, ne leti", rečenicom (18) nije zapravo niti izređeno, ali - kao što je to često sluđaj u prirodnom jeziku - podrazumijevo se. Naravno, primjenom pravila (19), znanje

leti(pingvinida). (20)

neće nikad biti deducibilno. Međutim, samo pravilo (19) ne može spriječiti da (20) postane deducibilno na neki drugi način. No, možemo to učiniti tako da negativno znanje, tj. "pingvin ne leti", izrazimo uvjetom integriteta (upitom)

?- leti(pingvinida). (21)

Azuriranje baze znanja, koje bi dovelo do deducibilnosti "znanja" (20), učinilo bi ujedno - zahvaljujući 'negativnom znanju' (21) - da baza znanja postane nekonsistentnom, kako je to iznad opisano. Stoga sistem logičke baze takovo azuriranje i ne dopušta. To pak znači da ćemo - prema pravilu (19) - za svaki entitet koji "je ptica", osim za one koji su pingvini, morati deducirati "da leti". S druge strane, uvjet integriteta (21) onemogućava da svako azuriranje baze zna-

nja, koje bi imalo za posljedicu da "letki pingvin" postane deducibilno.

### 3.2. Naslijedivanje svojstava

Ovdje ćemo ilustrirati mogućnosti izražavanja znanja, tj. pripisivanja svojstava entitetima, iz hijerarhijske strukture, tako da te svojstva naslijeduju ili ne naslijeduju podređeni entiteti u strukturi, u zavisnosti od načina na koji su ta znanja izražena. U tu svrhu analizati ćemo kako, uz adekvatno izražavanje znanja, logički konsistentna baza može sadržavati skup znanja poput:

|                      |      |
|----------------------|------|
| ljudi vole životinje | (22) |
| ljudi ne vole zmije  | (23) |
| zmije su životinje   | (24) |

Znanje (22) možemo – kao i obično, kada je o prirodnom jeziku riječ! – shvatiti a onda i formalno (precizno) izraziti u jeziku logičke baze, na više različitih načina. Učinimo to najprije činjenicom:

$$\text{voli}(\text{čovjek}; \text{životinja}). \quad (25)$$

Cinjenica (25) interpretira znanje (22) kao:

$$\text{Entitet } 'čovjek' \text{ (kao klasa) voli entitet } 'životinja' \text{ (kao klasu).} \quad (26)$$

Cinjenicom (26) nismo ništa ustvrdili o pojedinim ljudima (tj. entitetima koji su 'vrste' čovjek), niti pojedinim životinjama.

Nadalje, znanje (22) možemo shvatiti i na način kako je to precizno izraženo slijedećim pravilom:

$$\text{voli}(X; \text{životinja}) \text{ ako je}(X; \text{čovjek}). \quad (27)$$

Time je znanje (22) interpretirano kao:

$$\text{Entitet } 'čovjek' \text{ (kao klasa), a i svaki pojedini njegov podentitet (koji 'je' čovjek), voli entitet } 'životinja' \text{ (kao klasu).} \quad (28)$$

Interpretacija (28) znanja (22), izražena pravilom (27) isto tako ne kazuje ništa o pojedinim entitetima koji su podentiteti entiteta 'životinja'.

Konačno, mogudi način shvađanja znanja (22) bio bi i slijedeći:

$$\text{Entitet } 'čovjek' \text{ (kao klasa), a i svaki pojedini njegov podentitet (koji 'je' čovjek), voli entitet } 'životinja' \text{ (kao klasu), a i svaki pojedini njegov podentitet (koji 'je' životinja).} \quad (29)$$

Interpretaciju (29) pozitivnog znanja (22) možemo u jeziku logičke baze izraziti pravilom:

$$\text{voli}(X; Y) \text{ ako je}(X; \text{čovjek}) \text{ i je}(Y; \text{životinja}). \quad (30)$$

Negativno znanje (23) mogli bismo isto tako interpretirati na više načina. No, odaberimo ovdje samo slijedeći način:

$$\text{Nijedan entitet koji 'je' čovjek ne voli nijednog entiteta koji 'je' zmija.} \quad (31)$$

Znanje (23), interpretirano kako je dato u (31), izraziti ćemo u logičkoj bazi upitom:

$$\neg \text{voli}(X; Y) \text{ i je}(X; \text{čovjek}) \text{ i je}(Y; \text{zmija}). \quad (32)$$

I na kraju, znanja (24) izraziti ćemo činjenicom:

$$\text{vrsta\_od}(zmija; životinja). \quad (33)$$

Interpretacije (26) i (28) znanja (22), izražene činjenicom (25) odnosno pravilom (27), u logičkoj bazi znanja, koja utočili negativno znanje (32) i znanje (33), ne dovode do nekonistentnosti baze znanja. Naime, negativnim znanjem (32), svakom entitetu koji 'je' čovjek, održiće se svojstvo 'voli' sa vrijednostu koja 'je' zmija. No, niti činjenica (25) niti pravilo (27) to svojstvo sa takvom vrijednošću ne pripisuju entitetu koji 'je' čovjek.

S druge strane, interpretacija (29) znanja (22), izražena pravilom (30), dovodi do nekonistentnosti logičke baze znanja. To je (i neformalno) savsim razumljivo, obzirom da se negativnim znanjem (32) iskazuje da nitko tko 'je' čovjek ne voli nikoga tko 'je' zmija, dok se pravilom (30) iskazuje da svatko tko 'je' čovjek voli svakga tko 'je' životinja, pa prema tome i zmiju!

Sa navedena tri načina interpretiranja (shvađanja) znanja (22) izraženog u prirodnom jeziku, željeli smo istaći nužnost precizne (i adekvatne) interpretacije i formalnog predstavljanja znanja iz prirodnog jezika u jeziku logičke baze znanja. Cinjenica da znanje (22) možemo interpretirati na više načina, od kojih neki dovode i do nekonistentnosti, ne znači da čovjek normalno komunicira i zaključuje na osnovu nekonistentnog skupa znanja (premisa), kako se to ponkad tvrdi. Mnenjeno smo, da čovjek vrlo uspješno i adekvatno interpretira znanja izražena prirodnim jezikom (i to najčešće u zavisnosti od nekog datog konteksta), a ne da zaključuje iz nekonistentnog skupa premisa.

Predloženim načinima pripisivanja svojstava i vrijednosti entitetima, kako je to opisano u ovom odjeljku, željeli smo omogućiti izražavanje znanja, na način koji bi adekvatno odražavao mehanizam pridruživanja i (ne)slijedivosti svojstava kakav (ma da neformalno) postoji u prirodnom jeziku.

### 3.3. Ekvivalencija

U prirodnom jeziku ekvivalenciju obično iskazuјemo izrazom "ako i samo ako", iako valja istaći da u prirodnom jeziku ekvivalenciju mnogo češće mislimo (podrazumijevamo) nego što ju eksplicitno iskazujemo. U ovom odjeljku data je analiza dviju interpretacija (shvađanja) ekvivalencije kao i prijedlog načina da se ekvivalencija (odnosno, jedna od njenih interpretacija), izrazi u modelu logičke baze znanja.

Rečenicu

$$p(x) \text{ ako i samo ako } q(x) \quad (34)$$

izraziti ćemo u logici prvoga reda formulom

$$p(x) \leftrightarrow q(x) \quad (35)$$

gdje je simbol ' $\leftrightarrow$ ' najčešće definiran na metanivou sistema (dakle, znak '=' pripada metajeziku), kao:

$$p(x) \leftrightarrow q(x) = \\ (p(x) \rightarrow q(x) \wedge q(x) \rightarrow p(x)) \quad (36)$$

Formula (35) ne možemo direktno zapisati u jezičku logičke baze znanja, jer ne raspoložamo izrazom (simbolom) 'ako i samo ako', već samo sa implikativnim veznikom 'ako'. S druge strane, pokušaj da ekvivalenciju (35) izrazimo tako da u logičkoj bazi izrazimo desnu stranu definicije (36), tj. regularne klaузуе:

$$p(x) \leftarrow q(x) \quad (37)$$

$$q(x) \leftarrow p(x) \quad (38)$$

isto tako ne uspijeva. Naime, u tom slučaju imali bismo očigledan primjer cirkularne definicije tj.  $p(x)$  pomoću  $q(x)$ , a pritom i  $q(x)$  pomoću  $p(x)$ . Naravno, tada bi npr. cilj

$$\leftarrow p(x) \quad (39)$$

zajedno sa premissama (37) i (38) imao SLDNF-drvo sa beskonačnom granom, što smo već okarakterizirali kao neprihvatljivo. No, time mogućnost izražavanja ekvivalencije u logičkoj bazi znanja još nije sasvim izgubljena. Naime, značenje (ulogu) ekvivalencije - posebno u kontekstu predstavljanja znanja - možemo shvatiti na dva različita načina:

#### a) Uspostavljanje ekvivalencije

U tom slučaju, koji smo nazvali 'uspostavljanje ekvivalencije', ukoliko u skup premissa koji sadrži formulu (35) dodamo činjenicu

$$p(a) \leftarrow \quad (40)$$

deducibilnom će postati i formula (činjenica):

$$q(a) \leftarrow \quad (41)$$

Deducibilnost činjenice (41) slijedi iz klaузуе (38), koja je - prema definiciji (36) - "dio" (ili točnije: slijedi iz) formule (35), te činjenice (40). Na analogan način bi dodavanje činjenice (41), posredstvom klaузуе (37), deducibilno učinilo činjenicu (40). No, kako je već istaknuto, takovo predstavljanje ekvivalencije ne možemo primjeniti u logičkoj bazi, jer ono zahtjeva prisustvo formula (37) i (38) u bazi, što pak znači postojanje SLDNF-drva sa beskonačnom granom.

#### b) Održavanje ekvivalencije

Drugi način shvaćanja (i predstavljanja) ekvivalencije jeste takav da u logičkoj bazi "jedan smjer" iz ekvivalencije (35) - u skladu sa definicijom (36) - izrazimo klaузуе (tj. implikativnom formulom), dok se "drugi smjer" izvorne ekvivalencije iz (35) održava, i to zabranom unosa/brisanja onih znanja, koja bi dovela do narušavanja ekvivalencije koju tvrdi (zahtjeva) formula (35). U svrhu iskazivanja zabrane upotrijebiti ćemo cilj (cilj), tj. uvjet integriteta.

Shvaćanja ekvivalencije iznesena u (a) i (b) pokušajmo dalje eksplikirati slijedećim opisima:

(a') A je istinito ako i samo ako B je istinito. Nije poznato da bi B bilo istinito. Međutim, poznato je da je A istinito. Slijedi: i B mora biti istinito.

(b') A je istinito ako i samo ako B je istinito. Nije poznato da bi B bilo istinito. Međutim, postoji tvrdnja (dedukcija) da A jeste istinito. Zaključujemo: tvrdnja A je neprihvatljiva.

Shvaćanje ekvivalencije prema (a') izgleda sledećim (uobičajenim), barem pri hipotetičkom zaključivanju, u kojem ne sumljamo u nijednu od premissa, pa prema tome nemamo ni razloga za njeno odbacivanje. No, kako je iznad obrazloženo, takvo shvaćanje ekvivalencije ne možemo izraziti (predstaviti) u modelu logičke baze.

S druge strane, u kontekstu problematike predstavljanja i procesiranja znanja, zaključivanje na način kako je to pokazano u (b'), može biti vrlo primjenljivo i korisno. Naime, u realnim situacijama, deducibilnost neke informacije (tj. znanja) iz baze znanja može biti znak da neka od premissa nije istinita. Utolikom i mogućnost predstavljanja znanja i zaključivanja u skladu sa interpretacijom ekvivalencije (b') izgleda značajnim korakom u smjeru "više od same implikacije".

Pokažimo sada kako ekvivalenciju izrečenu sa (35) i shvaćenu u skladu sa (b'), predstavljamo u logičkoj bazi znanja. Kao znanje koje ćemo predstaviti pravilom, odaberimo regularnu klaузуу (37), tj:

$$p(x) \leftarrow q(x)$$

Klaузуа (38) - koju pored klaузуе (37)! - ne smijemo unijeti u pozitivan dio znanja logičke baze, prevesti ćemo u uvjet integriteta kako slijedi:

Klaузуа (38), zajedno sa (implicitno mišljeno) univerzalnim kvantifikatorom, glasi:

$$\forall x(p(x) \rightarrow q(x)) \quad (42)$$

Transformacijom formule (42) dobivamo

$$\forall x(\neg(p(x)) \vee q(x))$$

i dalje,

$$\neg(\exists x(\neg(p(x)) \vee q(x)))$$

što konačno (po de Morganu), daje:

$$\neg(\exists x(p(x) \wedge \neg(q(x)))) \quad (43)$$

Formula (43) ima točno oblik slijedećeg cilja:

$$\leftarrow p(x) \wedge \neg(q(x)) \quad (44)$$

ili - u jeziku logičke baze - uvjeta integritet:

$$\neg p(x) \wedge \neg q(x) \quad (45)$$

Uvjet integriteta (45) zabranjuje da se baza znanja mijenja tako, da iz nje bude deducibilno  $p(x)$  za neku instancu  $x$ , za koju nije deducibilno  $q(x)$ .

Obzirom da je uvjet integriteta (45) dobiven logičkim transformacijama pravila (38), mogli bismo reći da smo u logičkoj bazi (ipak!) uspešni izraziti ekvivalenciju (35). Međutim, uvjet integriteta (45) može stanje baze samo kontrolirati (a posredstvom sistema za upravljanje bazom i automatski održavati). Stoga se iz njega (tj. njegovim posredstvom), ne mogu deducirati nova znanja u bazi, pa je utolikom i moguće ekvivalenciju predstavljati samo u skladu sa njenim shvaćanjem opisanim u (b').

Uz prisustvo uvjeta integriteta (45), ažuriranjem baze, koja bi dovelo do deducibilnosti činjenice

$$p(a)$$

da da pritom nije deducibilna i činjenica

$$q(a) \quad (46)$$

nedopušteno je, jer dovodi do nekonsistentnosti baze kao teorije. Naime, kada (46) nije deducibilno, deducibilnim postaje - prema negaciji kao 'konačnom neuspjehu dedukcije':

$$n(q(a)) \quad (47)$$

Tada pak iz (46) i (47) slijedit

$$p(a) \wedge n(q(a))$$

a time i

$$\exists x(p(x) \wedge n(q(x)))$$

Što, zajedno sa uvjetom integriteta (45) - odnosno formulom (43), kao njegovim ekvivalentom u logici prvoga reda, pokazuje nekonsistentnost logičke baze znanja.

U primjeru implementacije modela logičke baze znanja, izražavanje ekvivalencije ilustrirano je primjerom predstavljanja slijedećeg znanja:

Netko je dobra zdravila ako i samo ako je fizički aktivan i nije strastven pušač.  
(48)

Rečenicu odnosno znanje (48) mogli bismo u bazi predstaviti pravilom:

`zdravije_od(X:dobro) ako fiz_aktivan(X:da)  
i nije pušač(X:strastven).`  
(49)

i uvjetom integriteta (upitom):

?- ( zdravije\_od(X:dobro) i  
      nije fiz\_aktivan(X:da) )  
      ili  
      ( zdravije\_od(X:dobro) i  
         pušač(X:strastven) ).  
(50)

Prema upitu (50), integritet logičke baze bio bi prekršen - a time i baza učinjena logički nekonsistentna - ukoliko bi iz nje, za neku instancu c varijable X, bilo deducibilno

`zdravije_od(c:dobra)`  
(51)

a pritom ne bi bilo deducibilno

`fiz_aktivan(c:da)`

ili pak ukoliko bi bilo deducibilno (51), ali bi pritom bilo deducibilno i

`pušač(c:strastven)`

Upit (50) nije jedini način da se dati uvjet integriteta izraziti. Jednostavniji način da se to učini bio bi sa slijedeća dva upita:

?- zdravije\_od(X:dobro) i nije  
      fiz\_aktivan(X:da).  
(52)

?- zdravije\_od(X:dobro) i  
      pušač(X:strastven).  
(53)

Konjunkcija upita (tj. negiranih egzistencijalno kvantificiranih formula) (52) i (53), logički je ekvivalentna upitu (50).

Općenito, upite (tj. uvjete integriteta), kao i pravila izražavati ćemo na način (tj. u obliku) za koji smatramo da najprirodnije (najčitkije) izražava neko dato znanje. Pritom nije mišljeno da se do uvjeta integriteta dolazi for-

malnim logičkim transformacijama, kako je to ovdje učinjeno za klausulu (38). Naime, direktno izražavanje "jednog smjera" ekvivalencije u obliku uvjeta integriteta, izgleda nam dosta jednostavnim, što potvrđuje navedeni primjeri (52) i (53).

### 3.4. Redundantnost

Ekstenzijom baze znanja nazivamo skup svih činjenica, deducibilnih iz baze. Za pravilo (ili činjenicu) kažemo da je redundantno, ukoliko se njegovim upisom (ili brisanjem), eksstenzija baze znanja ne mijenja. Drugim riječima, sve što je iz baze deducibilno, deducibilno je i bez tog pravila (ili činjenice). Pravilo (ili činjenica) može biti redundantno u trenutku upisa; isto tako, redundantnim može postati zbog upisa ili brisanja nekog drugog pravila (ili činjenice).

Način provjeravanja redundantne u logičkoj bazi znanja ilustrirajmo slijedećim primjerom. Neka skup premisa (tj. baza znanja) S bude:

`p(a) <--  
q(a) <--`

Pretpostavimo da u bazu znanja želimo upisati pravilo

`q(x) <-- p(x)`  
(54)

U notaciji logike prvoga reda, pravilo glasi:

`\forall x(p(x) \rightarrow q(x))`  
(55)

Formula (55) logički je ekvivalentna formuli

`\neg\exists x(p(x) \wedge n(q(x)))`  
(56)

Koja ima točna oblik upita (cilja):

?- p(x) i nije q(x).  
(57)

Za dato stanje baze znanja, odgovor na upit (57) glasi "ne". Pri tom odgovor "ne" znači da iz skupa premisa nije deducibilno 'p(c)' za nijednu instancu c varijable x, za koju ne bi bilo deducibilno i 'q(c)'. Ukoliko i dodavanje pravila (54) bazi znanja ne bi promjenilo eksstenziju baze, te stoga kažemo da je redundantno. No, to ne znači da je sama formula (54) (ili pak (55)) deducibilna iz datog skupa premisa, već samo da njenim upisom - iz date baze znanja - ničta nova ne bi postalo deducibilnim. Naravno, naknadna mijenjanja baze znanja mogu učiniti da redundantna formula (pravilo) to više nije, kako je to ilustrirano primjerima (4) i (5). Zato i govorimo o izrađunavanju odgovor substitucija odnosno o dedukciji na nivou ekstenzije, a ne o (logičkoj) dedukciji u značenju koje taj pojam ima u kontekstu sistema standardne logike prvoga reda.

Ukoliko pravilo (54) usprkos redundantnosti upišemo u bazu znanja, onda će činjenica 'q(a) <--' postati redundantna. Naime, biti će deducibilna pomoću upisanog pravila i činjenice 'p(a) <--', te utoliko njenim brisanjem iz baze znanja ukupna eksstenzija baze ne će biti smanjena (promjenjena).

U testnoj implementaciji modela dopušteno je upisivanje redundantnih znanja, kao i zadražavanje u bazi onih znanja, koja su redundantna postala. Sistem pritom upozorava na eventualnu redundanciju (i stvorenu redundanciju), a na korisniku baze znanja je da odluči što sa tim (redundantnim) znanjima uraditi.

Specifičan problem javlja se pri pokušaju provjere redundancije negativnih znanja. Naime, kako je iznad opisano, redundanca u bazi znanja definirana je na osnovu ekstenzija. S druge strane, odgovor na upite koji su uvjeti integriteta mora - za konsistentnu bazu - uvjek glasiti "ne". Mogli bismo stoga reći da je ekstenzija - ili skup izračunatih odgovor supstitucija - za te upite uvjek prazan. To pak ujedno znači da otkrivanje redundance na temelju ekstenzija, kako je to definirano (i implementirano) za pozitivna znanja, kod uvjeta integriteta nije moguće. Stoviše, obzirom da se dedukcija metodom SLDNF-resolucije svodi na izračunavanje odgovor supstitucija, usporedba upita koji imaju praznu ekstenziju ne dade se teoretski dovoljno konzistentno ugraditi u sam logički sistem, zasnovan na kluzačkoj logici i SLDNF-resoluciji kao pravilu izvođenja. No, problem otkrivanja redundance među uvjetima integriteta manje je značajan od problema omogućavanja adekvatnog izražavanja samih uvjeta integriteta i načinjenja efikasnog nadinog provjere njihovog (ne)valjenja u datoj bazi znanja. Ti su pak problemi (tj. izražavanje i provjera) uspješno rješeni (teorijski i implementacijski), u kontekstu predloženog modela logičke baze.

Iz navedenih razloga, u datoj implementaciji modela, ilustriranog primjerima u odjeljku (4), kontrola redundance odnosi samo na pozitivna znanja (tj. pravila i binjenice).

#### 4. ILUSTRACIJA RADA SISTEMA

U svrhu ilustracije modela logičke baze znanja, navedimo nekoliko primjera rada sistema za upravljanje logičkom bazom. Implementacija sistema izvedena je u C-Prologu. Neka stanja baze znanja bude slijedeća:

##### a) Pozitivno znanje

```

krv_gr_od(petar;ab).
krv_gr_od(X;Y) ako otac_od(X;Z)
    i krv_gr_od(Z;Y).

otac_od(ivor;petar).

majka_od(mararana).

boja_oci_od(anasmeda).
boja_oci_od(X;Y) ako majka_od(X;Z)
    i boja_oci_od(Z;Y).

zdravje_od(X;dobro) ako fiz_aktivan(X;da) i
    nije pušač(X;zdrastven).

fiz_aktivan(jure;da).

pušač(petar;zdrastven).
pušač(anasmeda).

```

##### b) Hjерархија ентитета из логичке базе.

```

vrsta_od(zivotinja;zivo_bice).
vrsta_od(čovjek;zivo_bice).
vrsta_od(anasmeda).
vrsta_od(petar;čovjek).
vrsta_od(mara;čovjek).
vrsta_od(jure;čovjek).
vrsta_od(zmija;zivotinja).

```

Inanje dato u okviru definicije hijerarhije entiteta u bazi normalno se označira kao i ostale binjenice. Pritom, svojstvo 'vrsta\_od' (ako je za entitet dato), mora biti jedinstveno za svaki entitet, o čemu sistem za upravljanje logičkom bazom vodi računa.

##### c) Negativno znanje

U implementaciji logičke baze znanja, upiti su imenovani. Imenovanje uvjeta integriteta izvedeno je sa ciljem optimizacije procesiranja znanja u bazi. Naime, integratit baze provjeravamo tako da pozivamo upite, kojima su uvjeti integriteta izraženi. No, obzirom da sluiranje samo nekih svojstava može izazvati kršenje nekih uvjeta integriteta, ti se (pri provjeravanju integriteta baze), pozivaju selektivno i inkrementalno, na temelju aktualnih veza između pojedinih svojstava i pojedinih uvjeta integriteta, koja vrijede u datom stanju baze znanja. Da bi takovo pozivanje bilo moguće, svakom uvjetu integriteta pridruženo je jedinstveno име. Inače, potrebne veze date su (i održavaju se automatski), posredstvom dvaju rječnika. Nadalje, znak "?", koji upite općenito označavamo u jeziku logičke baze, nadomeštili smo izrazom "nije\_istina\_da". To je (u datom primjeru implementacije) uobičajeno sa ciljem daljnje približavanja jezika baze znanja (i komunikacijskog jezika sistema), prirodnom jeziku. Naime, uvjet integriteta izražava negiranu egzistencijalno kvantificiranu formulu. Takvu formulu čitamo:

Ne postoji vrijednosti za  $x_1, \dots, x_j$ ,  
takođe da je izraz 'izraz' istinit..

To pak možemo (još) jednostavno izreći kao:

Nije istina da 'izraz'.

Imenovani i u opisanoj notaciji izraženi,  
uvjeti integriteta (tj. negativna znanja), kojima smo se bavili u odjeljku (3), gledaju:

```

ui_boja
    nije_istina_da boja_oci_od(X;zdrastven).

ui_zdravi
    nije_istina_da zdravje_od(X;dobro) i
        pušač(X;zdrastven).

ui_zdrav2
    nije_istina_da zdravje_od(X;dobro) i
        nije fiz_aktivan(X;da).

ui_voli
    nije_istina_da voli(X;Y) i
        ja(X;čovjek) i
        ja(Y;zmija).

```

Rad sistema za upravljanje logičkom bazom znanja ilustriran je primjerima koji slijede.

##### PRIMJER 1.

Upisivanje binjenice koja je redundantna  
(tj. vedu deducibilna iz sistema).



Deducibilno je: brat\_od(jakov;stevan) (4)

Cilj: boja\_obi\_od(stevan;X)  
se unificira sa:  
boja\_obi\_od(stevan;X) ako brat\_od(stevan;Y)  
i boja\_obi\_od(Y;X) (5)

Nije deducibilno:  
brat\_od(stevan;X) i boja\_obi\_od(X;Y) (6)

Za -- brat\_od(stevan;X) -- nema nijedne  
unifikacije. (7)

Cilj: boja\_obi\_od(stevan;X)  
se unificira sa:  
boja\_obi\_od(stevan;X) ako majka\_od(stevan;Y)  
i boja\_obi\_od(Y;X) (8)

Nije deducibilno:  
majka\_od(stevan;X) i boja\_obi\_od(X;Y) (9)

Za -- majka\_od(stevan;X) -- nema nijedne  
unifikacije. (10)

Za -- boja\_obi\_od(stevan;X) -- nema drugih  
unifikacija. (11)

Cilj: boja\_obi\_od(jakov;X)  
se unificira sa:  
boja\_obi\_od(jakov;X) ako majka\_od(jakov;Y)  
i boja\_obi\_od(Y;X) (12)

Nije deducibilno:  
majka\_od(jakov;X) i boja\_obi\_od(X;Y) (13)

Za -- majka\_od(jakov;X) -- nema nijedne  
unifikacije. (14)

Za -- boja\_obi\_od(jakov;X) -- nema drugih  
unifikacija. (15)

Dedukcija ? (elem./n.)  
! : n.  
Upisati pravilo ? (d./\_.)  
! : d. (16)  
Kontrola UI OK.  
Druge promjene u LB:  
Novo stanje LB prihvatljivo ? (d/\_.)  
! : d. (17)  
Promjena izvršena  
yes

- (1) Obzirom da je ekstenzija pravila prazna, jasno je da nijedna činjenica nije deducibilna iz toga pravila za sadašnje stanje baze. Pogledajmo zašto nije deducibilna činjenica (1).
- (2) Sa tom činjenicom unifabilno je upravo upisano pravilo, ...
- (3) ... no, tada treba deducirati (djelomično instancirano) tijelo toga pravila, što iz date baze nije moguće, jer ...
- (4) ... prvi od ciljeva iz tijela deducibilan je, uz istodobno daljnje instanciranje (vezivanje) varijabli, ali ...
- (5) ... drugi nije. Naime, drugi cilj je unifabilan sa upravo upisanim pravilom, no ...
- (6) ... pokušaj dedukcije cilja (1) uz upotrebu tog pravila ...
- (7) ... ne uspijeva.
- (8) Cilj (5), kao izvedeni cilj u pokušaju dedukcije cilja (1), pokušava se zatim deducirati posredstvom drugog pravila iz baze, sa kojim je unifabilan, no ...
- (9) ... ni taj pokušaj ...
- (10) ... ne uspijeva, ...
- (11) ... time je pokušaj dedukcije cilja (1) pomoću upravo upisanog pravila (2), završio neuspjehom.
- (12) Cilj (1) pokušava se zatim deducirati pomoću drugog pravila iz baze sa kojim je unifabilan, ...

- (13) ... no, ni taj pokušaj ...
- (14) ... ne uspijeva, ...
- (15) ... time su bezuspješno iscrpljena sve mogućnosti dedukcije, tj. sva unifabilna pravila, te cilj (1) nije deducibilan iz datoga stanja baze znanja.
- (16) Redundantno pravilo smo u bazu upisali, ...
- (17) ... i novo stanje baze prihvatali.

Odit će da obrazlaganje neuspjelih pokušaja dedukcije nalazi i eksplicira redom sve grane neuspjeha na pripadnom SLDNF-drvu, za dati upit i stanje baze znanja.

---

#### PRIJMER 5.

Unosom činjenice 'boja\_obi\_od(stevan;zelen)' čini da pravilo uneseno u primjeru (4) ne буде više redundantno. U ovom primjeru data je i uspjehna dedukcija činjenica 'boja\_obi\_od(jakov;zelen)', koja prije ovoga upisa nije bila deducibilna, kako je to pokazano u primjeru (4).

I ?- itact.  
! : boja\_obi\_od(stevan;zelen).

Kontrola UI OK.  
Druge promjene u LB:

Promjena ekstenzije pravila:

boja\_obi\_od(X;Y) ako brat\_od(X;Z) i  
boja\_obi\_od(Z;Y)

Pokazati promjenu ? (d./\_.)  
! : d.

Prijašnja ekstenzija pravila:

prazna

Sadašnja ekstenzija pravila:

boja\_obi\_od(jakov;zelen)

Dedukcija ? (elem./n.)  
! : boja\_obi\_od(jakov;zelen).

Činjenica : boja\_obi\_od(jakov;zelen)  
Dedukcija:

boja\_obi\_od(jakov;zelen) slijedi iz  
brat\_od(jakov;stevan) i  
boja\_obi\_od(stevan;zelen)  
brat\_od(jakov;stevan) - činjenica u LB  
boja\_obi\_od(stevan;zelen) - činjenica u LB

Dedukcija ? (elem./n.)  
! : n.  
Novo stanje LB prihvatljivo ? (d./\_.)  
! : d.  
Promjena izvršena  
yes

---

#### PRIJMER 6.

Upis činjenice  
brat\_od(stevan;jakov) (a)

dovodi do toga da postoji upit, koji za novo stanje baze znanja, ima SLDNF-drvo sa beskonacnom granom. Prilikom kontrole integriteta baze (kao djela postupka upisivanja), sistem za

upravljanje bazom - inkrementalnim pozivanjem ciljeva, na koje upisano znanje može utjecati - nalazi takav upit. Pokušaj njegove dedukcije (tj. SLDNF-opovrgnuda) - zbog postojanja beskonačne grane - dovodi do prekoraćenja raspoloživog prostora na sistemu i do prekida pokušaja dedukcije. Obrazloženje pojedinih koraka slijedi primjeru.

```

! ?- ifact.
! : brat_od(stevan;jakov).
! Out of local stack during execution
E Execution aborted 3 (1)

! ?- loop.
(2)

Pokušaj dedukcije cilja
--- boja_obi_od(X;Y) ---
doveo je do prekoraćenja prostora!
yes (3)

! ?- sh_loop,
! : boja_obi_od(X;Y), 10. (4)

    boja_obi_od(jakov;X) slijedi iz
        brat_od(jakov;stevan) i
            boja_obi_od(stevan;X)
    brat_od(jakov;stevan) - činjenica u LB
    boja_obi_od(stevan;X) slijedi iz
        brat_od(stevan;jakov) i
            boja_obi_od(jakov;X)
    brat_od(stevan;jakov) - činjenica u LB
    boja_obi_od(jakov;X) slijedi iz
        brat_od(jakov;stevan) i
            boja_obi_od(stevan;X)
    brat_od(jakov;stevan) - činjenica u LB
    boja_obi_od(stevan;X) slijedi iz
        brat_od(stevan;jakov) i
            boja_obi_od(jakov;X)

I T D.
yes

! ?- dorule.
! : boja_obi_od(X;Y) ako brat_od(X;Z) i
    boja_obi_od(Z;Y). (5)
yes

```

- (1) U (1) Prolog interpretator javlja da je došlo do prekida pokušaja SLDNF-opovrgnuda za neki cilj, i to zbog prekoraćenja raspoloživog prostora.
- (2) Naredbom 'loop' od sistema logičke baze tražimo koji je to cilj bio.
- (3) Odgovor je dat sa (3). Da bi pri prekidu rada Prolog interpretatora bilo moguće dobivanje takvog odgovora, sistem baze znanja pamtiti zadnji cilj koji se pokušalo deducirati.
- (4) Naredbom 'sh\_loop', uz navođenje cilja dobivenog naredbom 'loop' te dubine pradjenja pokušaja SLDNF-opovrgnuda (u našem primjeru 10), eksplicitirati smo pokušaj dedukcije, koji slijedi beskonačnu (ili bar preveliku) granu SLDNF-drvenata. Iz pokazanih koraka u pokušaju SLDNF-opovrgnuda, trebalo bi biti vidljivo da je grana beskonačna, tj. da se radi o cirkularnoj definiciji, u kojoj se cilj

boja\_obi\_od(jakov;X) (6)

pokušava deducirati pomolu pravila koja se poziva na izveden cilj:

boja\_obi\_od(stevan;X) (6)

S druge strane, pokušaj dedukcije cilja (6), poziva se na cilj (b)!

- (5) Pravilo, koja je dovelo do cirkularnosti definicije, brišemo naredbom 'dorule'. Tom naredbom brišanje se vrši bez provođenja ikakvih kontrola, jer bi izvođenje kontrola (integratit i stvorene redundance), opet otkrilo cirkularnost definicije (tj. dovelo do prekida procesa).

Problem cirkularnosti definicije jedan je od otvorenih problema logičkog programiranja. Praktičko rješenje, kakvo je ovde dato izgleda zadovoljavajućim, a i ne vidi se što bi se više od toga moglo učiniti (osim, naravno, zabraniti rekurzivne definicije i uvesti hijerarhiju svojstava, kako smo već objasnili u odjeljku (3), no takvo ograničenje smatramo isuvršen rigoroznim.

Pri postojanju rekurzivnih definicija, pojava cirkularnosti najčešće ne zavisi samo o jednom (rekurzivnom) pravilu, već i o ostalom sadržaju baze znanja. Jer pravilo, koje je u ovom primjeru dovelo do cirkularnosti, bilo je u primjeru (4) redundantno; u primjeru (5) prestalo je biti redundantno, dok je cirkularnim postalo tek ovde i to upisom činjenice (a) u bazu znanja. S druge strane, analogno pravila, kojim se svojstvo 'boja\_obi\_od' definira u ovisnosti od svojstva 'majka\_obi' (dato u početnom stanju baze znanja), nede nikada dovesti do cirkularnosti. Ili točnije: nede dovesti do cirkularnosti sve dok u bazu znanja budemo upisivali iskaze (činjenice, pravila), koji su u 'realnom svijetu' - kao modelu baze-teorije - istiniti. Razlika između ta dva svojstva (u kontekstu pisutnosti rekurzivnih definicija), jeste, na primjer, što je svojstvo 'brat\_od' simetrično, dok svojstvo 'majka\_obi' nije. No, to ili slična raznjava nisu dovoljna da bi a priori mogli znati koda li neko pravilo ili činjenica dovesti do cirkularnosti definicije nekog svojstva u logičkoj bazi. U tom kontekstu, i datu rješenje, koje omogućava eksplikaciju cirkularnosti i time i promjanu (ispravak, redifiniciju) znanja iz baze znanja, izgleda operativno zadovoljavajućim rješenjem.

## PRIMJER 7.

Primjer upisa uvjeta integriteta popratiti ćemo prikazom cijelokupnog postupka upisa znanja "Sve ptice leti osim pingvina", kojeg smo detaljno analizirali u odjeljku (3.1). Positivni dio znanja pritom iskazuјemo i upisujemo kao pravilo, sa naredbom 'irule' u koraku (2). Predhodno smo za (1) unijeli dva entiteta na koja se pravilo odnosi, tako da primjer bude ilustrativniji (tj. da ekstenzija pravila ne bude prazna). Dedukcije "Iz pozitivnog djelatnosti baze znanja (pomoću činjenica (1) odnosno pravila (2)), date su u ugjet 'ans' u (3). Negativno znanje, (tj. znanje o pingvinu, kao izuzetku od pravila), upisujemo sa naredbom 'insic' u (4). Time je unešeno znanje da "pingvini ne leti". Pokušaj upisa pravila u (5) ne dopušta se, jer bi to prekršilo uvjet integriteta upisan u (4), kako to sistem (u (5)) i obrázlaže.

```

! ?- ifact.
! : vrsta_od(slavujiptica),
! : vrsta_od(pingvin:iptica). (1)

```

Kontrola UI OK  
 Druga promjene u LB  
 Novo stanje LB prihvatljivo? (d./\_.)  
 d: d.  
 Promjena izvršena  
 yes

I ?- irule.  
 I: leti(X:da) ako je(X:ptica) i  
     ni\_je(X:pingvin). (2)  
 Svojstva -- leti -- nema u rječniku. Je li nje-  
 gova vrijednost (j)edinstvena ili (v)išestrukta?  
 I: j.  
 Kontrola UI OK  
 Druga promjene u LB?  
 Novo stanje LB prihvatljivo? (d./\_.)  
 I: d.  
 Promjena izvršena  
 yes

I ?- ans.  
 I: X tako\_da leti(X:da). (3)

Odgovori:

ptica  
 slavuj

Objašnjenja? (n-torka./n.)  
 I: slavuj.

Cinjenica: slavuj  
 Dedukcija:

```
leti(slavuj:da) slijedi iz
    je(slavuj:ptica) i
    ni_je(slavuj:pingvin)
je(slavuj:ptica) slijedi iz
    vrsta_od(slavuj:ptica) i
    je(ptica:ptica)
vrsta_od(slavuj:ptica) - cinjenica u LB
NIJE deducibilno: je(slavuj:pingvin)
```

Objašnjenja? (n-torka./n.)  
 I: n.  
 yes

I ?- incic.  
 I: ui\_leti  
 I: nije\_istna\_da leti(pingvin:da). (4)

Upis izvršen  
 yes

I ?- irule.  
 I: leti(X:da) ako je(X:ptica). (5)  
 Uvjet integriteta: ui\_leti  
     nije\_istina\_da leti(pingvin:da)  
 bio bi prekršen!  
 Dedukcija bi bila:  

```
leti(pingvin:da) slijedi iz je(pingvin:ptica)
je(pingvin:ptica) slijedi iz
    vrsta_od(pingvin:ptica) i
    je(ptica:ptica)
vrsta_od(pingvin:ptica) - cinjenica u LB
```

Upis nije izvršen  
 yes

---

## 5. ZAKLJUCAK

U članku je dat prijedlog modela logičke baze znanja, koji je definiran u terminima logike i realiziran sredstvima i metodama logičkog programiranja.

Model je ilustriran primjerima rada sistema za upravljanje logičkom bazom znanja, koji je realiziran u programskom jeziku Prolog.

Predloženim modelom (i implementacijom) dat je prikaz načina predstavljanja i procesiranja znanja zasnovan na jeziku (i sistemu) logike, za koju smatramo da - u kontekstu te problematike - otvara najviše mogućnosti.

## 7. REFERENCE

- <Boj 83> Bojadžijev, D.: Herbrandov izrek: mehanično dokazovanje izrekov in relacijske baze podatkov, DP-2936, Ine. "J. Stefan", Ljubljana, 1983.
- <Bro 82> Bratko, L.: Expert Systems and PROLOG, u Sumner, F.: Supercomputer System Technology, Pergamon Infotech Ltd. State of the Art Reports, Series 10, No. 6, 1982.
- <Cla 79> Clark, K.L.: Predicate Logic as a Computational Formalism, Res. Mon. 79/59, Imperial College, London, Dept. of Computing, 1979.
- <End 76> van Endem, M.H., Kowalski, R.: The Semantics of Predicate Logic as a Programming Language, J. of the ACM, Vol.23, No.4, 1976.
- <End 78> van Endem, M.H.: Computation and Deductive Information Retrieval, u Neuhold, E. (ed): Formal Description of Programming Concepts, North-Holland, 1978.
- <Gal 84> Gallaire, H., Minker, J., Nicolas, J.: Logic and Databases: A Deductive Approach, Computing Surveys, 1984.
- <Kit 84> Kitakami, H. et al: A Methodology for Implementation of a Knowledge Acquisition System, Int. Symp. on Logic Programming, Atlantic City, 1984.
- <Kow 79> Kowalski, R.: Logic for Problem Solving, North Holland, 1979.
- <Kow 81> Kowalski, R.: Logic as a Database Language, Tech. Rep., Imperial Coll. London, Dept. of Compt. 1981.
- <Llo 84> Lloyd, J.W.: Foundations of Logic Programming, Springer-Verlag, 1984.
- <Llo 85> Lloyd, J.W., Topor, R.W.: A Basis for Deductive Database System, Tec. Rep. 85/1, Univ. of Melbourne, Dept. of Comp. Sciences, 1985.
- <Nil 82> Nilsson, J.N.: Principles of Artificial Intelligence, Springer-Verlag, 1982.
- <Per 85> Pereira, L.M., Porto, A., Dias, V.: Knowledge Systems, Tec. Rep. DI/UNL - 2/85, Univ. Nova de Lisboa, 1985.
- <Rad 86a> Radovan, M.: Model deduktivne baze podataka implementiran u Prologu, Informatica, Ljubljana, br.1, 1986.
- <Rad 86b> Radovan, M.: A Knowledge Acquisition System for Logic Database, Tec. Rep. UNL - 2/86, Univ. Nova de Lisboa, Dept. de Informatica, 1986.
- <Rob 79> Robinson, A.J.: Logic: Form and Function, Edimburg University Press, 1979.
- <Yah 85> Yahya, A., Henschen, L.J.: Deduction in Non-Horn Databases, J. of Automated Reasoning, Vol.1, No.2, 1985.

UDK: 681.3.02

Borut Robič in Jurij Šilc  
Institut Jožef Stefan, Ljubljana

V članku predstavlja razvrstitev računalniških arhitektur, parojeno iz treh načinov vodenja računanja: krmilnega, podatkovnega in vodenja z zahtovo. Opisani so ustrezni računski modeli ter njihove realizacije na različnih organizacijah stroja.

Classification of New Generation Computer Architectures - Classification of new generation computer architectures based on control driven, data driven, and demand driven computation is described. Also, we present several simple operational models and their implementations on different machine organizations.

### 1. Prolog

Ideja o računalnikih peta generacije je bila prvič predstavljena na mednarodni konferenci v Tokyu oktobra 1981. Peta generacija bo združevala rezultate raziskav na področjih umetne inteligence, programirnega inženiringa, VLSI (ULSI) tehnologije ter predvsem računalniških arhitektur. Slednje bodo zanesljivo prešle od zaporednega na sočasno izvrševanje. Na resnost teh raziskav kaže tudi dejstvo, da so od tokijske konference pa do leta 1984 ustanovili pet velikih nacionalnih oziroma regionalnih raziskovalnih programov:

- japonski, katerega usmerja ICOT (Institute for New Generation Computer Technology),  
 - ameriška DARPA (Defense Advanced Research Project Agency) in MCC (Microelectronic and Computer Technology Corporation),  
 - britanski Alveyjev program in  
 - ESPRIT (European Strategic Research Programme in Information Technology) v EGS.  
 Raziskave novogeneracijskih računalniških arhitektur so intenzivne in so porodile vrsto novih, ne-von Neumannovih principov računanja ter pridruženih organizacij stroja. V članku prikazujeva možno razvrstitev arhitektur, kot je bila predlagana v delu [Tre182a].

### ARHITEKTURA

II



Slika 1. Elementi računalniške arhitekture.

## 2. Uvod

Rezultat raziskav na področju novejših računalniških arhitektur so tri osnovne družine arhitektur, ki se razlikujejo po načinu vodenja računanja [Trel81], [Trel82a]. Ustreerne arhitekture se imenujejo krmilno vodene, podatkovno vodene ozziroma arhitekture, vodene z zahtevo. Znotraj vsake družine pa se arhitekture ločijo še po izbranem modelu računanja ter seveda po organizaciji stroja. Izraz računalniška arhitektura je torej določen s tremi elementi

`<arhitektura> ::= <vodenje računanja>, <model računanja>, <organizacija stroja> ).`

Družina krmilno vodenih arhitektur združuje tradicionalne von Neumannove računalnike skupaj z njihovimi paralelnimi različicami, kot sta na primer SIMD in MIMO arhitektura. Ostali dve družini pa združujeta novejše, visoko paralelne ne-von Neumannove arhitekture.

V nadaljevanju bo prikazana podrobnejša razdelitev računalniških arhitektur ter razlike med njimi. Bralcu bo v pomoč slika 1, kjer se oznake ob posameznih elementih arhitekture nanašajo na ustrezena poglavja v članku.

## 3. Vodenja računanja

Računanje lahko smatramo kot zaporedno ponavljanje treh faz:

- izbiranja /selection/,
- preverjanja /examination/ ter
- izvrševanja /execution/.

a) Izbiranje: v tej fazi se določi skupina ukazov programa, ki so možni kandidati za izvršitev. Izvršilo se lahko le izbrani ukazi, vendar izbor ukaza še ne zagotavlja njegove takojšnje izvršitve. Pravilo, po katerem se ukazi izbirajo, imenujemo pravilo izbiranja. Loddimo tri pravila izbiranja:

- brezpogojno /imperative selection/,
- notranje /innermost selection/ ter
- zunanje /outermost selection/.

Pri brezpogojnem izbiranju se izbere ukaz ne glede na njegovo lego v programu. Izbor se izvrši na podlagi posebnega registra (programskega stvca) ali pa na podlagi prisotnosti vseh krmilnih paketov. Notranje izbiranje izbere najgloblje gnezdenje ukaze izraza, zunanje izbiranje pa ukaze, ki ne gnezdijo v nobenem izrazu.

b) Preverjanje: v tej fazi se ugotovi, če so izbrani ukazi izvršljivi, kar pomeni, da se preveri, če so prisotne vse potrebne vrednosti operandov v izbranih ukazih. Pravilo, po katerem poteka preverjanje, imenujemo pravilo izvršitve /firing rule/. Izvršljive ukaze prevzame tretja faza računanja - izvrševanje. Če ukaz ni izvršljiv, pa ga faza preverjanja bodo si odloži, dokler ga neka kasnejša faza izbiranja zopet ne izbere, ali pa ga poskuša napraviti izvršljivega s tem, da zahteva določitev vrednosti njegovih argumentov.

c) Izvrševanje: v tej fazi se izvršljivi ukazi dejansko izvrši.

Loddimo krmilno vodeno /control driven/ računanje, podatkovno vodeno /data driven/ računanje ter računanje vodeno z zahtevo /demand driven/.

Ceprov bodo vsa tri vodenja računanja podrobno opisana v nadaljevanju, že tu omenimo, da pri podatkovnem vodenju prisotnost vseh

potrebnih operandov sproži izvrševanje ukaza, medtem ko pri vodenju na zahtevo zahteva po rezultatu sproži izvrševanje tistega ukaza, ki ta rezultat lahko priskrbi.

### 3.1. Krmilno vodenje

Krmilno vodeno računanje ima sledeče značilnosti:

- izbiranje ukazov je brezpogojno,
- preverjanje ukazov se ne izvaja in
- izvrševanje ukazov sledi neposredno po izbiranju.

Torej se ukazi izvrši takoj, ko so izbrani.

### 3.2. Podatkovno vodenje

Značilnosti podatkovnega vodenja lahko strnemo v naslednje:

- izbiranje poteka tako, da se vsakemu ukazu dodeli procesor,
- preverjanje sestoji iz sprotnega ugotavljanja prisotnosti vseh vhodnih operandov ukaza,
- izvrševanje pa sestoji iz izvršitve vseh ukazov, katerih vsi potrebni operandi so prisotni.

Torej pri podatkovno vodenem računanju ukazi pasivno čakajo na svoje vhodne operande.

### 3.3. Vodenje z zahtevo

Vodenje z zahtevo pa ima sledeče značilnosti:

- ukaz se izbere (navadno po pravilu zunanjega izbiranja) tedaj, ko nek prej izbrani ukaz zahteva njegov rezultat,
- v fazi preverjanja se ugotovi, če so izbrani ukazi izvršljivi, torej če so znane vrednosti njihovih operandov. Če vrednost operanda še ni znana, se posreduje zahteva tistem ukazu, ki ga lahko izračuna,
- izvrševanje je sestavljeno iz izvršitve vseh tistih ukazov, katerih potrebni operandi so znani.

Torej se pri vodenju na zahtevo ukaz izvrši tedaj, ko je bila podana zahteva po njegovem rezultatu.

## 4. Modeli računanja

Vodenja računanja realiziramo z različnimi modeli računanja.

Krmilno vodenemu računanju pripadajo sledeči modeli:

- z zaporednim krmilnim tokom /sequential control flow/,
- s sčasnim krmilnim tokom /parallel control flow/,
- s tokom krmilnih paketov /control flow with control tokens/.

Podatkovno vodenemu računanju pripada le model:

- s tokom podatkovnih paketov /data flow/.

Računanje, ki je vodeno z zahtevo pa je moč realizirati z dvema modeloma:

- z redukcijo izrazov /string reduction/,
- z redukcijo grafov /graph reduction/.

V vsakem modelu računanja se zrcali izvirni način vodenja računanja v obliki sprožitvenega ter podatkovnega mehanizma.

Sprožitveni mehanizem /control mechanism/ določa način, kako izvršitev nekega ukaza vpliva na izvršitev ostalih ukazov in s tem vodenje izvrševanja programa. Sprožitveni mehanizem je lahko:

- zaporeden /sequential/: ukazi se izbirajo drug za drugim in se po vrsti izvršujejo,
- sočasen /parallel/: kjer se na nek način ugotavlja prisotnost vhodnih operandov ter povzroči začetek izvrševanja tistih ukazov, ki imajo na voljo vse potrebe operande,
- rekurziven /recursive/: kjer se posreduje zahtevo po operandih ter spravi izvrševanje tistega ukaza, katerega rezultat je bil zahtevan.

S podatkovnim mehanizmom /data mechanism/ pa je določen način, po katerem si ukazi delijo skupne operande. Pri tem si lahko ukazi delijo operande s pomočjo:

- vstavljenje vrednosti /literal/: če je vrednost operanda znana že pred pričetkom računanja, se takoj vpiše v vse ukaze, ki jo uporablja,
- sprotne vrednosti /value/: kopije operanda, ki se je izračunal, se posredujejo vsem ukazom, ki jim je operand skupen,
- reference /reference/: tu vsebujejo vsi ukazi referenco (naslov) na skupen operand.

Zvezo med obema mehanizmoma ter različnimi modeli računanja prikazuje tabela 1.

#### PODATKOVNI MEHANIZEM

|                              |                                |
|------------------------------|--------------------------------|
| vstavljenje in sprotne vred. | vstavljenje vred. in reference |
|------------------------------|--------------------------------|

| S | zaporeden               | zaporedni            |
|---|-------------------------|----------------------|
| P |                         | krmilni tok          |
| M |                         | -----                |
| R |                         | -----                |
| E |                         | -----                |
| O | tok podatkovnih paketov | sočasni              |
| H |                         | -----                |
| Z |                         | krmilni tok          |
| A |                         | -----                |
| I | sočasen                 | tok krmilnih paketov |
| N |                         | -----                |
| T |                         | tok krmilnih paketov |
| I |                         | -----                |
| V |                         | -----                |
| Z |                         | -----                |
| E |                         | -----                |
| E |                         | -----                |
| N | rekurziven              | redukcija            |
| M |                         | izrazov              |
| I |                         | redukcija grafov     |

Tabela 1. Modeli računanja glede na sprožitveni in podatkovni mehanizem.

#### 4.1. Zaporedni krmilni tok

Model z zaporednim krmilnim tokom ima naslednje značilnosti:

- krmilno vodenje računanja,
- zaporedni sprožitveni mehanizem,
- podatkovni mehanizem s pomočjo vstavljenih vrednosti in referenc.

Model z zaporednim krmilnim tokom uporablja en sam procesor za računanje in programski stevec, s katerim se izbere naslednji ukaz. Torej obstaja en sam krmilni tok, ki prehaja z ukaza na ukaz in temelji na zaporednem sprožitvenem mehanizmu. Ko krmilni tok doseže ukaz, se razrešijo vse reference, kar pomeni, da se dostavijo vrednosti operandov iz naslovljenih pomnilniških lokacij. V modelu z zaporednim krmilnim tokom se torej uporablja podatkovni mehanizem z vstavljenimi vrednostmi

in referencami. Ukaz se nato takoj izvrši, saj fazi (brezpogojnega) izbiranja neposredno sledi faza izvrševanja - računanje je torej krmilno veden. Rezultat izvršitve se vpiše v skupno lokacijo. Po izvršitvi ukaza se programski stevec bodisi neposredno ali posredno ažurira, s čimer krmilni tok preide na naslednji ukaz.

Izvrševanje v modelu z zaporednim krmilnim tokom ponazarimo na stavku  $z := (x+2)*(x-y)$ , ki je predstavljen z zaporedjem ukazov, pri čemer vsak vsebuje operacijo, kateri sledijo operandi (Slika 2). Ti so bodisi vstavljeni vrednosti ali pa naslovi lokacij, kjer so shranjene vrednosti operandov. Prenosanje vrednosti med ukazi se vrši s posredjo skupnih lokacij v pomnilniku.



Slika 2. Računanje v modelu z zaporednim krmilnim tokom.

#### 4.2. Sočasni krmilni tok

Model sočasnega krmilnega toka ima sledeče značilnosti:

- krmilno vodenje računanja,
- sočasni sprožitveni mehanizem,
- podatkovni mehanizem s pomočjo vstavljenih vrednosti in referenc.

V modelu s sočasnim krmilnim tokom uporabljamo ukaza FORK za začetek sočasnega računanja ter JOIN za sinhronizacijo. Ukaz FORK i povzroči nastanek novega zaporednega krmilnega toka s pribetkom pri ukazu z naslovom i. Ukaz na naslovu i ima tedaj na voljo že vse potrebne vhodne operandne. Sočasni sprožitveni mehanizem v tem modelu ne zahteva preverjanja prisotnosti potrebnih operandov, saj je pribetek novega krmilnega toka eksplicitno določen z ukazom FORK. Krmilni tok, ki je izvršil ukaz FORK i, nadaljuje z izvrševanjem naslednjega ukaza (implicitni krmilni tok). Ukaz JOIN n zaustavi prvih n-1 krmilnih tokov, ki so prispele do njega; ko prispe do tega ukaza zadnji, n-ti krmilni tok, nadaljuje z izvrševanjem naslednjega ukaza. Ker se v tem modelu sočasno vrši nekaj zaporednih krmilnih tokov, je njegov podatkovni mehanizem enak mehanizmu v modelu z zaporednim krmilnim tokom. Seveda zahteva tak model uporabo vedjega štavila procesorjev. Primer izračuna stavka  $z := (x+2)*(x-y)$  opisuje slika 3.



Slika 3. Računanje v modelu s sočasnim krmilnim tokom.

#### 4.3. Tok krmilnih paketov

Model toka s krmilnimi paketi ima sledeče značilnosti:

- krmilno vodenje računanja,
- sočasni sprožitveni mehanizem,
- podatkovni mehanizem s pomočjo vstavljenih vrednosti in referenc.

Tudi pri modelu s tokom krmilnih paketov poteka računanje sočasno, zato ta model zahteva večje število procesorjev. Vsak ukaz hrani poleg operacije ter operandov še naslov svojega naslednika, ki bo uporabil njegov rezultat, ter prostore za krmilne pakete, ki jih prejme od svojih predhodnikov po njihovi izvršitvi. Ko ukaz zbere vse krmilne pakete, se sproži njegovo izvrševanje, pri čemer se najprej razrešijo vse referenčne ter nato izvrši operacija. Na koncu se rezultat shrani v skupno lokacijo, krmilni paket pa se posreduje vsem naslednikom ukaza. Vidimo, da je izvrševanje krmilno vodenje s sočasnim sprožitvom mehanizmom, ki ugotavlja prisotnost potrebnih krmilnih paketov. Podatkovni mehanizem pa temelji na vstavljenih vrednostih in referencah. Potek računanja stavka  $z := (x+2)*(x-y)$  je opisan na sliki 4.

#### 4.4. Tok podatkovnih paketov

Model s tokom podatkovnih paketov ima naslednje značilnosti:

- podatkovno vodenje računanja,
- sočasni sprožitveni mehanizem,
- podatkovni mehanizem s pomočjo vstavljenih in sprotnih vrednosti.

Ta model je podoben modelu s tokom krmilnih paketov, le da se tu izvrševanje odvija s pomočjo podatkovnih paketov. Ukazi sestojijo iz operacij, mest za operative ter oznak vseh ukazov, kamor naj se posreduje rezultat. Operandi so bodisi vstavljeni ali pa sprotne vrednosti, s čimer je določen podatkovni mehanizem. Ukaz se lahko prične izvrševati takoj, ko mu je zadnji izmed njegovih neposrednih predhodnikov posredoval podatkovni paket s sprotno vrednostjo, na katerega čaka. Izvrševanje je podatkovno vodenje, saj sočasni sprožitveni mehanizem v tem modelu ugotavlja prisotnost vseh potrebnih vrednosti vhodnih operandov.

V primeru toka podatkovnih paketov so programi navadno predstavljeni s pomočjo usmerjenih grafov, s katerimi je opisan tok podatkov med ukazi. Točke programskega grafa so ukazi,



Slika 4. Računanje v modelu s tokom krmilnih paketov.

povezave pa skrbijo za prenos vrednosti (podatkovnih paketov) med njimi. Točka se lahko prične izvrševati šele tedaj, ko so prisotni podatkovni paketi v vseh njenih vhodnih povezavah. Ob priteku izvrševanja točka absorbira vse svoje vhodne podatkovne pakete (s čimer ti izginejo iz vhodnih povezav), po izvršitvi pa postavi rezultat (izhodni paket) istočasno vse svoje izhodne povezave. Izhodni paketi točke so hkrati vhodni paketi neposrednih naslednikov.

Pri modelu računanju s tokom podatkovnih paketov je k vsakemu ukazu pridružen procesor, ki pasivno čaka na potrebne vhodne vrednosti. Faza izbiranja je torej kar pridružitev procesorjev vsem ukazom. Faza preverjanja sestoji iz ugotavljanja, da so prisotne vrednosti vseh vhodnih operandov, da te vrednosti niso prisotne, ostane procesor neaktiv, v nasprotnem pa jih sprejme, preide v fazo izvrševanja ter zatem posreduje rezultate vsem svojim naslednikom. Izvršitev stavka  $z := (x+2)*(x-y)$  v tem modelu kaže slika 5.

#### 4.5. Redukcija

Krmilno in podatkovno voden modeli računanja uporabljajo ukaze, katerih velikost se ne

spreminja. Modela računanja z redukcijo pa uporablja gnezданje izrazov, katerih velikost se med računanjem spreminja. Izvršitvi ukaza v krmilno ali podatkovno vodenem modelu ustreza pri redukciji uporaba /application/ funkcije nad njenimi argumenti. Programi v redukcijskem modelu so izrazi oblike  $\langle f \rangle \langle a_1, \dots, a_n \rangle$ , kjer so tako funkcija kot njeni argumenti bodisi atomi (npr. + ali 2) ali pa izrazi, sestavljeni iz atomov in izrazov. Uporaba funkcije je sestavljen iz dveh korakov:

- zahteve za dodelitev vrednosti njenim neznanim argumentom ter
- izračuna funkcije nad njimi.

Izračun funkcije se torej odloži, dokler niso dodeljene vrednosti vsem argumentom. Na primer, zahteve za dodelitev vrednosti argumentu  $a_1$ , kjer je  $a_1$  definiran z  $a_1 = \langle g \rangle \langle b_1, \dots, b_M \rangle$ , sproži nadaljnjo uporabo funkcije  $g$  nad argumenti  $b_1, \dots, b_M$ . Takšne zahteve po uporabi funkcij lahko porodijo nove zahteve, s čimer je določen rekurziven sprožitveni mehanizem.

Oditno je, da mora biti vsak argument definiran z eno samo definicijo, kar imenujemo pravilo o enkratni priveditvi /single assignment rule/. Pravimo, da se dani argument sklicuje /reference/ na svojo definicijo. Poleg tega definicija vrne pri vsaki uporabi vedno enako vrednost kar imenujemo referenčna trans-parenčnost redukcije.

Pri redukciji poteka faza izbiranja navadno



Slika 5. Računanje v modelu s tokom podatkovnih paketov.

po pravilu zunanjega izbiranja. Prosesorji se pridružijo ukazom v času faze izbiranja. Faza preverjanja pregleda argumente ukaza ter ugotovi, če je izračun možen. Če je, preide računanje v fazo izvrševanja, v kateri se ukaz izvrši ter nadomesti s svojim rezultatom. V nasprotnem primeru pa faza preverjanja izda zahtevo po nadomestitvi neznanih argumentov z znanimi vrednostmi. Takšna zahteva povzroči nastanek novih faz izbiranja, preverjanja in izvrševanja tistih ukazov, ki lahko vrnejo zahtevane vrednosti. Vsaka takšna nova faza preverjanja seveda lahko porodi zopet nove faze računanja. Ko se vsa ta povzročena računanja končajo in vrnejo prvotno zahtevane vrednosti, zadetni ukaz končno preide v fazo izvrševanja.

Lodimo dve vrsti redukcije, ki se razlikujeta po načinu obravnavanja argumentov. Pripravljajoda modela računanja se imenujeta redukcija izrazov oziroma redukcija grafov.

#### 4.5.1. Redukcija izrazov

Model z redukcijo izrazov ima sledeče značilnosti:

- vodenje računanja z zahtevo,
- rekurzivni sprožitveni mehanizem,
- podatkovni mehanizem s pomočjo vstavljenih in sprotnih vrednosti.

Zahteva za dodelitev vrednosti argumentom poteka tako, da se neatomarni argument nadomesti s kopijo definicije, na katero se sklicuje. Podatkovni mehanizem zato temelji na vstavljenih in sprotnih vrednostih. Če funkcija vsebuje več neatomarnih argumentov, se vsi nadomestite sobasno. Če so argumenti funkcije atomarni, se funkcija izrabuna in nadomesti z rezultatom. Izračuni funkcij potekajo sočasno. V tem modelu je zelo pomembno dejstvo, da se postopek nadomeščanja izvrši vsakokrat, ko se zahteva izračun argumenta. Primer redukcije izrazov pri izvrševanju stavka  $z := (x+2)*(x-y)$  je opisan na sliki 6.



Slika 6. Računanje v modelu z redukcijo izrazov.

#### 4.5.2. Redukcija grafov

Model z redukcijo grafov pa ima sledeče značilnosti:

- vodenje računanja z zahtevo,
- rekurzivni sprožitveni mehanizem,
- podatkovni mehanizem s pomočjo vstavljenih vrednosti in referenc.

Pri redukciji grafa se definiciji, na katero se sklicuje argument, doda oznaka tega argumenta. To pomeni, da podatkovni mehanizem temelji na vstavljenih vrednostih in referencah. Po uporabi funkcije v tej definiciji se njena vrednost posreduje čakajočemu argumentu, hkrati pa se tudi definicija nadomesti s to vrednostjo. Ob kasnejšem sklicevanju na tako definicijo se takoj vrne njena vrednost. To je temeljna prednost redukcije grafa napram redukciji izrazov. Primer izračuna stavke  $z := (x+2)*(x-y)$  je opisan na sliki 7.



Slika 7. Računanje v modelu z redukcijo grafov.

4.6. Povzetek lastnosti modelov računanja

Zaporedni in sočasni krmilni tok imata sledeče skupne značilnosti:

- prenos podatkov med ukazi poteka preko referenč na skupne pomnilniške lokacije,
- vrednosti operandov so lahko shranjene v samem ukazu (vstavljenje vrednosti); s tem se pohitri njegova izvršitev,
- krmilni tok je po svoji naravi zaporeden, vendar lahko kreiramo sodasne krmilne tokove z uporabo posebnih ukazov FORK in JOIN,
- krmilni tok in tok podatkov sta ločena,
- potek računanja je popolnoma določen s krmilnim tokom.

Lastnosti računanja s tokom podatkovnih paketov so:

- sprotnne vrednosti se posredujejo med ukazi neposredno, v obliki podatkovnih paketov,
- možna je uporaba vstavljenih vrednosti,
- ob pribetku izvrševanja prevzame ukaz svoje vhodne pakete, s čimer ti izginejo iz vhodnih povezav, zato jih kasneje ne more več uporabiti,
- pri izvrševanju se ne uporablja nika-kratne skupne pomnilniške lokacije za prenos podatkov, kot je to primer pri krmilnem vodenju,
- izvrševanja programa je popolnoma določeno s tokom podatkov.

Redukcija pa ima sledeće značilnosti:

- vse programske strukture, funkcije in argumenti so gnezdeni izrazi,
- pri prenašanju vrednosti se ne uporablja nika-kratne skupne pomnilniške lokacije,
- izvršitev ukaza vrne bodisi atomaren ali pa sestavljen izraz,
- po izvršitvi definicije se le-ta lahko nadomesti z izračunano vrednostjo,
- potek računanja je popolnoma definiran s tokom zahtev po izvršitvah.

Vse opisane modele računanja in njihov odnos glede na način vodenja opisuje tabela 2.

## NAMINI VODENJA

|     | krmilno      | podatkovno      | z zahtevo |
|-----|--------------|-----------------|-----------|
| R   | zaporedni    | tok podatkovnih | redukcija |
| M A | krmilni tok  | paketov         | izrazov   |
| O S | sodasni      |                 |           |
| D U |              |                 | redukcija |
| E N | krmilni tok  |                 | grafov    |
| L A | tok krmilnih |                 |           |
| I N |              |                 |           |
| J   | paketov      |                 |           |
| A   | -----        |                 |           |

Tabela 2. Načini vodenja in ustrezeni modeli računanja.

## 5. Organizacija strojev

Kot je bilo uvodoma omenjeno, pripadajo načinom vodenja računanja ustrezone društine računalniških arhitektur, ki se imenujejo krmilno vodene arhitekturi, podatkovno vodene arhitekture ter arhitekture, vodene z zahtevo. Omenjene društine izvirajo iz načinov vodenja računanja, vendar pa lahko posamezne društine razdelimo na poddržline glede na izbrani model računanja ter organizacijo stroja /machine organization/. Pod izrazom organizacija stroja razumemo način sestavljanja in medsebojnega povezovanja osnovnih računalniških materialnih

virov /resources/, kot so procesorji, pomnilniki in komunikacijske enote.

Razlikujemo tri osnovne organizacije stroja in sicer:

- centralizirano organizacijo /centralized organization/;
- organizacijo za posredovanje paketov /package communication organization/;
- organizacijo za obravnavo izrazov /expression manipulation organization/.

V nadaljevanju bomo najprej opisali vse tri omenjene organizacije stroja.

### 5.1. Centralizirana organizacija

Centralizirano organizacijo sestavljajo en procesor, pomnilnik ter vodilo med njima (Slika 8). Takšna organizacija ima v danem trenutku v programu en sam izvršujejoč se ukaz. Po izvršitvi takšnega ukaza se prične izvrševanje njegovega nadaljnjo dolžavnega naslednika, izbranega s programskim števcem. To je v resnicni tradicionalna von Neumannova arhitektura.



P ... procesor  
C ... komunikacijska enota  
M ... pomnilnik

Slika 8: Centralizirana organizacija stroja.

### 5.2. Organizacija za posredovanje paketov

Organizacijo sestavljajo tri glavne enote: procesna enota, ki združuje večje število procesorjev, pomnilniška enota ter komunikacijska enota. Enote so krožno povezane, kot to prikazuje slika 9. Med enotami se nahajajo tri vrste /pools of work/, ki opravljajo nalogo zadasnega skladitvenja paketov, kadar je to potrebno. Izvrševanje programa v takšni organizaciji poteka v obliki enosmernega krožnega toka paketov skozi njene enote. Enote delujejo sodno, torej je izvrševanje programa cevljeno /pipelined/. Paketi, ki so pripravljeni za obdelavo v eni izmed enot, dakej v ustreznih vrstih, vse dokler jih ustrezena enota ni pripravljena sprejeti. Ko jih ta enota obdelava, shrani tako spremenjene pakete v vrsto pred naslednjo enoto.

### 5.3. Organizacija za obravnavo izrazov

Takšno organizacijo sestavljajo enaki osnovni gradniki, med seboj povezani v pravilno strukturo /regular structure/. Vsak gradnik sestavlja tri enote: procesor, pomnilnik in komunikacijska enota. Slednja skrbi za povezavo med procesorjem, pomnilnikom ter sosednjimi gradniki. Dve znanih strukturi takšne organizacije, vektorsko in drevesno, prikazuje slika 10. V takšni organizaciji se obravnavata programi kot gnezdeni izraz. Podizrazi so pridruženi gradnikom, pri čemer se podizrazi pridruži tistemu gradniku, ki zrcali leto podizraza v izrazu. Med izvrševanjem vsak gradnik pregleda svoj pridruženi podizraz ter ugotovi, kaj mu je storiti.



P ... procesor  
C ... komunikacijska enota  
M ... pomnilnik  
Q ... vrsta

Slika 9: Organizacija stroja za posredovanje paketov.



(a)



P ... procesor  
C ... komunikacijska enota  
M ... pomnilnik

Slika 10: Organizacija stroja za obravnavo izrazov; a) vektorska, b) drevesna.

## 6. Arhitekture

V tem poglavju bomo pokazali, kako lahko različne organizacije stroja podpirajo posamezne modele računanja. Povedano drugade, tri osnovne družine arhitektur bomo razdelili na poddružine, kot je prikazano v tabeli 3.

| družine arhitektur | model računanja         | organizacija stroja                 |
|--------------------|-------------------------|-------------------------------------|
| krmilno vodene     | zaporedni krmilni tok   | centralizirana obravnavna izrazov   |
|                    | sočasni krmilni tok     | posredovanje paketov                |
| podatkovno vodene  | tok podatkovnih paketov | posredovanje paketov                |
|                    | tok podatkovnih paketov | obravnavna izrazov                  |
| vodene z zahtevo   | redukcija izrazov       | obravnavna izrazov                  |
|                    | redukcija grafov        | obravnavna izrazov                  |
| vodene z zahtevo   | redukcija izrazov       | centralizirana posredovanje paketov |
|                    | redukcija grafov        | posredovanje paketov                |

Tabela 3. Razdelitev računalniških arhitektur.

### 6.1. Krmilno vodene arhitekture

#### 6.1.1. Zaporedni krmilni tok na centralizirani organizaciji

Najnaravnnejši kandidat za podporo zaporednega krmilnega toka je centralizirana organizacija stroja. Krmilni tok določa programski stevec v procesorju, ki zaporedno naslavlja ukaze, ki so na vrsti za izvršitev. Procesor takšne ukaze drugega za drugim, tj. zaporedno, izvršuje. Ker ta zveza doloda znano von Neumannovo arhitekturo, je na tem mestu ne boma podrobneje opisovali.

#### 6.1.2. Sočasni krmilni tok na organizaciji za obravnavno izrazov

Sočasni krmilni tok, pri katerem uporablja mo ukaza FORK in JOIN, podpira organizacijo za obravnavno izrazov. Zaporedni krmilni tokovi, ki se vršijo sočasno, potekajo v različnih gradnikih te organizacije. Krmilni tok, ki poteka v enem gradniku, lahko porodi nov krmilni tok v nekem drugem gradniku. Ko gradnik A prične izvrševati ukaz FORK i, sporoči (preko komunikacijske enote) tistemu gradniku B, v katerega pomnilniku se nahaja ukaz z naslovom i, naj prične z izvrševanjem svojega programa pri tem ukazu. V primeru, ko v B že poteka nek krmilni tok, A odloži izvršitev operacije FORK i, dokler se krmilni tok v B ne izteče. Tedaj se lahko izvrši ukaz FORK i, torej se pribne krmilni tok v B pri ukazu i, gradnik A pa lahko nadaljuje izvrševanje, narekovano z

lastnim krmilnim tokom. Gradnik, v katerem je krmilni tok prispeval do ukaza JOIN n, se zaustavi vse dotlej, dokler se v n-1 gradnikih ne izteče zadnji med porojenimi krmilnimi tokovi.

#### 6.1.3. Tok krmilnih paketov na organizaciji za posredovanje paketov

Krmilno voden model računanja s tokom krmilnih paketov pa je mogoč realizirati na organizaciji za posredovanje paketov. Arhitektura ima zgradbo, kot jo prikazuje slika 11.



Slika 11. Tok krmilnih paketov na organizaciji za posredovanje paketov

Program se nahaja v pomnilniški enoti /memory unit/. Enota za zbiranje /matching unit/ hrani za vsak ukaz program:  
- enotico doslej zbranih krmilnih paketov ukaza

- naslov ukaza v pomnilniški enoti.

Ko enota za zbiranje zbere vse potrebne krmilne pakete danega ukaza, pošlje njegov naslov preko vrste naslovov ukazov /instruction address pool/ v enoto za dostavo in vpis /fetch & update unit/. Ta enota prenese iz pomnilniške enote naslovljeni ukaz, razreši referenca ter sestavi ukazni paket. Le-ta vsebuje operacijo, vrednosti operandov ter naslove ukazov, ki pribakujejo rezultat. Ukazni paket se preko vrste ukaznih paketov /executable instructions pool/ prenese v procesno enoto. Ko se ukaz izvrši, se sestavijo podatkovni ter krmilni paketi. Podatkovni paketi nosijo rezultat ter naslov ukaza, ki daka nanj in se preko vrste podatkovnih paketov /data pool/ posljejo v enoto za dostavo in vpis, ki rezultate vpiše v naslovljene lokacije pomnilniške enote. Krmilni paketi pa se preko vrste krmilnih paketov /control token pool/ posredujejo enoti za zbiranje.

### 6.2. Podatkovno vodene arhitekture

#### 6.2.1. Tok podatkovnih paketov na organizaciji za posredovanje paketov

Model računanja s tokom podatkovnih paketov običajno realiziramo na organizaciji za posredovanje paketov. Takšno arhitekturo imenujemo podatkovno pretokovna arhitektura /data flow architecture/. Lotimo dve vrsti podatkovno pretokovnih arhitektur:

- arhitektura s shranjevanjem paketov /token store/;
  - arhitektura z zbiranjem paketov /token matching/.
- Prikazani sta na sliki 12 in sliki 13.

#### 6.2.1.1. Podatkovno pretokovna arhitektura s shranjevanjem paketov



Slika 12. Podatkovno pretokovna arhitektura s shranjevanjem paketov.

Pomnilniška enota /memory unit/ vsebuje ukazne pakete, ki vsebujejo operacijo, prostore za operande ter naslove na njegov rezultat dakovojih ukaznih paketov. Enota za vpis /update unit/ hrani naslov vsakega ukaznega paketa ter število operandov, ki jih mora biti prejeti, da bo postal izvršljiv. Pri tej arhitekturi se podatkovni paketi, ki jih sestavljajo procesna enota /processing unit/, posredujejo preko vrste s podatkovnimi paketi /data token pool/ v enoto za vpis. Vsak podatkovni paket vsebuje poleg rezultata tudi naslov dakovjega ukaznega paketa v pomnilniški enoti. Enota za vpis shrani rezultat prispevaja podatkovnega paketa v dakovodi ukazni paket v pomnilniški enoti ter zmanjša število operandov, ki jih mora ta paket biti prejeti. Če enota za vpis ugotovi, da je ukazni paket prejel zadnjega izmed potrebnih operandov, pošlje naslov paketa preko vrste naslovnih ukaznih paketov /instruction address pool/ enoti za dostavo /fetch unit/. Ta enota nato takoj prenese ukazni paket preko vrste ukaznih paketov /executable instruction pool/ v procesno enoto, kjer se ukaz izvrši. Podatkovni paketi, ki so rezultat izvršitve ukaza, se nato zopet posredujejo enoti za vpis.

Opomba: Izvrševanje, pri katerem enota za dostavo prenese izvršljiv ukazni paket v procesno enoto takoj, ko iz enote za vpis prejme njegov naslov, imenujemo takojenje izvrševanje. S predhodno analizo programskega grafa pa lahko dobimo določeno informacijo, ki služi enoti za dostavo pri izbiranju in prenašanju izvršljivih paketov v procesno enoto. Enota za dostavo lahko tedaj počaka s prenosom na trenutek, ki je najbolj ugoden. Tem je lahko omogočeno izvrševanje dosti 'večjih' programov, ne da bi se minimalni možni čas, potreben za njihovo izvrševanje, podaljšal. Omenjena analiza je podrobno opisana v [Robi86a, Robi86b].

Projekti Podatkovno pretokovno arhitekturo s shranjevanjem paketov so realizirali na MIT-ju pod vodstvom J.B. Dennisa [Denn83]. Druga realizacija te arhitekture je DDP (Distributed Data Processor), izdelan v Texas Instruments [Corn79]. Zanimivo je, da podpira DDP programski jezik Fortran 66. Omenimo še francoski projekt LAU (Language à Assignment Unique), ki poteka v CERT laboratoriju, Toulouss [Comt79, Comt80].

#### 6.2.1.2. Podatkovno pretokovna arhitektura z zbiranjem paketov



Slika 13. Podatkovno pretokovna arhitektura z zbiranjem paketov

Pri tej arhitekturi se podatkovni paketi, ki so prispeli iz procesne enote, ne shranijo neposredno v ukazni paket, kateremu so namenjeni. Namesto tega se podatkovni paketi malagajo v množice, ki se nahajajo v enoti za zbiranje /matching unit/ paketov. Vsaka množica je preko pridruženega naslova pripojena ukaznemu paketu, ki se nahaja v pomnilniški enoti /memory unit/. Ko se množica napolni (prejme zadnji potreben podatkovni paket), se preko vrste množic podatkovnih paketov /token sets pool/ prenese v enoto za dostavo in vpis /fetch & update unit/. Ta enota prenese iz pomnilniške enote kopijo naslovljenega ukaznega paketa, ga dopolni s prispevoma množico podatkovnih paketov, ter ga preko vrste ukaznih paketov /executable instruction pool/ pošlje v procesno enoto /processing unit/. Tu se ukaz izvrši, podatkovni paketi, ki so rezultati izvršitve, pa se zopet prenesejo v enoto za zbiranje paketov.

Opomba: Podobno kot v prejšnji arhitekturi, lahko tudi tu izvršljive ukazne pakete zadržujejo, le da v tem primeru vrši zadrževanje enota za zbiranje.

Projekti: Realiziranih je več projektov, med katerimi omenimo Manchester Data Flow Computer, ki so ga izdelali pod vodstvom I. Watsona in J.R. Gurd na univerzi v Manchesteru [Wat879, Gurd83, Gurd85]. Razširjena razlitica EXMAN (EXtended MANchester Data Flow Computer) je predlagana v [Patn86]. Tretji projekt poteka na univerzi v Newcastleu, kjer gradijo računalnik JUMBO [Treli82c]. Omenimo še Id (Irvin Dataflow Machine) projekt, zabit na kalifornijski univerzi v Irvinu, ki se trenutno nadaljuje na MIT-ju [Arvi80] in ga vodi Arvind.

### 6.2.2. Tok podatkovnih paketov na organizaciji za obravnavo izrazov

Tok podatkovnih paketov je moč realizirati tudi na organizaciji za obravnavo izrazov. Ko procesor v nekem gradniku prejme podatkovni paket preko komunikacijske enote iz drugega gradnika, vstavi vrednost, ki jo nosi paket v ukaz, kateremu je namenjena. V naslednjem koraku procesor ugotovi, če je ukaz izvršljiv, ter ga v tem primeru izvrši ter pošlje podatkovni paket, v katerem se nahaja rezultat, preko komunikacijske enote tistemu gradniku, v katerem se nahaja ukaz, ki ta rezultat pritakuje. Če pa ukaz še ni izvršljiv, se procesor povrne v stanje čakanja.

Projekti: Data-Driven Machine #1 (DDM1) je primer arhitekture, ki temelji na toku podatkovnih paketov, realiziranem na drevesni organizaciji za obravnavo izrazov [Davi78]. DDM1 so izdelali pod vodstvom A. Davisa na Burroughs Interactive Research Center, La Jolla, California.

### 6.3. Z zahtevo vodenje arhitekture

#### 6.3.1. Redukcija izrazov na organizaciji za obravnavo izrazov

Model z redukcijo izrazov je naravno podprt z organizacijo za obravnavo izrazov [Tre182b]. Kot smo že omenili, so programi v takšnem modelu računanja gnezdeni izrazi. Glavni gnezdeni izraz je porazdeljen po pomnilniških enotah gradnikov organizacije tako, da sta sosedna podizraza vpisana v pomnilniških enotah dveh sosednjih gradnikov. Med izvrševanjem se izraz bodisi širi (pri vstavljanju definicij, na katere se operandi sklicujejo) ali pa krči (pri nadomestitvah izračunljivih podizrazov z njihovimi rezultati). Ko procesor pregleda podizraz v lastni pomnilniški enoti ter najde v njem nek še neizračunani operand, zahteva preko komunikacijske enote prenos definicije, na katero se operand sklicuje. Po prihodu zahtevane definicije (preko komunikacijske enote) se povzroči premik ostalega izraza v stran, s čimer se napravi prostor za vstavitev prispevke definicije. Pri takšnih premikih lahko seveda preidejo podizrazi iz ene pomnilniške enote v drugo (v drug gradnik). Če pa procesor ugotovi, da je podizraz v njegovi pomnilniški enoti reducibilen (da so vsi operandi operacije znani), ga izračuna ter nadomesti z rezultatom. Posledica takšne redukcije je lahko krtenje celotnega izraza ter s tem premik delov izraza iz ene pomnilniške enote v drugo. Funkcija, ki jo pri računanju opravlja zaporedje pomnilniških enot je torej podobna funkciji dvosmernega premikalnega registra. Ker ima lahko nek podizraz več operandov, ki se sklicujejo na svoje definicije, in ker je ugodno, če se takšni operandi nadomesti z njimi sodobno (kar pa se lahko izvrši le v različnih gradnikih), morajo biti kapacitete pomnilniških enot primerno majhne. Visoka stopnja sodobnosti pri računanju je torej zagotovljena ob zadostnem številu gradnikov ter primerno majhni kapaciteti pomnilniških enot.

Projekti: Omenimo dve realizirani arhitekturi in sicer Newcastle Reduction Machine [Tre180] ter North Carolina Cellular Tree Machine [Mago80], ki ima drevesno organizacijo stroja.

#### 6.3.2. Redukcija grafov na organizaciji za obravnavo izrazov

Tudi model z redukcijo grafov je moč realizirati na organizaciji za obravnavo izrazov [Trau85]. Graf se pred izvrševanjem sveisno porazdeli na gradnike (pomnilnike). Izračuni definicij potekajo v gradnikih, kjer so definicije argumentov, rezultati pa se posredujejo gradnikom, ki so posredovali zahtevo. Zato gradnik skupaj z zahtevo pošlje tudi svoj naslov, ki se vpiše v definicijo argumenta.

Za realizacijo te arhitekture je primernejša organizacija stroja, kjer vsebujejo gradnike in procesor in komunikacijsko enoto, pomnilnik pa je združen. Deli pomnilnika so bodisi vnaprej dodeljeni gradnikom, ali pa je celoten pomnilnik skupen za vse gradnike.

#### 6.3.3. Redukcija grafov na organizaciji za posredovanje paketov

Pri redukciji je močno uporabiti organizacijo za posredovanje paketov le v modelu z redukcijo grafov. Izvrševanje programa na takšni organizaciji poteka z dvema vrstama paketov:

- paketi z zahtevo /demand token/,
- paketi z rezultatom /result token/.

Paket z zahtevo vsebuje:

- naslov ukaza, ki lahko izračuna zahtevano vrednost,
- naslov ukaza, ki je zahteval to vrednost.

Paket z rezultatom pa vsebuje:

- rezultat izvršitve ukaza,
- naslov ukaza, ki je ta rezultat zahteval. Če operandi ukaza, katerega izvršitev je bila predhodno zahtevana, še niso znani, pošlje tak ukaz pakete z zahtevo vsem tistim ukazom, ki lahko te vrednosti izračunajo. Ko ukaz sprejme paket z zahtevo, se izvrši (pred tem se lahko postopek posiljanja paketov z zahtevami ponovi), ter pošlje paket z rezultatom ukazu, ki ga je zahteval. Tedaj se lahko tudi ta ukaz izvrši. Sočasni sprožitveni mehanizem je določen z dvema praviloma:

- za sprožitev ukaza je potreben natanko en paket z zahtevo,
- za izradun ukaza morajo biti na voljo vsi potrebni paketi z rezultati.

Projekti: Značilen predstavnik je AMPS (Utah Applicative Multiprocessing System), zgrajen na univerzi v Utahu [Kell79]. Omenimo tudi projekta na Imperial College v Londonu [Darl81] ter na univerzi East Anglia [Slee81].

#### 6.3.4. Redukcija izrazov na centralizirani organizaciji

Pri realizaciji modela z redukcijo izrazov imajo enote v centralizirani organizaciji sledede značilnosti:

- pomnilniška enota združuje določeno število skladov /stack/, med katerimi se ponavljajo prenosa izraz,
- procesna enota skrbi za prenos trenutnega izraza iz zadetnega /source/ skладa v končni /sink/ sklad. Pri prenemanju izraza procesna enota razpoznavata njegove reducirne podizraze, jih sproti izračunava (reducira) ter namesto njih shranjuje v končni sklad njihove rezultate. Po prenosu celega izraza prevzame končni sklad naloge zadetnega in obratno. Prenemanje se ponavlja vse dokler ni izraz atomaren,

- komunikacijska enota je vodilo, po katerem se prenašajo izrazi iz začetnega sklada v procesno enoto in iz te v končni sklad.

Vsek izraz (in s tem tudi glavni izraz - program) je zapisan v prefiksnih oblikah, pri čemer so v taki obliki zapisani tudi vsi njegovi podizrazi. Pri prenosu izraza iz začetnega sklada v končni se mora takšna oblika ohraniti, zato navadno prenos poteka preko dodatnega, vmesnega /intermediate/ sklada.

**Projekti:** Primer takšne arhitekture je GMD (Gesellschaft für Mathematik und Datenverarbeitung), ki so jo realizirali v Bonnu, ZRN [Klug79].

## 7. Zakljuek

Predstavljena razdelitev novogeneracijskih arhitektur je le ena iz vrste možnih razdelitev. Kot je že bilo omenjeno, je pri tej razdelitvi osnovno vodilo vodenje računanja. Marsikatera realizirana arhitektura težko najde mesto v eni sami predlagani podprtžini (poglavje 6), saj je v novejših arhitekturah pričakovati različne kombinacije podatkovnega in sprožitvenega mehanizma, s tem pa tudi mešanih modelov računanja ter vodenja. Omenimo vzorčno vodenje /pattern driven/ računanja, kjer se ukaz pribne izvrševati, ko pride do ujemanja vzorca, ki je pogoj za pridetelek izvrševanja [Treli84]. Pojavljajo se tudi kompleksnejše organizacije stroja. Kot ilustracijo navedimo le dva najnovejša podatkovno pretokovna računalnika: SIGMA-1 [Shim86] in večprocesorski podatkovno pretokovni sistem na osnovi procesorjev µPD7281 [Jeff85, Silc86]. V obeh primerih gre za organizacijo stroja, ki je podobna organizaciji za obravnavo izrazov, le da so gradniki podatkovno pretokovni procesorji, katerih organizacija temelji na posredovanju paketov.

Računalniške arhitekture je mod razdeliti tudi z dveh drugih, diametralnih zornih kota: z vidika jezikov oziroma strojne opreme.

Tako obstaja razdelitev novejših računalniških arhitektur, temeljedih na visokih programirnih jezikih /high level language computer architectures/. Takšna razdelitev je podana v [Milu86] in jo prikazuje slika 14.

Seprav ni namen članka predstavitev takšne razdelitev arhitektur, pa vendarle omenimo skupino reduciranih arhitektur, med katere sodijo IBM 801, RISC (UC Berkely), MIPS (Stanford), RIMMS (univerza Reading), Transputer (Inmos) ter VM (Purdue). Osnova teh arhitektur je strojno realiziran nabor najpogosteje prisotnih ukazov v pravedeni kodri programov (RISC nabor). Redkeje uporabljeni ukazi se nadomestijo z ustreznimi zaporedji ukazov iz RISC nabora [Fatt85].

Za konec omenimo še dve možni delitvi arhitektur z drugega zornega kota, to je na osnovi strojne opreme. Morda najpogosteje delitev računalniških arhitektur je po Flynnnu [Flynn72], ki jih deli v štiri skupine:

- SISD (en ukazni tok in en podatkovni tok) /single instruction stream & single data stream/,
- SIMD (en ukazni tok in več podatkovnih tokov) /single instruction stream & multiple data stream/,
- MISD (več ukaznih tokov in en podatkovni tok) /multiple instruction stream & single data stream/ ter
- MIMD (več ukaznih tokov in več podatkovnih tokov) /multiple instruction stream & multiple data stream/.



Slika 14. Razdelitev računalniških arhitektur, temeljedih na visokih prog. jezikih.

Shoreova delitev [Shor73] pa obsega šest razredov računalniških arhitektur glede na zdrževanje materialnih virov, kot so procesne enote PE /processing units/, kreilne enote KE /control units/, ukazni pomnilniki UP /instruction memories/ in podatkovni pomnilniki PP /data memories/. Teh šest razredov je:

- stroj I: so klasične von Neumannove arhitekture, z možnostjo cevljenja v PE,
- stroj II: je podoben stroju I, le da se sošasno dostavijo bitne rezine /bit slice/ vsah besed iz PP; torej v nasprotju s strojem I, stroj II obdeluje besede 'prečno' in ne 'vzdolžno',
- stroj III: je kombinacija prvih dveh strojev, zato lahko obdeluje besede bodisi 'prečno' ali 'vzdolžno',
- stroj IV: je arhitektura, ki preko ene KE zdržuje enočico parov PE in PP, kjer PE-ji nimajo možnosti medsebojne komunikacije,
- stroj V: je podoben stroju IV, pri čemer lahko vsak par PE in PP komunicira s svojima sosednima paroma, ter
- stroj VI: za razliko od strojev I do V, kjer je PE lozen od PP, so tu funkcije PE in PP združene v eni sami enoti /logic-in-memory array/.

## 8. Ključne besede

### C

cevljene /pipelining/, 5.2, 7

### E

enota /unit/

- komunikacijska /communication \*/, 5.3, 6.3.1, 6.3.2
- krmilna /control \*/, 7
- poamnilniška /memory \*/, 6.1.3, 6.2.1.1, 6.2.1.2, 6.3.1
  - podatkovna /data \*\*/, 7
  - ukazna /instruction \*\*/, 7
- procesna /processing \*/, 6.1.3, 6.2.1.1, 6.2.1.2
- za dostavo /fetch \*/, 6.2.1.1
- za dostavo in vpis /fetch & update \*/, 6.1.3, 6.2.1.2,
- za vpis /update \*/, 6.2.1.1,
- za zbiranje /matching \*/, 6.1.3, 6.2.1.2

### G

gnezden izraz /nested expression/, 4.5, 5.3, 6.3.1, 6.3.4

### I

izbiranje /selection/, 3

- brezpogojno /imperative \*/, 3
- notranje /innermost \*/, 3
- zunanjé /outermost \*/, 3

izvrševanje /execution/, 3

### M

materijalni vir /hardware resource/, 5, 7

mehanizem /mechanism/, 4

- podatkovni /data \*/, 4
  - s sprotno vrednostjo /\*\* with value/, 4
  - z referenco /\*\* with reference/, 4
  - z vstavljeni vrednostjo /\*\* with literal/, 4
- sprožitveni /control \*/, 4
  - rekurziven /recursive \*\*/, 4
  - sočasen /parallel \*\*/, 4
  - zaporeden /sequential \*\*/, 4

modeli računanja /operational model/, 4, 4.6

### O

organizacija stroja /machine organization/, 5

- centralizirana /centralized \*\*/, 5, 5.1
- za obravnavo izrazov /expression manipulation \*\*/, 5, 5.3
- za posredovanje paketov /package communication \*\*/, 5, 5.2

### P

paket /taken/

- krmilni /control \*/, 6.1.3
- podatkovni /data \*/, 4.4, 6.1.3, 6.2.1.1, 6.2.1.2, 6.2.2
- ukazni /instruction \*/, 6.1.3, 6.2.1.1, 6.2.1.2
- z rezultatom /result \*/, 4.4, 6.3.3
- z zahtevo /demand \*/, 6.3.3

pravilna struktura /regular structure/, 5.3

- vektorska /array \*/, 5.3
- drevesna /tree \*/, 5.3

pravilo /rule/

- izvršitve /firing \*/, 3
- o enkratni priveditvi /single assignment \*/, 4.5

preverjanje /examination/, 3

programski graf /program graph/, 4.4

### R

radunalniška arhitektura /computer architecture/, 2, 6, 7

- krmilno voden /control driven \*/, 6.1
- MIMD /multiple instruction stream & multiple data stream/, 7
- MISD /multiple instruction stream & single data stream/, 7
- podatkovno voden /data driven \*/, 6.2
  - podatkovno pretokovna /data flow \*/, 6.2.1
    - s shranjevanjem paketov /\*\* with token store/, 6.2.1.1
    - z zbiranjem paketov /\*\* with token matching/, 6.2.1.2
- SIMD /single instruction stream & multiple data stream/, 7
- SISD /single instruction stream & single data stream/, 7
- temeljeda na visokem jeziku /high level language \*/, 7
  - jezikovno usmerjena /language directed \*\*/, 7
  - jeziku prirejena /language corresponding \*\*/, 7
- kompleksna /complex \*\*/, 7
- reducirana /reduced \*\*/, 7
  - s posrednja izvrševanjem /indirect execution \*/, 7
  - s programskim prevajanjem /translation in software \*\*/, 7
  - s strojnimi prevajanjema /translation in hardware \*\*/, 7
  - z neposrednim izvrševanjem /direct execution \*\*/, 7
- voden z zahtevo /demand driven \*/, 6.3

računanje /computation/, 3

- krmilno voden /control driven \*/, 3, 3.1
- podatkovno voden /data driven \*/, 3, 3.2
- voden z zahtevo /demand driven \*/, 3, 3.3
- vzorčno voden /pattern driven \*/, 7

redukcija /reduction/, 4, 4.5

- grafov /graph \*/, 4, 4.5.2
- izrazov /string \*/, 4, 4.5.1

RISC - radunalnik z omejenim naborom ukazov /reduced instruction set computer/, 7

### S

sklad /stack/, 6.3.4

- končni /sink \*/, 6.3.4
- vmesni /intermediate \*/, 6.3.4
- začetni /source \*/, 6.3.4

sklic /reference/, 4.5

### T

tok /flow/

- krmilni /control \*/, 4
  - s kraljnimi paketi /\*\* with control tokens/, 4, 4.3
  - sočasni /parallel \*\*/, 4, 4.2
  - zaporedni /sequential \*\*/, 4, 4.1
- podatkovnih paketov /data \*/, 4, 4.4

### U

uporaba funkcije /function application/, 4.5

### V

vrsta /pool of work/, 5.2

- krmilnih paketov /control token \*/, 6.1.3
- enotič podatkovnih paketov /taken sets \*/, 6.2.1.2
- naslovov ukazov /instruction address \*/, 6.1.3, 6.2.1.1

- podatkovnih paketov /data token #/, 6.1.3, 6.2.1.1, 6.2.1.2
- ukaznih paketov /executable instruction #/, 6.1.3, 6.2.1.1, 6.2.1.2

Pripis: Pri prevajanju angleških izrazov sva nekajkrat ubrala nekoliko svobodnejšo pot, predvsem takrat, ko bi dobesedni prevod slabo opisoval dotedjni predmet. Upava, da sva imela pri izbiri slovenskih izrazov sredno roko.

## 9. Literatura

- [Arvi80] Arvind, Kathail V., Pingali K. "A Processing Element for a Large Multiprocessor Dataflow Machine", Proc. Int'l. Conf. Circuits and Computers, New York, Oct. 1980.
- [Back78] Backus J. "Can programming be liberated from the von Neumann style? A functional style and its algebra of programs", Comm. ACM Vol.21, No.8, Aug. 1978, pp.613-641.
- [Berk71] Berkling K.J. "A computing machine based on tree structure", IEEE Trans. Computer, Vol.C-20, No.4, Jan. 1971, pp.404-418.
- [Bish86] Bishop P. Fifth Generation Computers, Concepts, implementations and uses, Ellis Horwood, 1986.
- [Braj86] Brajak P. "Paralelno procesiranje: arhitektura 90-tih godina", Zbornik jugoslavenskog savjetovanja o novim generacijama računala, MIPRO 86, Rijeka, Maj 1986, str.33-46.
- [Corn79] Cornish M. "The TI Data Flow Architectures: The Power of Concurrency for Avionics", Proc. 3rd Conf. Digital Avionics Systems, Fort Worth, Texas, Nov. 79, pp.19-25.
- [Comt79] Comte D., Hifdi N. "LAU Multiprocessor: Microfunctional Description and Technological Choices", Proc. 1st European Conf. Parallel and Distributed Processing, Toulouse, France, Feb. 1979, pp.8-15.
- [Comt80] Comte D., Hifdi N., Syre J.C. "The Data Driven LAU Multiprocessor System: Results and Perspectives", Proc. IFIP 80 Congress, Oct. 1980.
- [Davi78] Davis A.L. "The Architecture and System Method of DDM1: A Recursively Structured Data Driven Machine", Proc. 5th Ann. Symp. Comp. Arch., Palo Alto, Calif., April 3-5, 1978, pp.210-215.
- [Davi82] Davis A.L., Keller R.M. "Data Flow Program Graphs", Computer, Vol.15, No.2, Feb. 1982, pp.26-41.
- [Darl81] Darling J., Reeve M. "ALICE: A Multiprocessor Reduction Machine for the Parallel Evaluation of Applicative Languages", Proc. Int'l Symp. Functional Programming Languages and Computer Architecture, June 1981, Göteborg, Sweden, pp.32-62.
- [Denn74] Dennis,J.B., Misunas,D.P. "A Computer Architecture for highly parallel signal processing", Proc.1974 Nat. Computer Conf., AFIPS Press, Arlington, Va.,1974,pp.402-409.
- [Denn83] Dennis J.B., Lim W.Y-P., Ackerman W.B. "The MIT Data Flow Engineering Model", Information Processing 83, R.E.A. Mason (ed.), Elsevier Scince Publishers B.V. (North-Holland), 1983.
- [Flyn72] Flynn M.J. "Some Computer Organizations and their Effectiveness", IEEE Trans. Comp. Vol.C-21, No.9, Sept. 1972, pp.948-960.
- [Gilo83] Giloi W.K. "Towards a Taxonomy of Computer Architecture Based on the Machine Data Type View", The 10th Ann. Int'l Symp. Comp. Arch., June 13-17, 1983, Stockholm, Sweden, pp.6-13.
- [Gurd83] Gurd J.R., Watson I. "Preliminary Evaluation of a Prototype Dataflow Computer", Information Processing 83, R.E.A. Mason (ed.), Elsevier Scince Publishers B.V. (North-Holland), 1983.
- [Gurd85] Gurd J.R., Kirkham C.C., Watson I. "The Manchester Prototype Dataflow Computer", Comm. ACM, Vol.28, No.1, Jan. 1985, pp.34-52.
- [Jeff85] Jeffery T. "The μPD7281 Processor", Byte, November 1985, pp.237-246.
- [Kapa84] Kapauan A., Field J.T., Gannon D.B., Snyder L. "The Pringle Parallel Computer", The 11th Ann. Int'l Symp. Arch., June 5-7, 1984, Ann Arbor, Michigan, pp.12-20.
- [Kell79] Keller R.M. et.al. "A Loosely Coupled Aplicative Multiprocessing System", Proc. Nat. Comp. Conf., 1979, pp.861-870.
- [Mago80] Magó G.A. "A Cellular Computer Architecture for Functional Programming", Proc. IEEE COMPON 80, Feb. 1980, pp.179-187.
- [Milu86] Milutinović V. Tutorial on Advanced Microprocessors and High-Level Language Computer Architecture, IEEE Comp. Soc. Press, 1986.
- [Patn86] Patnaik L.M., Govindarajan R., Ramadas N.S. "Design and Performance Evaluation of EXMAN: An EXTENDED MANchester Data Flow Computer", IEEE Trans. Comp. Vol. C-35, No.3, March 1986, pp.229-244.
- [Patt85] Patterson D.A. "Reduced Instruction Set Computers", Comm. ACM, Vol.28, No.1, Jan. 1985, pp.8-21.
- [Prei85] Preiss B.R., Hamacher V.C. "Data Flow on a Queue Machine", The 12th Ann. Int'l Symp. Comp. Arch., June 17-19, 1985, Boston, Massachusetts, pp.342-351.
- [Robi85a] Robić B., Šilo J., Mihovilović B. "Funkcionalno programirni sistemi", Informatika 4/85, str.366-370, Nova Gorica, 1985.
- [Robi85b] Robić B., Šilo J.: "Jeziki in arhitekture sodobnih računalniških sistemov", IJS DP-4058, Ljubljana, November 1985.
- [Robi86a] Robić B., Šilo J., "On Choosing a Plan for the Execution of Data Flow Program Graph", Informatika 3/86, pp.11-17.
- [Robi86b] Robić B., Šilo J., "Analiza statičnih podatkovno pretokovnih programskega grafa", Elektrotehniški vestnik 66/2, str.53-56.
- [Shim86] Shimada T., Hiraki K., Nishida K., Sekiguchi S. "Evaluation of a Prototype Data Flow Processor of the SIGMA-1 for Scientific Computations", Proc. 13th Int'l Symp. Comp. Arch., June 1986, pp.226-234.
- [Shor73] Shore J.E. "Second Thoughts on Parallel Processing", Comput. Elect. Eng., Vol.1, 1973, pp.95-109.
- [Slee81] Sleep M.R., Burton F.W. "Towards a Zero Assignment Parallel Processor", Proc. 2nd Int'l Conf. Distributing Computing, April 1981.

- [Snyd84] Snyder,L. "Supercomputers and VLSI: The Effect of Large-Scale Integration on Computer Architecture", Advances in Computers, Vol.23, Marshall C. Yovits, Ed., Academic Press, 1984.
- [Ston75] Stone,H.S. Introduction to Computer Architecture, SRA,Chicago 1975.
- [Silc84] Silc J., Robid B. "Računalniki krimljeni s tokom podatkov", IJS DP-3579, Ljubljana, Oktober 1984.
- [Silc85a] Silc J., Robid B.: "Osnovna načela DF sistema", Informatica 2/85, str.10-15.
- [Silc85b] Silc J., Robid B., Mihovilovit B. "Podatkovno vodene računalniške arhitekture", Informatica 4/85, str.371-376.
- [Silc86] Silc J., Robid B. "Procesor s podatkovno pretokovno arhitekturo", Informatica 4/86.
- [Trau85] Traub K.R. "An Abstract Parallel Graph Reduction Machine", The 12th Ann. Int'l Symp. Comp. Arch., June 17-19, 1985, Boston, Massachusetts, pp.333-341.
- [Tre180] Treleaven P.C., Mole G.F. "A Multi-processor Reduction Machine for User-defined Reduction Languages", Proc. 7th Int'l Symp. Comp. Arch., May 6-8, 1980, pp.121-130.
- [Tre181] Treleaven P.C., Hopkins R.P. "Decentralized Computation", The 8th Ann. Symp. Comp. Arch., May 12-14, 1981, Minneapolis, Minnesota, pp.279-290.
- [Tre182a] Treleaven P.C., Brownbridge D.R., Hopkins R.P. "Data-Driven and Demand-Driven Computer Architecture", Comp. Surv., Vol.14, No.1, March 1982.
- [Tre182b] Treleaven P.C., Hopkins R.P. "A recursive Computer Architecture for VLSI", The 9th Ann. Symp. Comp. Arch., Apr. 26-29, 1982, Austin, Texas, pp.229-238.
- [Tre182c] Treleaven P.C., Hopkins R.P., Rautenbach P.W. "Combining Data Flow and Control Flow Computing", Comput.J., Vol.25, No.1, Feb. 1982.
- [Tre184] Treleaven P.C., Lima I.G. "Future Computers: Logic, Data Flow,...,Control Flow?", Computer, Vol.17, No.4, March 1984, pp.47-57.
- [Wats79] Watson I., Gurd J. "A Prototype Data Flow Computer with Token Labeling", Proc. Nat. Computer Conf., New York, N.Y., June 4-7, 1979, pp.623-628.
- [Tele85] Teleznikar A.P. "Mednarodna konferenca o računalniških sistemih pete generacije v Tokyu", Informatica 85/3, str.68-70.

**UDK: 681.327.6:621.38.049.7-181.4**

**M. Jenko in A. Vodopivec  
Iskra Mikroelektronika**

Podan je pregled mikroelektronskih tehnologij, njihovih razvojnih možnosti, vrst današnjih mikroelektronskih vezij, smernic razvoja načrtovalske opreme. Dani so kriteriji racionalnega pristopa sistemskega načrtovalca k mikroelektroniki. Opisan je načrtovalski postopek od zasnove logicne sheme do narejenih mask v DO Mikroelektronika.

#### Possibilities Offered to Microelectronic System Designer

A view of microelectronics technologies, their growth alternatives, sorts of present integrated circuits, directives for evolution of design support are given. Criterions on design solutions for custom integrated circuits from the system designer's view are described. Design procedure beginning with completed logical scheme to process masks in Iskra Microelectronics div. is depicted.

Gradivo je razdeljeno na :

1. Primerjava obstoječih mikroelektronskih tehnologij in načrtovanja po možnostih, ki jih nudijo načrtovalcem
  2. Smernice razvoja tehnologije, razvoja načrtovanja mikroelektronskih vezij
  3. Opis načrtovalskega postopka od zasnove logicne sheme do narejenih mask v DO Mikroelektronika
- I Primerjava obstoječih mikroelektronskih tehnologij in načrtovanja po možnostih, ki jih nudijo načrtovalcem

Danes obstoje tri osnovne veje mikroelektronskih tehnologij:  
- planarna tehnologija na siliciju in galijevem arzenidu  
- debeloslojna tehnologija  
- tankoslojna tehnologija

#### 1.1 Planarna tehnologija - osnovni tehnoloski postopki:

- kontrolirano vnosanje primesi v silicij z difuzijo, ionsko implantacijo
- termično ali plazemsko stimulirana rast plasti na siliciju
- naparevanje, naprsevanje metalnih povezav med elementi
- litografski postopki za definiranje topologije vezja
- debeloslojna oksidacija površine silicija za zaščito vezij, tankoslojna oksidacija za definiranje aktivnih območij tranzistorjev

#### 1.2 Debeloslojna tehnologija

Osnovni tehnoloski postopek je sitotisk. Nanašamo prevodne, uporovne, dielektrične, izolacijske paste preko sita, na katerem je definirana geometrija vezja, na keramično podlogo. Sledi zapenje posameznih nanesenih plasti. Oblikujemo lahko upore, kondenzatorje, prevodne steze.

#### 1.3 Tankoslojna tehnologija

Osnovni tehnoloski postopek je vakuumsko naparevanje in ionsko naprsevanje. Oblikujemo pasivne komponente in tankoslojne tranzistorje. Njihove karakteristike ne dosegajo monolitnih tranzistorjev.

Ce se le da, se vezja realizira v planarni tehnologiji. Glavni problem je, da imamo za vse elemente, ki jih hočemo narediti, na razpolago le ene in iste tehnoloske postopke. Zato je na ta način težko izdelati kombinacijo npr. hitre logike in nekaj amperov močnega izhodnega tranzistorja. Zato imata svojo vrednost tudi tankoslojna in debeloslojna tehnologija, kjer aktivne dele vezja prilepimo na podlago, povezemo in lahko opremimo s se nekaj pasivnimi komponentami, zapremo v ohisje ter prodajamo kot zaključeno vezje.

Razvoj gre v smer vse vecje integracije različnih gradnikov vezja samo na rezini - planarna tehnologija.

Planarnih integriranih vezij je danes na tržišču ogromno. Lahko jih klasificiramo po tipu osnovnega aktivnega elementa (1.3.1), po stopnji integracije (1.3.2), po uporabi in pristopu k izdelavi vezja (1.3.3).

### 1.3.1 Bipolarna in unipolarna vezja.

Osnovni gradnik bipolarnih vezij je bipolarni tranzistor. Ta vezja so naceloma hitrejsa od unipolarnih, so manj občutljiva na elektrostatiko, njihova izdelava zahteva več tehnoloških postopkov, staticna poraba je vecja, porabimo več prostora.

Osnovni gradnik unipolarnih vezij je MOS tranzistor. Locimo:

- PMOS vezja
- NMOS vezja
- CMOS vezja

Zacelo se je s PMOS vezji - aktivni gradnik vezja je p kanalni tranzistor. Tehnologija je manj zahtevna kot za NMOS in CMOS. Pravovna napetost je razmeroma visoka, gibljivost nosilcev toka - informacije je razmeroma nizka, zato so ta vezja sorazmerno počasna. Tudi brez preklopov porabljajo za svoje delovanje energijo, zato za aplikacije z nizko porabo niso primerna.

NMOS vezja so tehnološko zahtevnejša, pravovna napetost tranzistorjev je nizja, gibljivost nosilcev toka je priblizno enkrat vecja kot pri tranzistorjih s p kanalom, zato so ta vezja hitrejsa. Slabost pa je se vedno staticna poraba energije.

CMOS - /Complementary Metal Oxide Semiconductor/ vezja združujejo na isti rezini p in n kanalne tranzistorje. Vedno prevodni pull-up tranzistor PMOS in NMOS vezji je nadomescen z aktivnemu komplementarnim tranzistorjem. Prevodna proga je naenkrat sklenjena le na nic ali na napajalno napetost in tako v mirovanju ni prevajanja med nico in napajalno napetostjo. V mirovanju vezje zato praktično nima porabe. Omejitev so le plazeci tokovi nekaj mikroamperov. Ta vezja so tehnološko najbolj zahtevna, so malo vecja kot logični n ali p kanalni ekvivalent, zelo so primerna za aplikacije z željeno majhno porabo.

Nacrtovalsko ima vsaka družina vezij svoje male skrivnosti, osnovni principi so enaki.

### 1.3.2 Delitev po stopnji integracije

- SSI - Small Scale Integration - v vezju je do sto elementov
- MSI - Medium Scale Integration - v vezju je med sto in tisoč elementov
- LSI - Large Scale Integration - v vezju je med tisoč in deset tisoč elementov
- VLSI - Very Large Scale Integration - v vezju je med deset tisoč in dvesto tisoč elementov
- ULSI - Ultra Large Scale Integration - v vezju je nad dvesto tisoč elementov.

### 1.3.3 Delitev po uporabi in pristopu k nacrtovanju vezja

- Standardna vezja
- Standardna LSI vezja
- LSI vezja po narocilu = ASIC vezja /Application Specific IC's/

Zacelo se je z uporabo standardnih vezij, ker drugih v začetku ni bilo. Sem sodijo družine kot serija logičnih vezij 74, 74LS, 54, 4000 ipd, enostavna analogna vezja (operacijski ojačevalniki, komparatorji, stabilizatorji napetosti in tokov ipd) in diskretni elementi (tranzistorji, diode, senzorji ipd). Prednosti standardnih vezij so, da se jih v dolgem casovnem obdobju da kupiti praktično povsod, so

relativno poceni, spremembe sistema so relativno neboleče tudi potem, ko je sistem že nacrtan. Slabost je obsežnost sistema, s tem združena poraba, zanesljivost je zaradi velikosti in števila tiskanih povezav manjša, končna cena izdelka je v primeru velikoserijske proizvodnje velika, saj je evropska kartica z dvajsetimi vezji gotovo dražja od enega vezja, ki bi opravljalo isto funkcijo.

Standardna LSI vezja so:

- elementi procesorskih družin (mikroprocesorji, PIA, ACIA, ROM, RAM, timerji ipd),
- modemi, filtri, linijski oddajniki in sprejemniki, narocniška vezja za telefonske centrale.

Z standardnim LSI vezjem običajno resimo ključne probleme sistema, sistem je običajno zanesljiv, majhen, cenjen, poraba energije je majhna. Slabost nacrtovanja s takimi vezji je, da ta vezja nacrtovalcu sistema vsljujejo svojo filozofijo delovanja (b skupina), zato pogosto ne more vgraditi v sistem vseh željenih funkcij, kakšne funkcije vezij pa ostajajo neizrabljene.

ASIC vezja so vezja narejena po narocilu in zasnovi nacrtovalca. Sistemski nacrtovalci si zamisli sistemsko zasnovo, ključne dele sistema realizira z vezji po lastni zamisli, lahko uporabi delno tudi standardna vezja. Tak pristop k stvari je gledano s stališča sistema vsekakor najbolj racionalen in sistem ima tako največ ze ob nastanku vgrajenih lastnosti za uspešno trzenje.

Nacrtovalec in njegov organizacijski vodja se morata zavedati določenih zakonitosti, povezanih z ASIC vezji. Praviloma je razvoj sistema s po lastni zamisli nacrtanimi vezji drazji od razvoja sistema s pomočjo standardnih komponent. Tudi traja malo dalj. V primeru pametnega razdeljevanja sistema na vezja in vestnega nacrtovanja vezij pa ima sistem nesluteno boljše možnosti za prodajo in doseganje vecje cene na trgu kot sistem grajen izključno iz standardnih komponent. Ekonomika tako zastavljenega projekta je na koncu odločno pozitivna in zahtevnejše izdelke lahko delamo konkurenčne samo se na ta način.

ASIC vezja delimo po nacinu njihovega nacrtovanja na:

- ULA in UAA vezja - Uncommitted Logic Array, Uncommitted Analog Array, logične mreže, analogne mreže
- PLA vezja - Programmable Logic Array - programirane mreže
- CLSI vezja - Custom LSI - vezja po narocilu:
  - Full Custom - cisto nacrtovanje po narocilu
  - Standard Cell Design - nacrtovanje s standardnimi celicami

Logične mreže so vezja, ki so specena na zalogu. Kaj bo tako vezje delalo, dolocimo s predzadnjo masko - definicijo metalnih povezav med že prej narejenimi tranzistorji. V takem vezju je odvisno od tipa med sto in deset tisoč tranzistorjev. Nacrtovalcu je prepusreno, koliko jih bo uporabil. Dimenzijske tranzistorjev so predefinirane, velikost vezja tudi. Predefinirane so tudi osnovne metalne povezave za izdelavo logičnih vrat, flip flopov, stevcov, pomikalnih registrrov. Tudi analognim mrežam dolocimo delovanje samo z metalno masko - definicijo povezav med

osnovnimi gradniki. Tako največkrat oblikujemo filtre s specifičnimi lastnostmi.

Programirane mreže uporabnik sprogramira sam, da se mu na dan vhodni vzorec pojavi na izhodu željeni izhodni vzorec. Ta vezja praviloma z ozirom na zmogljivosti niso majhna, programiramo vsako posebej.

Vezja cisto po narocilu so razvojno izredno draga in ni garancije za zelo kratki razvojni čas. Načrtovalec si za zastavljen problem izbere standardne celice, ki jih razmesti in poveže tako, da porabi čim manjšo površino silicija. V kolikor resitev v obliki standardnih celic za vse dele vezja nima, mora narediti nove standardne celice oziroma dele vezja na novo.

Vezja iz standardnih celic so tista vezja po narocilu, kjer za vse dele vezja že obstoje preizkusene standardne celice, ki jih načrtovalec poveže v delujoco celoto. Standardne celice in povezave med njimi razmeščamo v vzdolžnih vrstah tako, da dobimo ob siceršnji omejitvi načrtovalske svobode z vzdolžnimi vrstami čim manjše dimenzijs in optimalno delovanje vezja. Izdelamo vse maske za zahtevano vezje - ne le maske povezav, saj geometrija vezja ni vnaprej definirana. Prihranimo na površini silicija, izboljšamo lastnosti vezja, razvojni stroški so vecji kot pri mrezah.

Je vec vznih kriterijev, kako se odlociti za pravo ASIC vezje za kar najboljši ekonomski ucinek. Napacna odlocitev na tem nivoju je lahko katastrofalna, saj potegne za sabo od predragtega izdelka do popolne zamude na trgu, kar pomeni veliko izgubo, nadaljnji odpor do take izdelave sistema in gotovo zato nadaljnjo nekonkurenčnost.

#### Kriteriji:

- velikost serije
- cena sistema
- zahtevana zanesljivost
- stevilo in kompleksnost funkcij
- površina vezja
- realizacija analognih in digitalnih vezij
- poraba energije
- posebne zahteve
- doravnavanje lastnosti vezij
- možnost nadaljnega razvoja sistema
- možnost načrtovanja in proizvodnje doma
- roki za izdelavo
- konkurenčnost na trgu

**Velikost serije** - Stroški izdelanega vezja se delijo na zacetne in proizvodne stroške. Jasno je, da majhne serije zelo slabo prenesejo visoke zacetne stroške in da gre pri velikih serijah predvsem za manjšanje proizvodnih stroškov, pa ceteri je zato načrtovanje nekoliko dražje. Tako ima vsaka vrsta ASIC vezij svojo kolicino, v kateri ima pogoje za optimalno ekonomsko učinkovitost. Optimalna kolicina za PLA vezja je do nekaj deset tisoc, za ULA in UAA med nekaj tisoc in dvajset tisoc, za vezja po narocilu od nekaj deset tisoc naprej.

**Cena sistema** - Z ozirom na tržne zakonitosti, katerim je nas izdelek podrejen, se ze v zacetku odločimo, ali je končni cilj nizka cena sistema ali velike zmognosti, zaradi katerih bo sicer dražji, pa zaradi zmognosti ne bo imel dovolj velike konkurenčnosti, ki bi zavrla njegovo prodajo. Če je kriterij cena, bomo uporabili čim več standardnih komponent in ASIC vezja pridejo v postev le pri velikih serijah in se to v poceni obliki (plasticna DIL ohisja). Če je kriterij velika zmognost izdelka, pogosto uporabimo vezja po

narocilu v kakovostenjsih ohisjih. Zaključene enote običajno realiziramo z vezji po narocilu.

Zahtevana zanesljivost je dejavnik v prid vezjem ASIC, saj je vzrok odpovedi sistema navadno stik prevec ali premalo, za kar je v integriranem sistemu bistveno manj možnosti.

Stevilo in kompleksnost funkcij nam pomagata pri odlocitvi med vezjem po narocilu in med predefiniranimi mrežami. V kolikor so vezja mesana digitalno analogna, seveda izberemo vezje po narocilu.

Površina vezja je zelo ozko povezana s ceno vezja. Cena naravnega z velikostjo vezja vec kot linearno, saj je zaradi napak v kristalni strukturi silicijeve rezine dober le dolocen odstotek vezij. Izplen pada z velikostjo vezij, saj je pri vecjem vezju vecja verjetnost, da se bo na njem pojavila napaka. Sledi nelinearno visja cena vezja. Priznana resitev je načrtovanje vezja v tehnologiji s čim manjšo osnovno geometrijo - pet, trije mikroni, večkrat tudi manj in načrtovanje po narocilu, kjer načrtovalec praviloma dobro izrabi površino silicija.

Poraba energije se z uporabo ASIC vezij navadno drastično zmanjša. Nastopijo pa lahko problemi s temperaturno dissipacijo, v kolikor zahtevamo tokovno zmogljivejše izhode. Resitev je prigradnja diskretnih komponent, kar pa je kompromis z zanesljivostjo. Z energetskega stališča so najugodnejša vezja CMOS, ki praktično nimajo statične porabe.

Posebne zahteve navadno lahko uresnicimo le z vezjem po narocilu. Take zahteve so povezane tudi s posebno ceno, saj samo z racionalnim načrtovanjem vedno vseh zahtev ne moremo uresniciti. Vecje sistemski higi razvijajo za potencialno ekonomsko zanimive posebne zahteve celo posebne tehnologije kot na primer za vezja, kjer je na isti rezini logika in močnostni elementi. Tudi velika hitrost je posebna zahteva. Klasične simulacije na hitrostni meji dane tehnologije odpovedo. Logična vrata simuliramo kot analogen element. Pred standardnimi komponentami ima ASIC vezje glede hitrosti vgrajeno prednost, saj je vsota parazitskih kapacitivnosti priključkov in povezav gotovo manjša. Tako lahko s pet mikronsko CMOS tehnologijo dosezemo do 25 MHz, s tri mikronsko CMOS tehnologijo do 100 MHz hitrosti.

Doravnavanje lastnosti vezij je gotovo zeljena možnost, saj se tako izognemo raznim potenciometrom, trimerjem, doravnavanju lastnosti vezja na tiskani plosci, ki je praviloma dražje od doravnavanja na silicijeve rezini pred inkapsulacijo. Doravnavamo tako, da izdelamo na vezju vrsto prezigalnih elementov, ki jih prezigamo s tokom ali z laserskim zarkom. S tem povezemo ali razklenemo doravnalne elemente; navadno precizno umerimo uporovno verigo, dolocimo kapaciteto kondenzatorja. Seveda je prežiganje irreverzibilen postopek in moramo pred prežiganjem izmeriti karakteristike vezja ter izracunati, katere elemente moramo prezgati, da bomo dosegli zeljene lastnosti. Zato je doravnavanje že del testiranja silicijeve tabletke na rezini in ga krmilimo z računalnikom testne naprave.

Možnost nadaljnega razvoja sistema je vedno dobrodošla in nujna, v kolikor naj bo sistem vsaj par let tržno zanimiv. Zato moramo pri razdelitvi sistema paziti, da ga razdelimo na smiselne vase zaključene celote s čim manj zunanjimi povezavami. Modularnost omogoča, da posamezne dele vezja spremenjamo ali naredimo v novi tehnologiji, ne da bi zato morali

spreminjati cel sistem. Možnost načrtovanja in proizvodnje doma zniza stroske vezja tudi za velikostni razred. Stroski so dinarski. Po tem kriteriju realiziramo vezja v MOS tehnologiji. Roki za izdelavo nas včasih prisilijo v izbiro enostavnnejših ASIC vezij - PLA, ULA in resitve zato tehnično lahko v prvem koraku niso najboljše. Vendar je bolje prodati slabši sistem, ta sistem nato naprej razvijati kot priti na trg za vso konkurenco. V splošnem se čas načrtovanja z vecanjem načrtovalskih izkušenj in uvajanjem simulatorjev, racunalniške grafike, krajsa. Konkurenčnost na trgu je posledica majhnih, zmogljivih, cenenih sistemov, kar ASICs vsekakor omogočajo veliko bolje kot samo standardne komponente.

## 2 Smernice razvoja

Pri smernicah razvoja se kazeta dokaj ostro loceni področji razvoja tehnologije in razvoja načrtovanja.

### 2.1 Smernice razvoja tehnologije

Razvoj tehnologije gre v vec smeri, saj ima industrija vec zahtev, ki niso vse združljive in naenkrat zahtevane. Glavne razvojne smernice so sledete:

- skaliranje dimenzij
- izdelava Smart Power vezij
- izdelava BiMOS vezij
- izdelava vezij na galijevecem arzenidu

#### 2.1.1 Skaliranje

Danes so industrijski standard vezja z minimalno dimenzijo dveh mikronov. Če je minimalna dimenzija (običajno je to dolzina tranzistorja) manjša, je celo vezja manjše, nacelno hitrejše, manj porabi. Same dobre stvari. Je pa vezje gotovo dražje, saj ob manjšanju dimenzijskih nastopi vrsta stranskih pojavov, ki jih je treba upoštevati ali eliminirati.

Po Dennardovem pravilu pri skaliranju zmanjšamo vse geometrije in napajalno napetost s faktorjem skaliranja S, koncentracijo nečistot v substratu povecamo z 1/S. Namen tega je izdelati manjše elemente s karakteristikami vecjih elementov. Teoretično s faktorjem skaliranja S zmanjšamo tok skozi elemente, zmanjšamo S-krat tudi zakanitev skozi elemente, disipacija moci je zmanjšana z faktorjem S<sup>2</sup>. V kolikor skaliramo tudi povezave, se jim upornost poveča - ob zmanjšanju parazitskih kapacitivnosti se RC konstanta ohranja.

V praksi povprečna dolzina povezave po skaliranju ni krajsa, saj je namen skaliranja gradnja vecjih (in hitrejših) vezij. Torej bo v prihodnje poleg zelo dobrega modeliranja elementov v submikrnskem območju velik poudarek na tehnikah za zmanjšanje RC konstant.

So povsem fizikalne omejitve, zaradi katerih je spodnja meja uporabne minimalne dimenzije tranzistorjev, kot jih danes poznamo, pri pol mikrona.

- Napajanja v nedogled ne moremo nizati, saj je pragovna napetost tranzistorja podana z razliko energijskih pasov p in n dopiranega silicija.
- Prebojne napetosti so določene s kritično poljsko jakostjo in debelino izolacijskih plasti.
- Spodnja meja tankosti povezav je določena z zacetkom migracije prevodne kovine kot posledico maksimalne tokovne gostote.

Skaliranje je omejeno tudi s stališča uporabnika. Danes je industrijski standard pet voltno napajanje in TTL logični nivoji. Prehod navzdol ekonomsko se ni upravil, saj potegne za sabo poleg kopice formalnih problemov tudi novo poglavje o sumu in motnjah. Kljub visokim vlaganjem - za skaliranje pod dva mikrona je v precej tehnoloških korakih potrebna drugačna oprema zaradi tanjsih in bolje definiranih plasti - tudi razvita Evropa sledi Japoncem in Američanom, saj je bila prva lekcija o tehnološkem zaostajanju na področju elektronike dovolj poučna.

#### 2.1.2 Izdelava Smart Power vezij

Ogromno je aplikacij zlasti v industrijski elektroniki, avtomatizaciji, avtomobilski elektroniki, siroki potrošnji, kjer na osnovi logicnih odločitev izvedemo določene močnejše preklope. Ustaljena realizacija je tiskano vezje z elementi ene logicnih družin s podatkovnim držalom, ki krmili diskretne tranzistorje, sledijo pa lahko se reljeji. Velikost, temperatura, poraba, zanesljivost so dejanski problemi. Smart Power vezja, kjer je na istem čipu logicni in močnostni del, nam na stopnji svoje tehnološke zrelosti te probleme odpravijo. Pobudo za takia vezja je dal uporabniški del mikroelektronike sistemskih his, odgovor je moral priti s strani tehnologije. Zato so zacetki vidnih poskusov v letu 1983, vecji razmah takih vezij pa je sele letos. Glavni tehnološki problem je ustrezna izolacija med močnostnimi stikali in logicnim delom, majhna upornost, tokovna zmogljivost, visoka prebojna napetost stikal.

Izolacijo dosegajo z zaporno polariziranimi p-n spoji, s posebnimi izolacijskimi difuzijami. Trenutno najboljša in najdražja je izolacija z dielektrično, vnesenimi v silicijev rezino, na katerih oblikujemo močnostne elemente. Tovrstna izolacija prenese napetosti cez tisoč voltov.

Majhno upornost stikal dosegajo z vec manjšimi stikal povezanimi vzporedno. Druga bolj ravna pot je striktno manjšanje upornosti kanala, vira, ponora, dovodov toka. Ustreznih tehnoloških korakov pa istočasno nizajo prebojno napetost med virom in ponorom, tako da v tej smeri ni resitve. Trenutno znajo v svetu narediti močnostne tranzistorje z do tri milijone vzporedno vezanih stikalnih celic na kvadratno inc. Obenem z manjšanjem upornosti pridobivamo na tokovni zmogljivosti stikal.

Visoko prebojno napetost dosežemo z razmaknitvijo vira in ponora tranzistorja. Izdelamo strukturo pnp-n. Vrata so p področje, n - v primeru pozitivno polariziranega ponora služi kot izolator. Tako razlika napetosti vira in ponora ni omejena le na ozko območje p, ki predstavlja dejanski tokovni ventil.

Današnja tipska področja uporabe Smart Power vezij so krmiljenje motorjev (GESmart), avtomobilска industrija (SGS, Motorola, Mostek, International Rectifier, Rockwell), krmilnikov prikazalnikov (SGS, Supertex, Siliconix, Telmos, Sprague, TI, Mostek), napajalnikov (Integrated Power Semiconductors, International Rectifier), krmiljenje koracnih motorjev (Integrated Power Semiconductors, Unitrode).

#### 2.1.3 BiMOS vezja

so v končni obliki hitrejša in manjša od bipolarnih in MOS vezij posebej. Združujejo prednosti MOS - nizka disipacija moci, manjša občutljivost na sum, in prednosti bipolarnih tranzistorjev - preklopna hitrost, bolje definirano obnašanje v linearnem območju, boljši tokovni viri. Da se ta vezja niso

pojavila že prej, so krivi postopki izdelave. Treba je namreč postaviti proces izdelave vezja, ki istocasno zagotavlja dobre bipolarne in MOS tranzistorje. Letos tak proces zahteva med sestajst in dvajset mask. Potencialna uporaba teh vezij je DRAM (hitrost kombinirana s cim. nizjo porabo), vezja za prenos in obdelavo podatkov.

#### 2.1.4 Vezja na galijejem arzenidu

V razvoju tovrstnih vezij se investira iz več razlogov:

- Ta vezja so do pet krat hitrejša od ECL vezij na siliciju. Gibljivost elektronov v GaAs je okrog devet krat vecja od gibljivosti elektronov v siliciju.
- Mnogo laže je dosegi visoko stopnjo integracije, saj je nedopiran GaAs izolator in s tem prihranimo precej procesnih korakov, ki so pri siliciju potrebni zaradi izolacije med aktivnimi deli vezja.
- Vezja na GaAs manj sumijo od vezij na siliciju.
- Toplotna prevodnost GaAs je vecja od le te silicija (hlajenje).
- V temperaturnem območju -200, 200 stopinj celzija se električne lastnosti gradnikov vezij na GaAs spremnijo znosno in lahko z dobrim nacrtovanjem definiramo tako področje uporabe.
- Glavni problem danes pa so dragi substrati. So tudi krhki in imajo mnogo napak. Danes je cena GaAs rezine tridesetkrat vecja od cene silicijeve rezine. Če k temu pristejemo se manjši izpleni zaradi vecje gostote napak, pa del razvojnih stroškov, je cena vezja na GaAs hitro dva velikostna razreda višja od cene vezja na siliciju z enako logično shemo. Najvec v pridobivanje substratov investirajo Japonci, tako da lahko upravljeno pricakujemo, da bodo japonski proizvajalci vezij na GaAs osvojili vecji delež tržisca. Danes je najvecje torisce delovanja na GaAs področje nizkosumnih ojacevalnikov, ki jih zahtevajo sateletske in vojaske komunikacije. Tako visokih frekvenc in tako nizkega nivoja suma na siliciju ne moremo dosegi. Tudi logične mreže na GaAs so že razvite. Letos so poprecne zakasnitve na vrati 30 ps, poraba je 200 mW. Proizvajalci so Harris, Honeywell, TI, Ford Microelectronics, NT&T, Toshiba. Stroski Honeywellove logične mreže z dva tisoč vrati in šestinpetdeset I/O celicami so sto desettisoč dolarjev.

#### 2.2 Smernice razvoja nacrtovanja

V zadnjih nekaj letih se je programska oprema za nacrtovanje integriranih vezij neverjetno razvila. starejsi programi na miniracunalnikih so postali zastareli, saj potrebujejo preveč racunalniškega časa na teh relativno dragih procesorjih.

V industriji integriranih vezij je prevladalo mnenje, da je pisanje lastne programske opreme za nacrtovanje integriranih vezij zelo zahteveno in neekonomicno. To si lahko privoscijo le največje družbe. Večina manjših in srednjih proizvajalcev programsko opremo kupuje pri za to področje specializiranih firmah. Njihovi lastni strokovnjaki se ukvarjajo samo se z združevanjem različnih paketov v enoten sistem.

Vecina te programske opreme sedaj deluje na delovnih postajah, ki jih je moč povezati z mrezo Ethernet. Te delovne postaje so opremljene s posebnimi pospeševalniki - specializirano opremo namenjeno enemu samemu postopku. Ti pospeševalniki so prisli najbolj do veljave pri logični simulaciji in simulaciji napak, kjer le to sedaj opravlja v veliki meri

strojna oprema sama, kar je seveda hitrejše kot programi z najboljšimi algoritmi. Razlika v hitrosti delovanja je med 10 in 100 krat.

Za izdelavo zelo obseznih integriranih vezij ne pride vec v postopek klasicno nacrtovanje vezij po narocilu, saj bi tako nacrtovanje vezij z 100.000 do 1.000.000 vrati trajalo nekaj let, kar seveda ni sprejemljivo. Trenutno so na vrhuncu programi za avtomatično nameščanje in povezovanje standardnih celic in logičnih mrež, vedno bolj pa se uveljavljajo prevajalniki na siliciju.

Končni cilj nacrtovanja je cim hitrejša izdelava vezja, ki bo delovalo že v prvem poskusu. Torej je treba povsem izkljuciti predvidljive napake. Le te lahko nastopajo v interakciji med posameznimi programi, lahko so napake v programih samih, lahko so posledica cloveskega faktorja. Prvo in drugo možnost s skrbnim preverjanjem programske opreme lahko izkljucimo, tretjo pa zmanjšamo tako, da cim več nacrtovalskih postopkov avtomatiziramo.

Pri nacrtovanju integriranih vezij z prevajalniki na silicij nacrtovalec vnesе logično shemo, željene signalne zahteve, oznako procesa, v katerem bo vezje izdelano in s tem posredno izbere za ta proces specificka nacrtovalska pravila. Izvod programskega paketa je končna geometrija vezja, po kateri izdelajo maske. Cloveski faktor je omejen le še na napacno zastavljen problem.

Cotovo bo sel razvoj na področju programske opreme v prihodnjih letih v smer izdelave cim popolnejših prevajalnikov na siliciju. Danes znajo najboljši prevajalniki nacrtati bit slice procesor. Razvojno zahtevna vezja pa bodo gotovo tudi v prihodnje delali precej ročno, saj je znanje treba najprej osvojiti, da ga lahko vgradis v samostojen nacrtovalski sistem. Gotovo bodo avtomatizirni na področju nacrtovanja vezja lahko pocenili, razvojni čas bo krajsi in nacrtovalskih napak bo manj. Tudi razvoj danes zahtevnih vezij bo lahko hitrejši in cenejši.

#### 3 Oris nacrtovalskega postopka od zasnove logične sheme do narejenih mask v DO Mikroelektronika

Nacrtovanje integriranih vezij je zelo zahteven postopek. Integrirano vezje lahko sestavlja nekaj sto do nekaj sto tisoč medsebojno povezanih aktivnih in pasivnih elementov. Podatkovne baze za opis takega vezja so zato velike, kljub temu pa ne smejo vsebovati napak. V naslednjih nekaj vrsticah bi rada pokazala možnosti in perspektive nacrtovanja integriranih vezij v Iskri.

Zaradi obseznosti podatkov, ki opisujejo integrirano vezje, je možnost vnosa napake pri nacrtovanju zelo velika. Vsaka napaka ponavadi pomeni, da vezje ne bo delovalo tako, kot je bilo zamisljeno, zato se vedno bolj uveljavljajo postopki, ki avtomatizirajo posamezne postopke v procesu nacrtovanja.

Integrirana vezja po narocilu delimo glede na metodo nacrtovanja na tri skupine:

- narocniška vezja
- vezja iz standardnih celic
- logične mreže

V Iskri DO Mikroelektronika imamo precej zmogljiv sistem za racunalniško podprt nacrtovanje integriranih vezij, ki omogoča nacrtovanje vseh treh zvrsti. Postopki za nacrtovanje se od skupine do skupine razlikujejo. Razlikuje se tudi potreben čas za razvoj takega vezja, s tem pa tudi stroski razvoja. Ti direktno vplivajo na končno ceno vezja. Drug pomemben faktor, ki vpliva na

končno ceno, pa je povrsina vezja na siliciju. Stroski razvoja so obratno sorazmerni površini vezja na siliciju. Najdražji in najbolj dolgotrajen je razvoj narocniških vezij, ki da najmanjšo povrsino na siliciju. Najcenejši je razvoj logicnih mrež, pri katerih je za končno konfiguracijo potrebno izdelati eno samo masko. Sestevek obeh stroskov pokaze, da se izplača izdelovati glede na število kosov:

- do 20.000 vezja na osnovi logicnih mrež
- od 20.000 do 100.000 vezja na osnovi standardnih celic
- nad 100.000 narocniška vezja.

Nekateri postopki so pri vseh treh metodah načrtovanja enaki, drugi pa se razlikujejo. Zajem shematskega opisa vezja in logična simulacija sta n.pr. enotna medtem ko je izdelava geometrije različna. V nadaljevanju bova najprej opisala programsko opremo, ki jo imamo v Mikroelektroniki, nakar bova podrobnejše obdelala vrstni red postopkov pri vseh treh metodah načrtovanja.

Težko je oceniti čas, ki je potreben za izdelavo logicnega oz. funkcionalnega opisa vezja. Ta je odvisen predvsem od izkušenosti nacrtovalca in kompleksnosti vezja. Mnogo laže je oceniti čas, ki je potreben od trenutka, ko je opis vezja gotov, do končne realizacije.

### 3.1 Pregled programske opreme

Vetina obstoječe programske opreme bazira na miniracunalniku VAX 11/780. Nekaj manj obseznih programov, ki jih v glavnem uporabljamo za vnos podatkov deluje na osebnih racunalnikih. To so programi za izdelavo integriranih vezij z metodo standardnih celic, ki pa pridejo do prave veljave sele, ko imamo na miniracunalniku obsezno in preverjeno bazo podatkov.

Programski paket SIDS za načrtovanje integriranih vezij po narocilu smo kupili od licencnega partnerja Gould AMI. Ta paket programov je deloval na racunalnikih Prime, zato se je tedanje vodstvo razvoja odločilo za konverzijo te programske opreme na racunalnik VAX, ki ima v Jugoslaviji zagotovljeno vzdrževanje. Kupili smo tudi programe za vnos logicnega opisa vezja in logično simulacijo. Kupljeni so bili naslednji programi:

- BOLT - prevajalnik opisa vezja
  - SIMAD - logicni simulator
  - HOLDNET - ekstrakcija velikosti tranzistorjev in povezav med njimi iz logicnega opisa
  - SIDSED - simbolično urejevanje geometrije vezja uporabljamo za nacrtovanje naročniških vezij in standardnih celic
  - SDRC + preverjanje nacrtovalskih pravil v simbolični bazi podatkov
  - STRACE - preverjanje električne skladnosti simboličnega opisa in ekstrakcija velikosti tranzistorjev in povezav med njimi iz simboličnega opisa
  - SPRINT - izpis simboličnega opisa
  - STP - pretvarjanje iz simboličnega v geometrični opis
  - GPLOT - izris geometrične baze podatkov
  - COMPARE - primerjava velikosti tranzistorjev in povezav med njimi, ki jih dobimo iz logicnega in iz simboličnega opisa.
  - SPICE - analogni simulator

Ketíčni elementi v tom paketu sú:

- SIMAD, ki je za zelo obsežna vezja zelo pocasen. Simulacija poteka tudi po nekaj dñi
  - STRACE je za zelo obsežna vezja zelo pocasen

Digitized by srujanika@gmail.com

Slika 1

Izris simbolične baze podatkov za dvovhodna vrata NAND na elektrostatičnem risalniku.

Nekaj osnovnih znakov:

"a"- vrata tranzistorja

" - " - difuzija

"1"-metal

"/- polisilicij

- SDRC, ki je za obsežna vezja zelo pocasen. Preverjanje načrtovalskih pravil poteka tudi po nekaj dñi. Ni ga mõc uporabiti za zelo obsežna vezja
- STP, ki je za obsežna vezja zelo pocasen. Pretvarjanje simboličnega opisa v geometrični opis poteka tudi po nekaj dñi. Ni ga mõc uporabiti za zelo obsežna vezja
- COMPARE, ki je za zelo obsežna vezja zelo pocasen. Simulacija poteka tudi po nekaj dñi.

Problem smo reševali z uvedbo metode načrtovanja s standardnimi celicami, pri kateri podatke zajemamo in logicno simuliramo na osebnih računalnikih s programskim paketom SCEPTR. Pomanjkljivost tega paketa je, da je njegov izhod komandna procedura za program SIDSED, ki zloži celotno vezje v simbolični obliki. Celice so načrtane tako, da ne moremo kršiti načrtovalskih pravil pri njihovem nanesanju in povezovanju, zato preverjanje načrtovalskih pravil na simboličnem opisu odpade. Compare prav tako odpade, ker ga do neke mere nadomesti programska oprema SCEPTR. Problem predstavlja pretvorba iz simboličnega v geometrični opis, zato smo sami napisali program, s katerim je mõc komandno proceduro, ki je rezultat programskega paketa SCEPTR, direktno pretvoriti v geometrično obliko. Ta postopek je na ta način stokrat hitrejši.

Pri AMI-ju smo kupili tudi paket CIPAR, ki omogoča avtomatično nanesanje in povezovanje standardnih celic. Program je dokaj neusinkovit. Izkoriščenost povrsine na siliciju se precej izboljša z uporabo optimizatorja Timberwolf 1.0 z Berkeleyeve univerze, se bolj pa bi se z uporabo procesa z dvema plastema metala.

Shematski vnos in logicno simulacijo iz paketa SCEPTR uporabljamo tudi za načrtovanje vezij po metodi logičnih mrez. Sami smo morali napisati program za grafično urejanje geometrije vezja.

Končni produkt postopka načrtovanja so datoteke, ki jih zapišemo na trak, s katerim krmilimo generator vzorcev - napravo, s katero se izdelajo maske in vzorci za avtomatsko testno opremo. Program za pretvorbo geometrijske baze podatkov v datoteke za generator vzorcev (PG) smo napisali sami.

### 3.2 Načrtovanje z logičnimi mrezami

Kot sva že omenila, je to metoda, s katero najhitreje pridejo do integriranega vezja. Samo načrtovanje je zelo podobno načrtovanju z metodo standardnih celic, bistvena razlika pa je končni produkt procesa načrtovanja. Pri metodi logičnih mrez dobimo eno masko, medtem ko pri metodi načrtovanja s standardnimi celicami dobimo toliko mask, kot jih proces zahteva (8 - 9 mask). Ko je maska pripravljena, je pot do končnega vezja zelo kratka. Logične mreže se izdelujejo na že pripravljenih rezinah, ki so izdelane do določene stopnje, tako da jih je mõc dokončati v enem tednu.

Načrtovanje se začne z vnosom logičnega opisa v računalnik. Pri tem imamo dve možnosti. Logiko lahko z urejevalnikom teksta vnesemo na alfanumeričnem terminalu računalnika VAX ali pa na osebnem računalniku Sirius ali IBM PC/XT. Vnašanje logike je lažje na osebnem računalniku, kjer je v paketu programov SCEPTR grafični urejevalnik, ki omogoča shematski vnos. Pri vnosu logike je treba zelo paziti, da je možno vezje na zunanjih sponkah zadovoljivo testirati. Pri intergriranih vezjih namreč ni možno merjenje signalov med



Slika 2

Izris geometrične baze podatkov za dvovahodna vrata NAND

posameznimi elementi vezja.

Ko je logika vnesena, jo preizkusimo s programom za logicno simulacijo. Ce izhodni vzorci, ki jih dobimo s simulacijo, ne ustrezajo zamislenim, z grafičnim urejevalnikom popravimo shemo in ponovno simuliramo. Postopek ponavljamo toliko časa, da smo zadovoljni z odzivi vezja, ki jih pokaze simulacija. Logicno shemo lahko izrisemo na matricnem tiskalniku ali pa na risalniku, ki omogoča izdelavo dokumentacije vezja. Pravilnost logičnega opisa je seveda predpogoj za pravilno delovanje vezja. Logičen opis zatem prenesemo na VAX, kjer vezje ponovno simuliramo s programom SIMAD. Ta simulacija je samo dodatna kontrola. Izhodne datoteke, ki jih dobimo, pa je možno z drugim programom pretvoriti v testne vzorce za avtomatsko testno napravo.

Vnos logike in izdelava potrebne dokumentacije vzame načrtovalcu en do dva tedna. Tu prevzame delo načrtovalec sestavnice mask ali pa ga nadaljuje načrtovalec sam.

Ko je simulacija gotova, pristopimo k zadnjemu interaktivnemu postopku. S posebnim programom zacnemo sestavljati geometrijo. Na predefinirani mreži postavljamo in povezujemo celice. Program je uporabniško prijazen, zato je delo hitro in usinkovito. Vse spremembe, ki jih vnesemo s pomočjo tipkovnice in miske, se sproti pojavljajo na zaslonu, na katerem lahko prikažemo manjše del vezja in s tem vecje podrobnosti ali celotno vezje zaradi boljseg globalnega pregleda. Tudi geometrijo lahko izrisemo na matricnem tiskalniku. Za to delo





Slika 3

Primer vezja iz standardnih celic, ki ga je zložil program za avtomatično nameščanje in povezovanje celic. Vezje je razdeljeno na periferijo, ki jo sestavljajo vhodno izhodne celice (A, B, C, D, CL, R, VSS, VDD) in jedro. Z jedrnimi celicami realiziramo željene logične ali analogne funkcije, ki jih uporabljamo preko vhodno izhodnih celic, ki hkrati varujejo vezje pred elektrostatskimi razelektritvami.

potrebujemo enega cloveka nekaj dni.

Ko je postavljanje in povezovanje celic gotovo, drug nacrtovalec preveri skladnost med logicno shemo in geometrijo, napake se popravijo. Podatke s posebnim programom nato prenesemo v obliki tekstovne datoteke po terminalski liniji na VAX, kjer drug program celice nadomesti z njihovo vsebino, povezave pa zamenja z ustreznimi pravokotniki. Do koncnega rezultata, t.j. maske za generator vzorcev, moramo izvesti se nekaj avtomatičnih postopkov. Dobljeni geometrijski bazi podatkov pripisemo podatke, ki so na metalnem nivoju fiksnii (napajalne linije, ...), vezje za dokumentacijo izrisemo na elektrostaticnem risalniku in nazadnje pretvorimo geometrično datoteko v datoteke za generator vzorcev.

Izurjen nacrtovalec potrebuje za celoten proces nacrtovanja dva do tri tedne. Izdelava mask traja en dan, vendar je treba zaradi zasedenosti opreme vcasih cakati tudi po dva do stiri tedne. Rezine z logicnimi mrežami je treba se dvakrat maskirati. Od vezja do vezja se spreminja samo metalna maska. Izdelati je treba metalne povezave in narediti odprtine v pasivaciji na mestih, kjer se pritrđijo zicke, ki silicijevu ploščico povezujejo z nožicami na ohišju. Procesiranje poteka nekaj dni. Z dobro časovno usklajenostjo posameznih postopkov je tako pri logicnih mrežah možno priti od logične sheme do vezja v enem mesecu.

### 3.3 Nacrtovanje s standardnimi celicami

Z metodo standardnih celic dosežemo boljši izkoristek površine na siliciju. Tu je postopek nacrtovanja podoben opisanemu postopku nacrtovanja po metodi logicnih mrez. Rezultat nacrtovanja so maske za vse nivoje. Pri naših standardnih osem in devet nivojskih procesih traja procesiranje priblizno en mesec.

Metoda standardnih celic omogoca izdelavo logicnih in analognih integriranih vezij. Pri analognih vezjih je pogosto potrebno nacrtati novo ali prirediti obstojecu celico. Nacrtovalec mora zato znati uporabljati analogni simulator Spice.

Nacrtovanje se začne z vnosom logicnega oz. funkcionalnega opisa vezja v racunalnik. Ta je povsem enak kot pri logicnih mrežah. Tudi tu se po vnosu podatkov menjavajo simulacije in popravki.

Preverjen logičen opis zatem prenesemo na VAX, kjer vezje ponovno simuliramo s programom SIMAD. Ta simulacija je samo dodatna kontrola, izhodne datoteke, ki jih dobimo, pa je možno z drugim programom pretvoriti v testne vzorce za avtomatsko testno napravo.

Vezja iz standardnih celic so vcasih kompleksnejša kot logicne mreže, ki so omejene z najvecjim modelom, ki ga izdelujemo (t.j. 1200 ekvivalentnih vrat). Vnos logike in izdelava potrebne dokumentacije vzame nacrtovalcu en do tri tedne.

Ko smo z simulacijo logičnega oz. funkcionalnega opisa zadovoljni, je treba namestiti in povezati celice. Za to imamo dve metodi. Prva je ročno namešcanje in povezovanje na osebnem racunalniku, druga pa je avtomatično namešcanje in povezovanje na miniracunalniku.

Za avtomatičen postopek uporabljamo program Cipar iz paketa programov Cipar. S pomočjo optimizatorja Timberwolf se izboljša izkoriscenost površine silicija. Vhodni podatki za program so obstoječe datoteke z logicnim oz. funkcionalnim opisom vezja.

Program sam postavi in poveze celice integriranega vezja. Obdeluje jih kot pravokotnike, ki jih postavi paroma v vrste in jih poveže v kanalih med vrstami. Dodatni programi iz paketa Cipar omogočijo izris geometrije na elektrostaticnem risalniku in pretvorbo geometrije v pravo geometrično bazo podatkov, med katero program nadomesti pravokotnike z njihovo vsebino, povezave pa s pravokotniki. Izdelava geometrije vzame en do dva dni.

Boljšo izkoriscenost površine silicija dosežemo z grafičnim urejevalnikom iz paketa programov SCEPTRÉ na osebnem racunalniku. Razlika v površini integriranega vezja je med 10% in 30%. Program dovoljuje namešcanje celic in povezav na mrezo, katere vozlisca so dovolj oddaljena drugo od drugega, da ni mogoče krašti nacrtovalskih pravil. SCEPTRÉ omogoča tudi primerjavo med izdelano geometrijo in logicnim opisom.

Ko je doseženo ujemanje med geometrijo in logicnim opisom, podatke s posebnim programom prenesemo v obliki tekstovne datoteke po terminalski liniji na VAX, kjer drug program celice nadomesti z njihovo vsebino, povezave pa zamenja z ustreznimi pravokotniki. Nadaljnji postopek za izdelavo trakov za generator vzorcev je enak kot pri logicnih mrežah.

Izurjen nacrtovalec potrebuje za celoten proces vnos logičnega oz. funkcionalnega opisa en do tri tedne. Nacrtovalec geometrije mask potrebuje za ročno namešcanje in povezovanje celic en do dva tedna. Izdelava mask traja nekaj dni. Rezine z vezji nacrtanimi po metodi standardnih celic morajo skozi celoten proces, kar zaradi množice različnih postopkov traja priblizno en mesec. Z dobro časovno usklajenostjo posameznih postopkov je tako pri standardnih celicah možno priti od logične sheme do vezja v dveh do treh mesecih.

### 3.4 Nacrtovanje naročniških vezij

Nacrtovanje naročniških (full custom) vezij je najdolgotrajnejši postopek. S to metodo dosežemo najboljši izkoristek, kar se pri zelo velikih serijah seveda izplača. Rezultat nacrtovanja so maske za vse nivoje. Pri naših standardnih osem in devet nivojskih procesih traja procesiranje priblizno en mesec.

Ta metoda ne pride v naših razmerah velikokrat v postopek, saj so serije vezij, ki jih pri nas naročajo razna podjetja ponavadi premajhne, da bi cena posameznega vezja prenesla razvojne stroške. Naročnik mora potrebovati vsaj 100.000 vezij, da se mu to izplača. Tudi ta metoda omogoča izdelavo logičnih in analognih vezij.

Nacrtovanje se začne z vnosom logičnega oz. funkcionalnega opisa vezja v racunalnik. Ta postopek je povsem enak kot pri logicnih mrežah in standardnih celicah. Tudi tu se po vnosu podatkov menjavajo simulacije in popravki.

Preverjen logičen opis zatem prenesemo na VAX, kjer vezje ponovno simuliramo s programom SIMAD. Ta simulacija je samo dodatna kontrola, izhodne datoteke, ki jih dobimo, pa je možno z drugim programom pretvoriti v testne vzorce za avtomatsko testno napravo.

Kompleksnost naročniških vezij je podobna kot je kompleksnost vezij s standardnimi celicami. Vnos logike in izdelava potrebne dokumentacije vzame nacrtovalcu en do tri tedne.

Pri naročniških vezjih se tu delo sele začne. Sedaj je treba posamezne logične oz. funkcionalne bloke izdelati tako, da zavzamejo

cim manj povrsine na siliciju. Vsako celico je potrebno elektricno simulirati in optimizirati za dano mesto v vezju. To delo je dolgotrajen postopek, ki zahteva izkusenega nacrtovalca.

Ko je geometrija posameznih blokov narejena, jih je treba namestiti cimbolj skupaj in povezati. Med namescanjem in povezovanjem je vcasih potrebno katerega od blokov spremeniti. Geometrijo nacrtujemo na semigraficnih barvnih terminalih s pomočjo programa Sidsed. Ko je geometrija gotova s programoma Sdrc in Strace preverimo, ce je vezje nacrtano po nacrtovalskih pravilih in elektricno skladnost simboličnega opisa. Strace nam izloči tudi velikosti tranzistorjev in povezav med njimi iz simboličnega opisa. S programom Compare nazadnje primerjamo velikosti tranzistorjev in povezav med njimi, ki jih dobimo iz logicnega in iz simboličnega opisa. Vse to preverjanje zagotavlja, da nacrtano vezje nima napak. Zadnji program iz paketa SIDS Stp nam pretvori simbolični opis v mnogokotnike in jih zapise v geometricno bazo podatkov. To je moč izrisati na elektrostaticni risalnik.

Izurjen nacrtovalec potrebuje za celoten proces vnosa logicnega oz. funkcionalnega opisa en do tri tedne. Skupaj z nacrtovalcem geometrije mask potrebuje izdelavo blokov in za ročno namescanje in povezovanje le teh nekaj mesecev. Ostali postopki trajajo toliko časa kot pri metodi standardnih celic, kar da skupaj več kot tri meseca.

#### Viri:

1. Power MOSFETs: Power for the 80s, Duncan Grant, Allian Tregidga, Solid State Technology, Nov. 1985
2. Mixed process chips are about to hit the big time, Bernard Conrad Cole, Electronics, March 3, 1986
3. 1. Sola za nacrtovanje mikroelektronskih vezij v Iskri; interno gradivo, Nov. 1985
4. Stretching the limits of software, Bernard Conrad Cole, Electronics, June 23, 1986

**UDK: 681.324**

**Slavko Mavrič, Branko Miholovič, Peter Kolbezen  
Institut Jožef Stefan, Ljubljana**

**Članek predstavlja funkcijo povezovalne mreže v večprocesorskem sistemu in spregovori o njenih bistvenih lastnostih. Opisane so pomembnejše topologije enostopenjskih in večstopenjskih povezovalnih mrež in narejena kvalitativna primerjava med njimi. Na koncu je podan primer sistema na osnovi skupnega vodila.**

**In the article the function and the basic properties of the interconnection network in a multiprocessor system are presented. We describe the principal topologies of singelstage and multistage interconnection networks. Also, the qualitative comparition between them is made. Finally, we present an example of global bus based system.**

## **1. UVOD**

Sodobna elektronska tehnologija omogoča gradnjo paralelnih računalniških sistemov, ki jih sestavlja na stotine ali celo na tisočine procesorjev. Eden izmed največjih problemov pri gradnji takih paralelnih sistemov je v izbiri prave povezovalne mreže za udinkovito medsebojno povezavo procesorjev, pomnilniških modulov in drugih naprav. Optimalna izbira povezovalne mreže za nek sistem zavisi predvsem od namenosti sistema (aplikacije), velikosti sistema, zahtevane hitrosti, cenovnih omejitev... Z govorstvo lahko rečemo, da šele prava povezovalna mreža omogoči pričakovano udinkovitost celotnega sistema.

## **2. VLOGA POVEZOVALNE MREŽE**

V logičnem smislu predstavlja povezovalna mreža zaključeno enoto z M vhodi in N izhodi ter lastno preslikovalno funkcijo, ki opisuje povezovalne lastnosti mreže. Statično preslikovalno funkcijo najlaže podamo v obliki matrike z M vrsticami in N stolpci. Element matrike  $a_{ij}$  je enak 1, če mreža omogoča povezavo med vhodom i in izhodom j, sicer pa je enak 0. Statična preslikovalna funkcija govori o povezovalnih lastnostih "prazne" povezovalne mreže, kar pomeni, da v trenutku, ko ocenjujemo možnost povezave i,j še ne obstaja nobena povezava v mreži.

Naloga povezovalne mreže večprocesorskog sistema je ta, da omogoča povezavo med mnogico procesorjev in mnogico pomnilniških modulov sistema. Pri tem obstajata dva osnovna pristopa.

Pri prvem pristopu tvori vsak procesor skupaj s pripadajočim lokalnim pomnilnikom procesni element (PE). Ti procesni elementi so medsebojno povezani prek povezovalne mreže tako, da je vsak procesni element priključen na vhodno in izhodno linijo povezovalne mreže. Imenujmo tak način povezave PE-na-PE pristop (Slika 1).

Drug pristop postavlja povezovalno mrežo med mnogico procesorjev in mnogico pomnilniških enot. Imenujmo ga P-na-M pristop (Slika 2).

Glavna prednost prvega pristopa je v hitrem dostopu do lokalnega pomnilnika, medtem ko je prednost drugega pristopa v tem, da si procesorji delijo pristop do obsežnih podatkovnih blokov in da je obseg pomnilnika, ki pripada posameznemu procesorju spremenljiv.

Možna je tudi kombinacija obeh pristopov, pri kateri se procesni elementi povezujejo preko mreže med seboj, kot tudi z globalnimi pomnilniškimi enotami (PE-na-M pristop).



**Slika 1: PE-na-PE pristop**



Slika 2: P-na-M pristop

### 3. OSNOVNE ZNADILNOSTI POVEZOVALNIH MREŽ

Na izbor arhitekture povezovalnih mrež vplivajo predvsem naslednji dejavniki: delovni način, strategija krmiljenja, metoda preklapljanja in topologija mreže.

Glede na delovni način razlikujemo med sinhrono in asinhrono komunikacijo. Pri prvi se komunikacijske poti vzpostavljajo sinhrono s funkcijami manipulacije s podatki in posredovanjem podatkov in instrukcij, medtem ko se pri drugem načinu zahteve za komunikacijo posredujejo dinamično. Sistem je lahko zasnovan tako, da predvideva sinhrono in asinhrono procesiranje, tako da govorimo pravzaprav o treh delovnih načinih povezovalnih mrež: sinhroni, asinhroni in kombinirani delovni način.

Ker tipična povezovalna mreža sestoji iz množice preklopnih elementov in povezav, se komunikacija med dvema vozliščema sistema vzpostavi z odgovarjajočim krmiljenjem preklopnih elementov, pri čemer sta splošno uporabljena dva pristopa. Prvi pristop združuje kraljine funkcije vseh preklopnih elementov v centralnem krmilniku, medtem ko je pri drugem krmiljenje prepusteno posameznim preklopnim elementom povezovalne mreže. V prvem primeru govorimo o centralnem, v drugem primeru pa o porazdeljenem krmiljenju.

Dve glavni metodologiji preklapljanja sta aparатурno in paketno preklapljanje. Pri prvem se v času komuniciranja vzpostavi fizična pot med izvorom in ponorm. Pri paketnem preklapljanju pa podatki, organizirani v pakete, potujejo skozi povezovalno mrežo brez vzpostavljenje celotne poti. Velja, da je aparaturno preklapljanje bolj primerno za veliko množino podatkov, medtem ko je paketno preklapljanje primernejše za krajsa sporodila. Tretja metodologija, integrirano preklapljanje, izdržuje lastnosti oba, tako da lahko govorimo o treh metodologijah: aparaturno, paketno in integrirano preklapljanje.

Topologija povezovalne mreže je lahko predstavljena z grafiom, kjer vozlišča predstavljajo elemente mreže, povezave grafa pa ponazarjajo komunikacijske povezave med njimi. Topologije lahko klasificiramo v dve glavni skupini, to so eno in večstopenjske. Enostopenjske povezovalne mreže sestojte iz le ene stopnje preklopnih elementov, ki ji sledi nek povezovalni vzorec. Pri večstopenjskih povezovalnih mrežah pa srečamo množico stopenj preklopnih elementov in povezovalnih vzorcev, tako da pot med poljubnim vodom in izhodom mreže vodi skozi vse stopnje.

Kartezični produkt navedenih dejavnikov oblikuje prostor povezovalnih mrež večprocesorskih sistemov. Seveda vsebuje ta prostor nekaj neza-

nimivih točk, vendar nas izbiранje primerne arhitekture omeji na podprostor primernih rešitev za postavljene zahteve.

Topologija mreže je ključnega posena pri določanju primerne arhitekture, zato se bomo v nadaljevanju posvetili topologijam povezovalnih mrež.

### 4. ENOSTOPENJSKE POVEZOVALNE MREŽE

Bistveno za to skupino mrež je, da sestoje iz le ene stopnje preklopnih elementov, kar pomeni, da je za polje N procesnih elementov potrebno polje N preklopnih elementov. Mreža tega tipa je mogoče enostavno razdeliti tako, da se posamezni preklopni elementi pridružijo aparatori opremi pripadajoče procesne enote. Enostopenjske mreže lahko klasificiramo v dve skupini, to so statične in dinamične mreže. Pri statičnih mrežah so povezave pasivne, kar pomeni, da je fizična povezava med dvema procesnima elementoma fiksna in je ni mod preusmeriti za komunikacijo z drugim procesnim elementom. Pri dinamičnih mrežah pa se komunikacijske poti lahko rekonfigurirajo s krmiljenjem preklopnih elementov povezovalne mreže. Ker statične enostopenjske povezovalne mreže v splošnem ne omogočajo vseh povezav direktno ampak iterativno, mora v splošnem nek podatek na poti od izvora do ponora večkrat potovati skozi mrežo.

Opisali bomo nakaj topologij enostopenjskih mrež s tem, da bomo definirali funkcije mrežnih preklopnih elementov z njihovo preslikovalno funkcijo, oziroma naborom preslikav, ki jih le ti lahko generirajo.

Imejmo N vozlišč in jih označimo v vrstnem redu od 0 do N-1. Neka preslikava  $P(x) = y$  nam pove, da obstaja povezava od vozlišča x k vozlišču y.

#### 4.1. Statične enostopenjske mreže

##### Obroč

Mreža definira premikalna preslikava.

$$P_1(x) = x+1 \text{ mod } N \quad +1 - \text{premikalna preslikava}$$

To je najpreprostejša mreža, ki sestoji iz obroča procesnih elementov, tok podatkov pa je enosmeren. (slika 3.)



Slika 3: Obroč



Slika 4: Mreža sosedstva.

### Mreža sosedstva

Predstavlja enostavno razširitev obroda tako, da omogoča dvostraten tok informacij. Generira dve preslikave:

$$\begin{aligned} P_{+1}(x) &= x+1 \bmod N & +1 & - \text{premikalna preslikava} \\ P_{-1}(x) &= x-1 \bmod N & -1 & - \text{premikalna preslikava} \end{aligned}$$

Obrod in mreža sosedstva sta primerna za relativno majhno število procesnih elementov, saj za povprečni čas potovanja podatkov ( $T_d$ ) pri obroču velja  $T_p = (N/2)T_d$  pri mreži sosedstva pa  $T_p = (N/4)T_d$ , kjer  $T_d$  predstavlja čas potreben za komunikacijo med dvema sosednjima procesnima elementoma.

### Illiac mreža

Te mrežo sosedstva obogatimo z dvema novima preslikavama, tako da imamo

$$\begin{aligned} P_{+1}(x) &= x+1 \bmod N & +1 & - \text{premikalna preslikava} \\ P_{-1}(x) &= x-1 \bmod N & -1 & - \text{premikalna preslikava} \\ P_{+n}(x) &= x+n \bmod N & +n & - \text{premikalna preslikava} \\ P_{-n}(x) &= x-n \bmod N & -n & - \text{premikalna preslikava} \end{aligned}$$

In te je  $N$  popolen kvadrat ( $N = n^2$ ), dobimo Illiac mrežo, ki je uporabljena v sistemu Illiac IV. V tej mreži je vsak procesni element povezan s svojimi severnimi, južnimi, vzhodnimi in zahodnimi sosedom, kot prikazuje slika 5.



Slika 5: Illiac mreža

### Mreža hiper-kocke

Pri tej in naslednjih predstavljenih topologijah opišemo preslikave laže z logičnimi in premikalnimi funkcijami nad biti v dvojniškem zapisu oznake vozlišča. Preslikave:

$$O(pp_{i-1} \dots p_i) = qq_{i-1} \dots q_i$$

pove, da obstaja povezava od vozlišča z oznako  $pp_{i-1} \dots p_i$  k vozlišču  $qq_{i-1} \dots q_i$ .

Mreža hiper-kocke dimenzijs  $m$  definira  $m$  preslikav tipa:

$$C(pp_{m-1} \dots p_1) = pp_{m-1} \dots p_1 \dots q_i \quad i = 1, 2, \dots, m$$

če si procesne elemente take mreže predstavljamo kot ogljikasti  $m$ -dimensionalne kocke vidimo, da je vsak procesni element povezan z  $m$  sosedji, kar prikazuje slika 6.



Slika 6: Mreža hiper-kocke ( $m = 3$ )

### Mreža popolnega mešanja

Mreža popolnega mešanja (perfect shuffle) definira preslikavi mešanja in zamenjave.

$$S(pp_{m-1} \dots p_1) = q_{i-1} q_{i-2} \dots q_1$$

$$E(pp_{m-1} \dots p_1) = pp_{m-1} \dots p_1$$

Prikazuje jo slika 7. Cele črte ponazarjajo zamenjavo, prekinjene pa mešanje.



Slika 7: Mreža popolnega mešanja

### 4.2. Dinamične enostopenjske mreže

#### Skupno vodilo

Mreža opisujejo preslikave:

$$B(x) = y \quad y = 0, 1, \dots, N-1 \quad y = x$$

Ta mreža omogoča vse preslikave direktno, toda zaradi le ene fizичne poti samo eno naenkrat.



Slika 8: Skupno vodilo

### Popolna stikalna polje (cross bar)

Preslikovalna funkcija te mreže je enaka kot pri skupnem vodilu, torej:

$$B(x) = y \quad y = 0, 1, \dots, N-1 \quad y = x$$

Bistvena razlika je v tem, da omogoča ta mreža vse povezave hkrati.



Slika 9: Popolno stikalno polje

Poudarimo še enkrat, da zahteva statična enostopenjska mreža iterativni prenos podatkov skozijo za doseg poljubne preslikave. Z iterativnostjo mislimo na dejstvo, da mora nek podatek, poslan z izvornega procesnega elementa proti ponornemu elementu, na svoji poti obiskati neko možico vasnih oziroma poaredovalnih elementov in nekajkrat potovati skozi povezovalno mrežo. Zato je za takso mrežo bistvenega pomena podatek o številu potrebnih iteracij za doseg poljubne preslikave. Z namenom primerjanje predstavljenih mrež vpeljmo pojem razdalje. Razdalja med dvema elementoma i in j je enaka številu potrebnih iteracij za doseg preslikave  $i \rightarrow j$ .

Povezovalne mreže bomo primerjali po dveh kriterijih: kriteriju maksimalne oddaljenosti in kriteriju distribucije.

Kriterij maksimalne razdalje podaja največjo razdaljo med dvema elementoma mrež, medtem ko kriterij distribucije opisuje razdaljo potrebno za posredovanje neke informacije vsem elementom v mreži, oziroma je enak številu zaporednih grup paralelnih preslikav potrebnih za doseg tega cilja, s tem, da so znotraj neke grupe vse preslikave istega tipa. Oba kriterija predstavljata nekakšno merilo učinkovitosti posamezne mreže. Za opisane povezovalne mreže sta podana v spodnji tabeli.

| Pov. mreža    | Maks. razdalja | Distribucija    |
|---------------|----------------|-----------------|
| Obrod         | $N-1$          | $N-1$           |
| M.sosedstva   | $N/2$          | $N-1$           |
| Illiac        | $\sqrt{N}-1$   | $2(\sqrt{N}-1)$ |
| Hiper-kocka   | $\log N$       | $\log N$        |
| Pop. mešanje  | $2\log N-1$    | $2\log N-1$     |
| Skupno vodilo | 1              | $N-1$           |
| Pop.st.polje  | 1              | $\log N$        |

## 5. VEĐSTOPENJSKE POVEZOVALNE MREZE

Ta tip povezovalne mreže omogoča vse preslikave vhodov na izhode direktno. Dobljen je z rekurzivno dekompozicijo popolnega stikalnega polja (cross bar) do preklopnih elementov velikosti  $2 \times 2$ . Veđstopenjske povezovalne mreže torej sestojijo iz več stopenj preklopnih elemen-

tov oz. celic. Bistveni parametri veđstopenjske mreže so: uporabljenja preklopna celica, topologija in način krmiljenja preklopnih elementov.

Kot redeno je za preklopno celico navadno uporabljeno stikalno z dvema vhodoma in dvema izhodoma, ki je lahko v enem izmed dveh (slika 10a) ali štirih stanj (slika 10b). V prvem primeru omogoča mreža vse preslikave tipa eden-na-edem, v drugem primeru pa tudi eden-na-več.



Slika 10a: Preklopna celica z dvemi stanji



Slika 10b: Preklopna celica s štirimi stanji

Topologijo mreže predstavlja uporabljen povezovalni vzorec med naborom vhodnih in izhodnih linij povezovalne mreže. Veđstopenjsko mrežo sestavlja  $M$  stopenj s po  $N/2$  preklopnih celic, kjer za  $M$  velja neenačba:

$$\log N \leq M \leq 2\log N - 1$$

kjer je  $N$  enak številu vzhodnih oziroma izhodnih linij povezovalne mreže. Iz tega je razvidno, da kompleksnost povezovalne mreže raste s faktorjem  $O(N \log N)$ , kar je v primerjavi z  $O(N^2)$  kompleksnostjo popolnega preklopnega polja precej bolj prihragen predvsem pri velikih vrednostih  $N$ . Veđstopenjske mreže so torej najbolj primerne za sisteme z velikim številom procesnih elementov.

Kar zadeva strategijo krmiljenja in metodo preklapljanja sledimo pri veđstopenjskih povezovalnih mrežah centralno in porazdeljeno krmiljenje, kot tudi operativno in paketno preklapljanje. Izbrani koncept doloda izgled preklopne celice, saj mora le-ta upoštevati protokol, ki ga določata strategija krmiljenja in metoda preklapljanja. Opisali bomo topologijo najbolj uporabljenih veđstopenjskih povezovalnih mrež.

### Mreža osnovne linije (Baseline)

Sestavlja jo  $\log N$  stopenj, katerih vsaka ima  $N/2$  preklopnih celic  $2 \times 2$ . Priprimo mreži sledete označbe: stopnje naj bodo označene od leve proti desni s številkami od 0 do  $\log N-1$ , povezovalne vzorce označimo v isti serii od 0 do  $\log N$ . Preklopnim celicam posamezne stopnje pripadajo vrednosti od 0 do  $N/2-1$  v serii od zgoraj navzdol, prav tako pa označimo posamezne povezave znotraj vsakega povezovalnega vzorca od 0 do  $N-1$ . Preslikava podana v obliki:

$$PE(P,j) = (R), s. povezavo (Q)$$

posen, da obstaja povezava med preklopnim elementom  $P$  stopnje  $i$  in preklopnim elementom  $R$  stopnje  $j$  in da je ta povezava  $Q$ .  $P, R$  in  $Q$  bodo nastopali v obliki dvojščrkga zapisa.

Topologija mreže osnovne linije podajata naslednji pravili:

$$\text{EC}(\langle p_{i-1}, \dots, p_i \rangle) = \langle p_{i-1} \dots p_{i+1}, 0 p_i \dots p_{i+1} \rangle$$

s povezavo  $\langle p_{i-1} \dots p_i 0 \rangle$   $0 \leq i < 1$

in

$$\text{EC}(\langle p_{i-1}, \dots, p_i \rangle) = \langle p_{i-1} \dots p_{i+1}, 1 p_i \dots p_{i+1} \rangle$$

s povezavo  $\langle p_{i-1} \dots p_i 1 \rangle$   $0 \leq i < 1$

Mreža osnovne linije z  $N=8$  podaja slika 11.



Slika 11: Mreža osnovne linije

#### Posredna n-kocka (indirect n-cube)

Povezovalni vzorci te mreže temelje na principu povezav pri hiper-kocki s tem, da je v vsaki stopnji realizirana ena izmed povezav, to pomeni, da se poljubni dva preklopni celici dveh sosednjih stopenj razlikujeta kvedjemu v enem bitu svojih oznak. Formalni opis topologije podajata naslednji formuli:



Slika 12: Mreža posredne n-kocke

$$\text{KE}(\langle p_{i-1}, \dots, p_i \rangle) = \langle p_{i-1} \dots p_{i+2}, 0 p_i \dots p_{i+1} \rangle$$

s povezavo  $\langle p_{i-1} \dots p_i 0 \rangle$   $0 \leq i < 1$

in

$$\text{KE}(\langle p_{i-1}, \dots, p_i \rangle) = \langle p_{i-1} \dots p_{i+2}, 1 p_i \dots p_{i+1} \rangle$$

s povezavo  $\langle p_{i-1} \dots p_i 1 \rangle$   $0 \leq i < 1$

Če tej povezovalni mreži zamenjamo vrstni red povezovalnih vzorcev med stopnjami, dobimo topologijo, ki je znana kot Banyanova mreža. Izgled posredne n-kocke za  $N=8$  je na sliki 12.

#### Omega povezovalna mreža

Ta mreža, prav tako kot gornji, sestoji iz log N stopenj s po  $N/2$  preklopni celicami. Povezovalni vzorci med posameznimi stopnjami mreže so vsi enaki in temelje na preslikavi popolnega mešanja po naslednjem pravilu:

$$\text{OC}(\langle p_{i-1}, \dots, p_i \rangle) = \langle p_{i-1}, p_{i-2} \dots p_1 \rangle$$

s povezavo  $\langle p_{i-1} \dots p_1 0 \rangle$   $0 \leq i < 1$

in

$$\text{OC}(\langle p_{i-1}, \dots, p_i \rangle) = \langle p_{i-1}, p_{i-2} \dots p_1 \rangle$$

s povezavo  $\langle p_{i-1} \dots p_1 1 \rangle$   $0 \leq i < 1$



Slika 13: Omega mreža

Vse tri predstavljene povezovalne mreže sestavlja log N stopenj, katerih vsaka ima  $N/2$  preklopnih elementov  $2 \times 2$ . Tak tip mreže omogoča direktno povezavo poljubnega vhoda s poljubnim izhodom, vendar ne sočasno. Lahko bi pokazali, da so te mreže topološko ekvivalentne ena z drugo, oziroma, da imajo izomorino topologijo. To pomeni, da z ustrezeno premestitvijo preklopnih elementov pri enem tipu mreže pridemo do drugega.

#### Benesova mreža

Povezovalna mreža, pri kateri se lahko v vsakem trenutku doseže povezava nekega vhoda z zeljenim izhodom s preureditvijo že obstojedih povezav, mora imeti vseje število stopenj, navadno  $M = 2 \log N - 1$ . Primer take mreže je Benesova mreža. Povezovalni vzorci te mreže so isti kot pri mreži osnovne linije s tem, da vsak vzorec nastopa dvakrat. Prikazuje jo slika 14.



Slika 14: Benesova mreža



Slika 15: Diagram kvalitete mrež

| Mreža   | P     | I             | T                | E              | L | I | K                                 |
|---------|-------|---------------|------------------|----------------|---|---|-----------------------------------|
| Obroč   | N     | N             | N                | N              | N |   | 1/2                               |
| Vodilo  | 1     | 2             | N                | 1              |   |   | $N/(2N+2)$                        |
| Pop.st. | N     | 4             | $N/4$            | $2N$           |   |   | $N/(N+8)$                         |
| n-kocka | $N/2$ | $\log N$      | $N \log N/2$     | $N + N \log N$ |   |   | $N/(\log N(2+3\log N))$           |
| Benes   | N     | $2\log N - 1$ | $N \log N - N/2$ | $2N \log N$    |   |   | $2N/((2\log N - 1)(6\log N - 1))$ |

## 6. OCENA KVALITETE MREŽ

Predstavili smo topologije pomembnejših povezovalnih mrež, ki so se pojavile v paralelnih računalniških sistemih. Poudarili smo že, da je izbiro povezovalne mreže odvisna od več parametrov, med katerimi je najpomembnejši število procesnih elementov. Stevilo procesnih elementov določa fizično kompleksnost mreže in njene funkcionalne lastnosti. Fizična kompleksnost mreže se izraža v številu preklopnih elementov in številu fizičnih povezav, o funkcionalnih lastnostih pa govori maksimalno število sodasnih zvez v mreži in pa podatek o času, potrebnem za prenos paketa podatkov skozi mrežo. Vpeljimo pojem kvalitete mreže, ki nam bo služila kot kriterij pri določanju primerne mrežne topologije za določeno število procesnih elementov. Kvaliteto mreže definira naslednja enačba:

$$K = NP/(T(E+L))$$

N.....Stevilo procesnih elementov sistema  
P.....maksimalno število sorašnih zvez  
T.....čas prehoda skozi mrežo  
E.....število preklopnih elementov mreže  
L.....število fizičnih povezav mreže

V gornji tabeli smo podali posamezne parametre in kvalitete nekaj mrež. Izmed statičnih enostopenjskih mrež smo izbrali obroč, izmed vedostopenjskih z  $M = \log N$  pa mrežo posredne n-kocke. Lahko bi se prepričali, da je kvaliteta ostalih statičnih enostopenjskih mrež istega reda kot kvaliteta obroča, kvaliteta vedostopenjskih mrež z  $M = \log N$  pa istega reda kot kvaliteta posredne n-kocke. Iz diagrama na sliki 15. lahko vidimo, da je za majhno število procesnih elementov najboljša rešitev popolno stikalno polje, dobra pa sta tudi obroč in skupno vodilo. Za več kot 64 procesnih elementov pa sta kvalitetnejši posredna n-kocka in Benesova mreža.



Slika 16: Arhitektura sistema na Q-vodilu

## 7. ZAKLJUČEK

Naj namesto zaključka predstavimo arhitekturo eksperimentalnega večprocesorskega sistema s skupnim vodilom, ki nastaja na našem institutu. Arhitekturo sistema prikazuje slika 16. Uporabljeni je asinhrono DEC-ovo Q vodilo. Funkcijo arbitraže skupnega vodila prevzema procesor LSI 11/23, ki je hkrati tudi skupni vmesnik masovnega pomnilnika; vsak procesor sistema lahko posega po masovnem pomnilniku in preko LSI 11/23. Trenutno je procesni element (PE) zasnovan na mikroprocesorju Z80A. Vsebuje 64K zlogov lokalnega pomnilnika. Z zunanjim svetom ga povezuje 8 nadzorno/statusnih besed (IOCSR). Vsak izmed procesnih elementov lahko posega neposre-

dno po svojem lokalnem pomnilniku, po skupnem pomnilniku in po nadzorno/statusnih besedah drugega procesnega elementa. Ker ima G-vodilo možnost 22 bitnega naslavljanja, lahko v sistemu uporabimo do 4M zlogov skupnega pomnilnika.

#### 8. LITERATURA

- [C1] R.W.Hockney, C.R.Jesshope: Parallel Computers, Adam Hilger Ltd, Bristol 1981
- [C2] Tse-Yun-Feng: A Survey of Interconnection Networks, Computer, December 1981 pp.12-27
- [C3] Chuan-Lin-Wu, Tse-yun-Feng: On a Class of Multistage Interconnection Networks, IEEE Transactions on Computers, August 1980 pp. 694-702
- [C4] H.J.Siegel: Interconnection Networks for SIMD Machines, Computer, Junij 1979 pp. 57-65
- [C5] H.J.Siegel: A Model of SIMD Machines and a Comparison of Various Interconnection Networks, IEEE Transactions on Computers, December 1979, pp. 907-917
- [C6] H.J.Siegel: The Multistage Cube:A Versatile Interconnection Network, Computer, December 1981, pp. 65-76
- [C7] Chin-Yuan-Chin, Kai-Huang: Connection Principles for Multipath Packet Switching Networks, The 11th Anual International Symposium of Computer Architecture, June 1984, pp. 99-108
- [C8] P.Brajak: Paralelno procesiranje: arhitektura 90-tih godina, Zbornik jugoslavenskog savjetovanja o novim generacijama računala, MIPRO 86, Maj 1986, pp. 33-46

UDK: 681.323:656.616.3

Andrej Novak  
Višja pomorska šola Piran

Clanek opisuje široko uporabo elektronskih in računalniških sistemov v pomorskem prometu. sledi opis ladijskega informacijskega sistema in njegovih podsistemov. Prikazano je sedanje stanje na ladjah in možnosti, katere imamo pri nas za vključitev v to panogo industrije. Ena izmed naših možnosti je izdelovanje računalniških sistemov za tovorjenje ladij. Clanek je zaključen z opisom osnovnih načel za izdelavo takega sistema.

Ship's information system  
and loading of ships by computer.

This paper describes the wide use of electronic and computer systems in the sea transport. A description of the ship's information system and its subsystems follows. The present situation on board the ships and our possibilities to be included in that field of industry is pointed out. One of our possibilities is the building up of such computer systems for the loading of ships. Finally a description of the basic principles for the building up of such system is included.

## 1. UVOD

Hitro uvažanje elektronike, avtomatizacije in računalništva opažamo v vseh panogah gospodarstva, prav tako tudi v pomorskem gospodarstvu.

Potrebno je pripomniti, da so se zgoraj omenjene tehnologije pojavljale v pomorskem prometu vedno z manjšo časovno zakasnitvijo. Vzrok za njo so strogi predpisi pomorskih uradov. Ti namreč predpisujejo zaradi varnosti plovbe v praksi predhodno preverjene in varne sisteme.

Tako so se z zaporednim razvojem elektronike, avtomatizacije in računalništva vistem kronološkem zaporedju pojavili na ladjah v prvih desetletjih tega stoletja najprej radiooddajniki, sprejemniki, radiogoniometer in vrtavčni kompasi. Obdobje druge svetovne vojne je dalo sisteme Consol, Loran, Decca in radar. V naslednjih dveh desetletjih pridobi pomorstvo globalne navigacijske sisteme Omega, satelitski in inercialni sistem. V zadnjih petnajstih letih pa so se na vseh področjih pomorske dejavnosti v veliki meri začeli uporabljati računalniški sistemi. Tako današnja poveljniška mesta v pomorskem prometu predstavljajo elektronsko računalniški sistemi, v katerih se klasični pomorščak srednjih let le s težavo znajde.

Danes bi informacijske sisteme v pomorskem prometu lahko razdelili v sledeče skupine:

### 1.1. Komercialno-operativni informacijski sistem

Nahaja se v pomorski delovni organizaciji. Njegova naloga je ekonomsko in operativno vodenje delovne organizacije in njej pripadajočih ladij.

### 1.2. Ladijski informacijski sistem

Nahaja se na ladjah. Služi za varnost ladij v plovbi in njihovo ekonomsko izkoriščenost.

Zgoraj omenjena sistema sta povezana s satelitskim komunikacijskim sistemom.

### 1.3. Vremensko vodenje ladij

Ta sistem sestavljajo sinoptični center, računalniški center in ladje. Glede na vremenske in oceanografske pogoje ter plovne lastnosti ladij računalnik za vsako ladjo posebej izračuna njo dnevno optimalno pot. Ladjarji, ki so uporabljali ta sistem, so beležili vidne prihranke zaradi časovno krajev plovbe, manjše porabe goriva in nepožkodovanega tovora.

#### 1.4. Informacijski sistemi za varnost plovbe

To so radarsko računalniški sistemi novejšega datuma. Osrednji računalniški sistem se nahaja največkrat v pristanišču. Radarske postaje kot senzorji se nahajajo v pristanišču, pred njim in v področjih gostega ali nevarnega prometa. Računalnik spremja gibanje ladij. Pri tem opozarja na spremembe v njihovih gibanjih, na plovbo, katera ni v skladu s predpisi in na ladje, ki so v nevarnosti. Kontrola prometa in ladje so zaradi potrebnih informacij povezani s komunikacijskim sistemom.

#### 1.5. Simulacijski sistemi

Tudi ti sistemi so novejšega datuma. To so navigacijski, radarski, strojni, protipožarni simulacijski sistemi, simulacijski sistemi za tovorenje ladij in manevriranje z njimi ter drugi. Uporabljajo se predvsem za izobraževanje pomorskih kadrov, pa tudi za raziskovalno delo. Izobraževanje pomorskih kadrov na simulatorjih je ekonomično, občirno, na visokem nivoju in hitro.

Tudi pri gradnji ladij uporabljajo tuje in naše ladjedelnice CAD in druge računalniške sisteme.

V dalnjem tekstu bomo opisali le ladijski informacijski sistem, kasneje pa bomo opis že z očili na načela izdelave enega njegovih podsistemu, to je podsistem za računalniško tovorenje ladij.

### 2. LADIJSKI INFORMACIJSKI SISTEM

Ladijski informacijski sistem je sestavljen iz več podsistemu. Ukrepi za varno in ekonomično plovbo, ki sledijo iz zbranih informacij, so na današnji stopnji že vedno prepričeni človekovi presoji. Zato so sistemi le delno povezani, niso pa povezani v integrirani sistem za popolno avtomatično vodenje ladje, čeprav so se taki poskusi vrtili. Večina današnjih podsistemu deluje na osnovi računalnikov. Vendar ladja zopet nima centralne procesorske enote. Njena preobremenitev ali izpad bi delno ali popolnoma chromila ladjo. Tako ima vsak podsistem in večkrat celo vsak instrument v njem lasten računalnik. Izpad posameznega računalnika tako ne predstavlja nevarnosti za plovbo, saj se sistemi prekrivajo, velikokrat pa so podvojeni.

Ladijski informacijski sistem bi lahko razdelili na devet podsistemu.

#### 2.1. Navigacijski podsistem

Sprejemniki tega podsistemu se nahajajo na poveljniškem mostu ladje. Podsistem služi za varno vodenje ladje po poti od točke odhoda do točke prihoda. Po tej poti vodita ladjo vrtavčni kompas in avtopilot. Vendar se ladja zaradi učinkov yetra in morskih tokov večkrat oddalji od predpisane poti. Da bi ugotovili pravi položaj ladje in jo usmerili na predpisano pot, smo do nedavnega uporabljali klasične terestrične in astronomiske metode. Danes v ta namen večinoma uporabljamo elektronsko računalniške sprejemnike navigacijskih sistemov. To so radiogoniometer, Decca, Loran, Omega in satelitski sprejemnik. Ker oddajniki omenjenih sistemov niso pod nadzorom ladje, so ti sistemi strateško odvisni. Zato so neprestana prizadevanja za izpopolnjevanje strateško neodvisnega inercialnega sistema. Morsko globino in hitrost ladje merimo z elektronskimi globinomerji in brzinomerji. Za določanje položaja ladje v obalni plovbi in preprečevanje trčenj na morju uporabljamo

radar. Pri tem je dosegena visoka stopnja avtomatizacije s sodobnimi ARPA radarji, kateri vsebujejo v sebi iz dneva v dan močnejše računalnike, danes še do nekaj MB.

Zgoraj omenjeni sprejemniki dobivajo informacije od oddajnikov sistema s posredovanjem elektromagnetskih valov. Ker so ti pri širjenju skozi atmosfero podvrženi refrakciji, položaj ladje ni popolnoma točen. Če v geodesiji ali pri raziskavah naftnih ležišč zahtevamo večjo točnost položaja, uporabljamo integrirani navigacijski sistem. Ta združuje dva ali več zgoraj opisanih sprejemnikov. Centralni procesor nato obdeluje dobljene informacije, iz vsakega sistema izloči pomembljivosti in tako daje najtočnejši možni položaj ladje.

#### 2.2. Pogonski podsistem

S tem podsistemu nadzorujemo pravilno delovanje glavnega ladijskega stroja, pomožnih strojev in generatorjev. Služi se sinhronizacijo generatorjev ter pravilno nastavitev strojev, s čimer zmanjšujemo porabo pogonskega goriva. Podsistem tudi opozarja na bodoča vadževalna dela. V delovnem času ta podsistem signalizira napake in okvare pogona v kontrolno kabino pogona. Izven delovnega časa pa se alarmi prenesejo v kabino delurnega častnika stroja in na poveljniški most. Večinoma je ta podsistem vezan na navigacijskega na poveljniškem mostu, odkoder lahko tako neposredno upravljamo z glavnim ladijskim strojem.

#### 2.3. Komunikacijski podsistem

Za interne komunikacije na ladji uporabljamo telefon in alarmne naprave. Za komunikacije med ladjami ter ladjo in kopnom uporabljamo na razdaljah do 40 navtičnih milij VHF sistem, na velikih razdaljah pa radiotelegrafijo in radiofonijo. Novost predstavlja teleprinterska zveza preko telekomunikacijskih satelitov.

#### 2.4. Protipožarni podsistem

Služi za ugotavljanje in gašenje požarov. Senzorji podsistema se nahajajo v kabinah, strojnem prostoru in v tovornih skladiščih ladje. Detektorja se nahajata na poveljniškem mostu in v kontrolni kabini pogona. Pravočasen alarm podsistema omogoča hitro in uspešno gašenje še le nastajajočega požara. Protipožarna sredstva se lahko vključujejo iz poveljniškega mosta, kontrolne kabine pogona ali iz ostalih protipožarnih mest na ladji.

#### 2.5. Meteorološki podsistem

Meteorološke in oceanografske informacije so izredno važne za varnost ladje in tovora ter ekonomičnost plovbe. Te informacije so na ladji potrebne, da se z njim izognemo manjšim toda nevarnim baričnim telesom kot so tropski orkani, ali da z ladjo izvedemo pravilen manevr v večjih baričnih tvorbah kot so cikloni srednjih širin.

Meteorološke in oceanografske informacije dobivamo v glavnem na tri načine.

##### 2.5.1. Klimatološke informacije dobivamo iz publikacij.

2.5.2. Sinoptične informacije so najvažnejše. Normalno jih dobiva ladja štirikrat dnevno iz vremensoslovnih centrov s pomočjo radiotelegrafije, radiofonije ali radio faksimila. Slednji vsakih 6 ur avtomatično izriče vremensko karto. Če je ladja vključena v vremensko vodenje ladij, kot je to že opisano v poglavju 1.3., dobiva telegrafsko sporočila o njeni optimalni

dnevni plovni poti.

2.5.3. Mikroklimatološke informacije o temperaturah in vlagi v ladijskih skladiščih dobivamo s pomočjo senzorjev ali z merjenji. Ti podatki so pomembni za preprečevanje poškodb tovora.

#### 2.6. Podsistem za tovor

V analogni izvedbi ta podsistem ni nudil zadovoljive natančnosti. V digitalni izvedbi, ki je novejšega datuma, pa ta podsistem nudi potrebno točnost. V tej izvedbi je nujno potreben na kontejnerskih ladjah, služi za popolno avtomatizirano tovorjenje večjih tankerjev, vse hitreje pa se uvaja tudi na ostalih tipih ladij. S tem podsistemom vršimo pravilno razporeditev tovora v ladijskih skladiščih, izračunavamo vgrez, trim, prečno in dinamično stabilnost ladje, določamo upogibne momente in strižne sile. Temu sledi računalniški izpis podatkov in rezultatov ter risanje plana tovora. Podatke o potovanjih shranjujemo v datotekah. Najnovejše izvedbe tega podsistema izračunavajo obnašanje ladje pri prodoru vode. Ena od možnosti razvoja tega podsistema je optimizacija tovorjenja ladje. Bolj občirno bo računalniška problematika tega podsistema opisana v petem poglavju tega članka.

#### 2.7. Podsistem za ladijske zaloge

Ta podsistem daje pregled zalog rezervnih delov za krovno službo in pogon. Bistvena je povezava takih ladijskih podsistemov z osrednjim v ladijskem podjetju.

#### 2.8. Administrativni podsistem

Ta računalniški podsistem vodi pregled nad dokumenti ladje in posadke, ter opozarja na njihovo iztekanje. Z njim vodimo zaloge hrane in ekonomičnost njenih nakupov, ter obračunavamo OD posadke.

Trgovske ladje, katere ne prevažajo potnikov, večinoma nimajo zdravnika. Imajo pa ambulanto in apoteko s predpisanimi zdravili, prvo pomoč pa nudijo častniki krova. V težjih bolezenskih primerih je danačna praksa povezava ladje preko komunikacijskega sistema z določenimi zdravstvenimi centri za pomorstvo, ki dajejo za bovinika diagnozo in terapijo. Tu je možnost razvoja ekspertnega sistema, ki bi na osnovi anamneze iz dialoga računalnik-človek postavil diagnozo in terapijo za bovinika na ladji.

#### 2.9. Upravni in pravni podsistem

Ta podsistem daje poveljniku ladje podatke o upravnih normah v različnih državah sveta in njihovih pristaniščih, ter pravna navodila v izjemnih primerih in primerih nezgod.

### 3. SEDANJE STANJE NA LADJAH

V celoti tak ladijski informacijski sistem s svojimi devetimi podsistemi, kot je opisan v prejšnjem poglavju, na ladjah večinoma še ne obstaja. Obstajajo podsistemi 1 do 5, podsistem za tovor se hitro uvaja, podsistema za zaloge in administracijo se šele uvažata, dočim je upravni in pravni podsistemi šele zamisel, katero bo koristno izvesti.

V primerjavi z vrednostjo ladje cena celotnega ladijskega informacijskega sistema ni visoka. Vendar so klasične metode v primerjavi z elektronskimi in računalniškimi že cenejše. Zakaj se torej na ladje uvajajo sodobni informacijski sistemi? Prvi vzrok je varnost plovbe. Upravni predpisi zato določajo, da

morajo biti ladje opremljene z radiogoniometrom, VHF primopredajnikom in nad določeno nosilnostjo z ARPA radarjem. Povečana varnost zmanjšuje škode, temu primerno se tudi znižujejo visoke zavarovalne premije, odkoder vidimo, da se v varnosti pravzaprav skriva ekonomski vsrok. Drugi vzrok je čisto ekonomskega značaja. Avtomatizirani, elektronsko in računalniško vodeni procesi zmanjšujejo drage ladijske posadke, zmanjšujejo porabo goriva, ter skrajšujejo časa potovanja ladje in njenih postankov v pristaniščih. Privzemimo, da je življenska doba ladje približno 15 let. Po izračunih nekaterih podjetij se zaradi prej omenjenih vzrokov investicijska vrednost avtopilotu, satelitskega navigacijskega sprejemnika in računalniškega sistema za tovorjenje ladje izplača prej kot v enem letu. Uporaba teh sistemov prinaša v naslednjih 14 letih čisti dobiček ladjarju. Tako je uporaba sodobnega ladijskega informacijskega sistema za razumnega ladjarja ekonomsko nujnost.

Oglejmo si stanje pri nas. Kot primer vzemimo novo ladjo Portorož, katero je Slovenski plovbi iz Pirana letos junija predala ladjedelnica Uljanik iz Pule. Na poveljniškem mostu ima ladja radiogoniometer, radar, ARPA radar, globinomer, merilec hitrosti, VHF primopredajnik, požarni detektor, radio faksimil in satelitski sprejemnik. Ker je satelitski sistem globalnega značaja, prekriva sicer z manjšo natančnostjo področja lokalnih sistemov Loran in Decca. Zato ladji nista nujno potrebna sprejemnika teh sistemov. Pogon je avtomatsko krmiljen iz kontrolne kabine pogona, upravljanje z glavnim strojem pa se lahko vrši iz poveljniškega mosta. V delovnem prostoru se nahaja računalnik za tovorjenje ladje. Ladja nima informacijskih podsistemov za zaloge, administracijo in upravno pravnega. Iz navedenega vidimo, da je ladja v pogledu ladijskega informacijskega sistema zadostno in sodobno opremljena. Isto opažamo tudi pri ostalih novogradnjah flote SFRJ in na novejših tujih ladjah.

### 4. NASE MOŽNOSTI RAZVOJA IN IZDELAVE LADIJSKIH INFORMACIJSKIH PODSISTEMOV

Danes domače ladjedelnice gradijo ladje za domače in tuge ladjarje. Domači ladjarji pa gradijo ladje tudi v tujih ladjedelnicah. Pri tem plačujemo visoko ceno v devizah za nakup celotne tehnologije ladijskega informacijskega sistema, katero v celoti vedno uvozimo iz tujine.

Oglejmo si ponovno podsisteme ladijskega informacijskega sistema v istem vrstnem redu, kot smo jih že opisali.

Sedanjo globalno navigacijsko sistema sta Omega in satelitski TRANSIT sistem. Prvi naj bi imel 9 oddajnikov razvrščenih po vsem svetu, drugi pa 6 lastnih satelitov. Razvoj in vzdrževanje takih sistemov zahteva velike investicije, katere zmorejo le tehnološko in ekonomsko najbolj razvite dežele. Sedaj je v razvoju nov satelitski sistem NAVSTAR, ki naj bi zatekel delovati okoli leta 1993. Pri njegovi izvedbi bo soudeležena večina vrhunskih dosežkov tehnoloških in naravoslovnih znanosti. Tudi izdelava radarjev zahteva visoko tehnologijo.

Navigacijska sistema Loran in Decca sta lokalnega pomena. Njun razvoj je zanimiv v vojaške namene. Oddajnike sistema je potrebno varovati, posebno pa še, če so izven državnih meja. Eno od Loran verig, katera pokriva Sredozemlje in Jadran, uporabljamo tudi v trgovski mornarici. Navigacijska točnost sistema je par sto

metrov. To točnost smo imeli priliko opaziti v zadnjem ameriškem napadu na Libijo. Zato je razumljiv povračilni poskus poškodovanja loran oddajnika na Lampedusi.

Pri nas izdelujemo dobre komunikacijske sisteme. Tu je prehod v pomorsko gospodarstvo lahek. Tudi avtopiloti lahko izdelujemo doma.

Meteorološki sistem za pomorstvo je v Jadranu delno razvit. Zanimivo bi bilo raziskati nadaljnje možnosti njegovega razvoja in uvedbe meteorološkega vodenja ladij v Jadranu.

Iz zgoraj omenjenega sledi, da zahteva razvoj prvih petih podsistemu ladijskega informacijskega sistema obširnega razvoja, večje investicije in visoko tehnologijo. Razvidno je tudi, da je pri nas trenutno najlažji prestop v pomorsko gospodarstvo na področju komunikacijskega in meteorološkega podistema.

Bistveno drugačen pa je položaj na področju zadnjih štirih podsistemu. Njihova osnova je nova, hitro se razvijajoča računalniška industrija, kjer še lahko ujemamo korak s časom.

Pri podistemenu za tovor je potrebno izdelati programsko opremo za vsak tip ladje posebej. Če so ladje znotraj tipa ladij različno pregrajevane ali dograjevane, je potrebno programsko opremo priradiiti za vsako ladjo posebej. Tipov ladij pa je v svetu in pri nas veliko. Tu je možnost dela za veliko prizvajalcev programske opreme, toraj tudi za nas. Način vodenja zalog in administracije je odvisen od posamezne delovne organizacije. Najverjetnejše bomo morali za naše delovne organizacije tako programsko opremo izdelovati sami. Ekspertni sistem za postavljanje diagnoze in terapijo bolnika na ladji ter upravno in pravni podistem sta globalnega značaja. V kolikor tu ne bi pohiteli z razvojem, nas bodo večji proizvajalci zlahka izrinili iz tržišča.

Omenjeni štirje podsistemi uporabljajo manjše računalniške sisteme, take kot jih izdelujemo pri nas. Vendar je potrebno pripomniti, da morajo ti sistemi zadovoljevati pogoje delovanja na ladjah. Delovati bi morali pri temperaturah od 0 do 45 stopinj C, pri visoki vlažnosti, slanosti, dimu in prahu. Sistemi bi morali delovati pri zibanju ladje v plovbi in večjih spremembah električne napetosti v pristaniščih. Končno bi morali delovati še pri vibracijah, katere ladji v plovbi povračajo udarci valov in delovanje glavnega stroja.

Sklonimo sedaj zadnje ugotovitve. Cena tuje programske opreme, ki je izdelana za tip ladje ali poslovanja, torej za manjše količine proizvodov, je bistveno višja od domače cene. Pri nas imamo strokovnjake za izdelavo tovrstne programske opreme. Kar zadava zahteve, katera so postavljene aparurni opremi za delovanje na ladjah, je problem rešen, ker taksi sistemi delujejo. V kolikor naša aparurna oprema ne bi zadolžala postavljenim zahtevam, bi jo izboljšali ali je delno dokupili v tujini. S tem bi zaposlili naše strokovnjake, ladjarjem pa znižali stroške za opremo, pri čemer bi bili stroški dinarski. Ko bi se domači podsistemi pojavili na naših ladjah, bi bili pod istimi prizvodnimi pogoji hitro konkurenčni tudi na zunanjem tržišču.

## 5. RAČUNALNIŠKO TOVORJENJE LADIJ

Oglejmo si sedaj potrebo in namen računalniškega sistema za tovorjenje ladij in osnovna načela za njegovo izvedbo.

### 5.1. Potreba in namen računalniškega tovorjenja ladij

Potreba tovorjenja ladje s pomočjo računalnika je za neke tipe ladij postala ekonomična nujnost.

Integralni transport je v pomorske prevoze uvedel kontejnerje. Tako se je razvil poseben tip ladij za prevoz kontejnerjev. Nalaganje kontejnerjev na tako ladjo in razlaganje kontejnerjev iz nje poteka v pristaniščih zelo hitro. Pri tem so za varnost ladje potrebni obširni izračuni njene stabilnosti. Te izračune mora izvršiti ladijska posadka. Edino ona je po določbah zakonov odgovorna za varnost ladje. Te izračune za kontejnersko ladjo pa lahko v realnem času izvrši posadka le s pomočjo računalnika. Ekonomičnost in hitrost poslovanja kontejnerske ladje pa je odvisna tudi od pravilne izbire tovora zanjo in njegove rasporeditve v pristanišču. Zato vršijo predhodne plane tovorjenja kontejnerske ladje, prav tako z računalnikom, luška ali ladjarška podjetja.

Posadke velikih tankerjev za prevoz tekočih goriv morajo izvrševati nekoliko manj obsežne izračune stabilnosti. Imajo pa težave z odpiranjem in zapiranjem ventilov ter pogonom črpalk za tovorjenje ali istovorjenje goriv, ki so na taki ladji na večjih razdaljah. Prihranke v času in denarju so beležili tisti ladjarji, ki so na take ladje uveli računalniško vodenje sisteme, kateri poleg izračunov stabilnosti tudi računalniško daljinsko krmilijo ventile in črpalk pri tovorjenju in istovorjenju goriv.

Znane voznine v svetovnem pomorskem prometu narekujejo zmanjševanje dragih ladijskih posadk. Da bi zmanjšana posadka lahko opravila vsa tekoča dela, potrebuje za izvrševanje del višjo tehnologijo. Tako se računalniki za tovorjenje ladij danes pojavljajo na vseh tipih ladij.

Namen računalniškega tovorjenja ladje je torej hitrejše opravljanje standardnih izračunov. To so izračuni vgresov ladje, trima, ter prečne in dinamične stabilnosti. Hitrejše računanje omogoča izračun večih variant in izbiro najboljše. Novejše ladje so večje in ekonomičneje grajena. Zato so pri njih potrebnih dodatnih izračuni dovoljenih upogibnih momentov in strišnih sil. Vsem tem izračunom sledi računalniški izpis podatkov in rezultatov, ter risanje plana tovora. Končno spravimo vse podatke in rezultate za vsako potovanje v datoteko.

### 5.2. Zahteve pri računalniškem tovorjenju ladij

Da bi računalniški sistem za tovorjenje ladij opravičil svoj namen, mora izvrševati izračune bistveno hitreje od dosedanjih tabelarnih postopkov. To postavlja izvedbi sistema sledeče zahteve:

-Sistem mora biti avtonomen. To pomeni, da operater vnaša v računalnik samo najnujnejše meritve in podatke. Sistem torej izloča vsakršno uporabo grafov ali tabel.

-Začetne vrednosti spremenljivk vstavlja sistem sam.

-Menu-ji morajo omogočati tako izbiro podprogramov in njim pripadajočih strani, da je vnos najnujnejših skupin spremenljivk najhitreje izvršen.

-Na oba načina vstavljeni spremenljivki shranimo. Shranjene morajo biti tako, da se po men-

javi strani zopet prikašajo na ekranu. Po spremembji poljubne spremenljivke morajo biti vse spremenljivke in njim pripadajoče vrednosti dostopne za zaključni račun.

-Obstojati mora možnost, da z enim ukazom sprememimo vrednosti določeni značilni skupini spremenljivk in njim pripadajočih vrednosti.

-Med vnosom dveh zaporednih spremenljivk se morajo delni podprogrami izvrševati v realnem času. Ta je manjši od ene sekunde.

-Zaradi izvrševanja delnih podprogramov v realnem času morajo biti njihovi algoritmi časovno učinkoviti. Program pa mora biti tudi prostorsko učinkovit. Mejo med obema učinkovitostima določa predpisani realni čas.

Nadalje mora sistem zadovoljiti še sledeče zahteve:

-Točnost rezultatov mora biti enaka ali večja kot pri sedanjih tabelaričnih postopkih.

-Programska oprema sistema mora biti zaščitena proti uporabi, katera ni v skladu s predpisi o tovorjenju ladij.

Ce sistem ne bi izpolnjeval slednjih dveh zahtev, izračune sistema pomorski uradi ne bi priznali.

-Sistem mora biti prijavzen do uporabnika.

-Sistem mora dajati zvočna in pisana opozorila. Z njimi opozarja operaterja na nepravilnosti pri tovorjenju kot so pretovorenost ladje, slaba stabilnost in drugo.

-Izpis dokumentacije mora biti onemogočen v primeru, ko tovorjenje ni v skladu s predpisi.

-Terminologija pri interaktivnem delu mora biti v angleškem jeziku.

V nasprotnem bi bil nadzor nad tovorjenjem ladje in pripadajočo dokumentacijo otežan tujim strokovnjakom v tujih pristaniščih.

### 5.3. Osnovna načela tovorjenja ladje

Algoritmi za tovorjenje ladij so zasnovani na načelih mehanike, pri čemer privzamemo ladjo kot elastični nosilec.

Pri vzdoljni stabilnosti računamo vgreze ladje in vzdolni nagib ladje (trim). Te vrednosti dobimo iz vzdolnih momentov, katera povzročata sili vzgona in teže celotne ladje na njima pripadajočima ročicama, merjenima od sredine ladje. Ročica, na kateri deluje vzgon, je funkcija vgreza ladje in je izračunana iz ladijskih linij. Ročico na kateri deluje teža ladje izračunamo, če vzdolne momente, katere povzročajo vse teže na ladji, delimo s težo celotne ladje. Težo celotne ladje predstavlja vsota teže same ladje, mrtvih tež, tež v tankih goriv, maziv, balasta, pitne vode in tež tovora. Vzdolne momente omenjenih tež pa dobimo, če vsako težo pomnožimo s pripadajočo razdaljo od njenega težišča do sredine ladje.

Pri prečni stabilnosti ponovno računamo moment, katerega povzročata dvojici sil vzgona in teže celotne ladje. Ta moment računamo zato, ker on vrača nagibajočo se ladjo v stabilni položaj. Iste račune momentov, katere smo prej vršili v vzdolni ravni ladje, vršimo sedaj v njeni prečni ravni. Pri tem teže ostajajo iste, ročice pa merimo od kobilice ladje. Te ročice bomo v dalnjem tekstu imenovali višine težišč ladijskih prostorov iznad kobilice. Če vso vseh nastopajočih momentov po višini delimo s težo celotne ladje, dobimo višino težišča

ladje. Vektor vagona ladje seká prečno simetralo ladje v točki, katero imenujemo metacenter. Višina metacentra nad kobilico ladje je vašna funkcija vgreza, katero se izračuna iz ladijskih linij. Razdaljo med težiščem ladje in metacentrom imenujemo metacentrična višina. Metacentrično višino končno popravimo za vpliv svobodnih površin. Tako izračunana in popravljena metacentrična višina predstavlja mero za stabilnost ladje. Njena vrednost mora ustrezati predpisom za tovorjenje ladij.

### 5.4. Algoritmi za tovorjenje ladij

Zelo zgoščen opis osnovnih načel za tovorjenje ladij v prejšnjem poglavju je imel le ta namen, da ugotovimo, da se algoritmi za tovorjenje ladij načeloma sestojajo iz treh delov.

Kot prvo moramo poznati oddaljenost prijemališča vagona od sredine ladje, nato višino metacentra in še druge vrednosti. Vsa te vrednosti so funkcije, katere so izračunane iz ladijskih oblik, podane pa so za argument vgreza.

Kot drugo moramo poznati volumne ladijskih tankov za goriva, maziv, balast in pitno vodo. Volumni in specifične teže določajo teže tekočin v tankih. Za računanje momentov moramo poznati položaj težišč tankov. To pomeni, da moramo poznati razdaljo težišč od sredine ladje in višino težišč iznad kobilice. Sredinski tanki v dvojem dnu ladje imajo največkrat obliko kvadra. Bočni tanki v dvojem dnu imajo sicer ravne stene, razen dveh, kateri sledita oblike dna in boka ladje. Tanki v bližini strojnega prostora so zaradi prostorske izkoristitvenosti često dograjevani. Višinski tanki leže večinoma ob boku ladje, zato njihove oblike sledijo ukrivljenosti boka in odlivnega dela krova. Geometrijsko najbolj nepravilne oblike imajo tanki na pramu in krmi ladje. Ti tanki so često že dograjeni. Na koncu velja pripomniti, da tanki niso vedno polni. Tako moramo izračunati volumna in položaja sistemnega težišča v funkciji višine tekočine (sonde) za nepravilna geometrijska telesa.

Nekoliko lajše je računati volumne in položaje sistemnih težišč za ladijska skladišča. Ta so pravilnejših oblik, vendar so v njih pregrade, ventilatorji in rebra ladje. Tako je v istem ladijskem skladišču volumen in položaj sistemnega težišča različen za razsute tovore, generalni tovor ali kontejnerje.

Ko ladijska posadka računa stabilnost ladje, gornje izračune ni sposobna izvesti. Ti izračuni so izvršeni v ladjedelnicah. Obliko ladijskih reber je v primerjavi z vodnimi linijami matematično lajše izraziti. Zato v ladjedelnicah vršijo račune volumnov in sistemnih težišč ladijskih prostorov z numerično integracijo v glavnem v vzdolni smeri ladje.

Tako so izračunane funkcije oddaljenosti prijemališča vagona od sredine ladje, višina metacentra ter druge za argument vgreza ladje, volumni in položaji sistemnih težišč tankov za argumenta sonde in trima, volumni in položaji sistemnih težišč za tovorna skladišča pa glede na posamezne vrste tovrov. V tovornih skladiščih je te vrednosti potrebno popraviti, če so skladišča s tovrom le delno zapolnjena.

Vse te funkcije za navedene argumente izdelajo v ladjedelnicah v obliku grafov. Grafi niso natančni, delo z njimi pa je zamudno. Zato so omenjene funkcije v novejšem času ustreznejše prikazane s tabelami. Množica tabeliranih

funkcij za določeno ladjo je zbrana v 'Knjigi stabilnosti'. Knjiga stabilnosti je danes s strani pomorskih uradov edini priznani dokument za pravilno tovorjenje ladje.

Ko smo dobili iz Knjige stabilnosti vse potrebne podatke, nam končno ostane še zadnji, tretji del izračuna vzdoljne in prečne stabilnosti. Ostalo nam je bilo množenj za izračun tež in momentov, seštevanj tež za izračun celotne teže ladje, ter končno nekaj daljjenj in odštevanj. Ti zadnji algoritmi za tovorjenje ladij zahtevajo torej le štiri osnovne računske operacije.

Poglejmo sedaj, kako je s tovorjenjem ladje s pomočjo računalnika. Če naj računalniški sistem za tovorjenje ladij opraviči svoj namen, mora izračune izvrševati hitro in točno. To pa izključuje zamudno uporabo grafov ali tabel. Računalniški sistem mora biti torej avtonomen, vse izračune mora izvrševati sam. Operater dela samo z računalnikom in pri delu z njim ne uporablja Knjige stabilnosti.

Zahteva po avtonomnosti računalniškega sistema za tovorjenje ladij postavlja iavedbi sistema naloge ponavljanja ladjedelniških izračunov. Zato moramo poznati matematične izražave oblik ladja v prečni ali vodoravnih ravnini v funkciji argumenta v vzdoljni ali navpični osi. Le tako lahko izvršimo numerične integracije z ustreznim korakom argumenta. Tako dobilni rezultati bi zadočali zahteve točnosti sistema. Izkaže pa se, da taka računalniška numerična integracija v zankah še zdaleč ne zadoča zahteve dela v realnem času tudi pri delu z hitrimi in večjimi računalniki.

Na sedanji stopnji razvoja računalniških sistemov za tovorjenje ladij pravzaprav mnogo hitreje izvršujemo račune, katere danes vršimo na osnovi podatkov iz tabel Knjige stabilnosti. Na tej stopnji se nam ponuja možnost pridobitve veliko hitrejših računalniških algoritmov.

Če bi si ogledali grafe funkcij pripadajočih argumentov v Knjige stabilnosti, bi najprej opazili, da so vse te funkcije zvezne. Končno bi opazili, da so te funkcije večinoma monotono naraščajoče funkcije, le izjemoma so to monotono naraščajoče in padajoče funkcije ali obratno.

Prva možnost, ki jo sedaj imamo, je ta, da funkcije iz Knjige stabilnosti vnesemo s programom v pomnilnik računalnika. Pri tem funkcionske vrednosti tvorijo člene seznama. Korak argumenta moramo izbrati tako, da zadostimo prostorski učinkovitosti in točnosti algoritma. Pri vnosu funkcijskih vrednosti za konstanten korak argumenta dobivamo funkcijskih vrednosti za tabelirane in netabelirane vrednosti argumentov z linearno interpolacijo. Ta algoritem je torej računalniška inačica sedanjih tabelaričnih postopkov računa stabilnosti. Tudi pri njih iščemo funkcijsko vrednost za netabeliran argument z linearno interpolacijo.

Drugo možnost izražave takih zveznih monotonih funkcij nudijo statistične metode. Učinkovita se izkaže metoda najmanjših kvadratov. Tako lahko večino funkcij iz Knjige stabilnosti izrazimo z regresijskimi polinomi, la malo pa z regresijskimi eksponentnimi funkcijami. Koefficiente regresijskega polinoma izračunamo iz vrednosti koordinat točk funkcije. Zahtevi točnosti algoritma zadostimo, če izračunamo koefficiente regresijskega polinoma iz zadostnega števila koordinat in z izbiro ustrezne stopnje polinoma.

Izkaže se, da so algoritmi na osnovi regresij-

skih polinomov časovno učinkovitejši od algoritmov na osnovi seznamov. Oboji pa zadočajo zahtevi o delu v realnem času.

Potrebno je pripomniti, da so funkcionske vrednosti v Knjigi stabilnosti zaokrožene na zadnjem mestu. To površča zaokrožitveno napako pri izračunih vrednosti, računanih z obimi algoritmi. Tako izrašča napaka na zadnjem mestu pri seznamih do +1, pri regresijskih polinomih pa med -1 in +1. Omenjene napake bi bilo možno odpraviti, če bi bile funkcionske vrednosti v Knjigi stabilnosti podane na dve decimalni mestni več.

Za današnjo stopnjo razvoja računalniških sistemov za tovorjenje ladje smo na ta način dosegli dvoje:

- Prvič smo dobili časovno in prostorsko učinkovite algoritme.
- Kot drugo pa so ti algoritmi zasnovani na vrednostih iz Knjige stabilnosti. Tako ni vzroka, da bi tako narejen sistem pomorski uradi ne priznali.

Pri tako izvedenem računalniškem sistemu za tovorjenje ladij bo v bližnji budučnosti dobila Knjiga stabilnosti isti pomen, katerega imata danes magnetni kompas in astronomiske metode. Knjigo stabilnosti bomo za tovorjenje ladij uporabljali samo v slučaju okvare računalnika.

Na višji stopnji razvoja računalniških sistemov za tovorjenje ladij ne potrebujemo le funkcij iz knjige stabilnosti za argument tripla, temveč tudi za argument prečnega nagiba (list-a). Pred algoritma na osnovi seznama ali regresije se tu ne postavlja vprašanje časovna, temveč prostorske učinkovitosti. Postavlja se vprašanje, če ne bi bile na tej stopnji prostorsko učinkovitejše metode numerična integracija. Trdimo lahko le, da bi bile časovno neučinkovite. Časovno učinkovitost pa bi dosegli z integracijami na kratkih intervalih pri poznanih funkcijskih vrednostih na spodnjem delu intervala. To pa je zopet v želodi prostorske učinkovitosti. Rešitve tega problema ta članek ne obravnava.

### 5.5. Učinkovitost algoritmov

V tem poglavju bomo funkcije iz Knjige stabilnosti na kratko imenovali funkcije.

V prejšnjem poglavju smo omenili, da so regresijski polinomi časovno nujučinkovitejši algoritmi.

Posamezno funkcijo je pri zahtevani točnosti večkrat možno izraziti z enim regresijskim polinomom do 18 stopnje. Če v računalniškem programu zapisemo polinom v obliki

$$f(x) = a_n x^n + a_{n-1} x^{n-1} + \dots + a_1 x + a_0$$

se bo pri visokih stopnjah polinoma računalniški čas bližal zgornji meji realnega časa. To pa zato, ker za en argument izračunavamo več funkcijskih vrednosti, katere so izražene s takim zapisom polinomov. Če pa v programu zapisemo polinome v obliki

$$f(x) = ((\dots(a_n x^n + a_{n-1} x^{n-1} + \dots + a_1 x + a_0) * x + a_{n-2}) * \dots + a_0)$$

nam računalniški čas ne bo delal težav. Prvi zapis polinoma ima namreč kvadratno časovno učinkovitost v primerjavi z drugim zapisom, ki ima linearno časovno učinkovitost. Zaradi

časovne učinkovitosti zato v programih načelno zapisujemo polinome v drugi oblikki. Prostorsko učinkovitost programskega zapisa polinoma izboljšamo tako, da decimalke njegovih koeficientov okrajšamo do meje, katera zadošča zahtevani točnosti izračunanih funkcijskih vrednosti.

Ce ima funkcija singularne točke ali točke obračajev, je ni možno izraziti z zahtevano točnostjo z enim regresijskim polinomom, četudi bi bila njegova stopnja višja od desete. V takih primerih s pogojnimi stavki v programu funkcijo med omenjenimi točkami izrazimo odsekoma, v večini primerov s polinomi nižjih stopenj. Pogojni stavki in polinomi nižjih stopenj povečajo časovno učinkovitost. Prostorska učinkovitost se seveda zmanjša, vendar ne presegajo prostora v pomnilniku, katerega bi zavzela ista funkcija, če bi jo zapisali v obliki seznamama.

Kadar funkcijo ne moremo izraziti z regresijskim polinomom, ali je ne moremo izraziti z zahtevano točnostjo, jo izrazimo s seznamom. S seznamami pa izraščamo tudi tiste funkcije, pri katerih je potrebna pri računu stabilnost visoka točnost. V prejšnjem poglavju smo namreč videli, da napaka zaokrožitve vpliva na izračun funkcijskih vrednosti manj, če je funkcija izražena s seznamom.

Pri čitanju kratkih seznamov je računalniški čas zadovoljiv. Pri čitanju dolgih seznamov pa precej preseže realni čas. V takem primeru moramo seznam razdeliti na podseznamo. S pogojnimi stavki v programu pri določeni vrednosti argumenta računalnik čita samo en podseznam. Na ta način časovno učinkovitost nastavimo na poljuben čas.

Omenjeni postopek pa seveda zmanjšuje prostorsko učinkovitost. Ker so funkcijskie vrednosti večinoma racionalna števila z enakim številom decimalnih mest, jih vpišemo v sezname kot cela števila tako, da jih predhodno pomnožimo z ustrezeno potenco števila 10. Tako so v seznamu prikazana z označeno točnostjo INTEGER in ne SHORT, kar izboljša prostorsko učinkovitost. Časovna učinkovitost pri tem ni zmanjšana, saj samo rezultat delimo z ustrezeno potenco števila 10.

Kot bomo videli v naslednjem poglavju je uporabniški program računalniškega sistema za tovorjenje ladje sestavljen iz glavnega programa in podprogramov. Podprogrami pa so sestavljeni iz modulov. Velikost modula določa velikost strani zaslona ali zahtevana hitrost izvajanja izračunov. Izberimo sedaj stran zaslona, na katero vnašamo n argumentov. Ob vnosu vsakega argumenta delni podprogram izračuna temu argumentu pripadajoče funkcijskie vrednosti. Privzemimo, da so v delnih podprogramih funkcije izražene s seznamami, katerih časovna učinkovitost je na meji realnega časa. Sedaj želimo spremeniti le m-ti argument in s tem njenu pripadajoče funkcijskie vrednosti. Predno ta argument dosežemo s kurzorjem, smo zapravili m-1 sekund. Uvedimo sedaj v delne podprograme majhne spremembe. Pred začetkom vsakega delnega podprograma dodajmo novo spremenljivko, katera naj dobi vrednost starega argumenta. Nato vnesimo novi argument. Delnim podprogramom dodajmo sedaj pogojni stavek. Ta naj predpiše brezpogojni preskok preko delnega podprograma v primeru, da sta stara in nova vrednost argumenta enaki. Na ta način smo prihranili m-1 dragocenih sekund računalniškega časa, prostorsko učinkovitost programa pa smo le neznatno zmanjšali.

Opisali smo nekaj načinov izboljšav časovne in prostorske učinkovitosti algoritmov. Pripor-

nimo, da moro nad obema učinkovitostima določa predpisani realni čas ter tip aparатурne opreme in njenega operacijskega sistema. Ponovimo še, da so algoritmi na osnovi regresijskih polinomov hitrejši, algoritmi na osnovi seznamov pa počasnejši, toda točnejši. Iskaže pa se, da je pri najbolj zahtevnih funkcijah za oba tipa algoritmov prostorska učinkovitost enaka.

### 5.6. Opis sheme programa

Uporabniški program računalniškega sistema za tovorjenje ladij mora izpolniti vse zahteve, katere so navedene v poglavju 5.2. Pri izdelavi programa dajemo do meje dela v realnem času popolno prednost časovni učinkovitosti programa. Sele nato posvetimo vso pozornost njegovi prostorski učinkovitosti. Iskaže se, kot bomo videli v naslednjem poglavju, da so taki programi sele občirni.

Da bi bil program časovno učinkovit, ne zadostuje, da vsebuje samo časovno učinkovite algoritme. Program mora biti tudi ustrezno strukturiran. Zato je sestavljen iz glavnega programa, podprogramov z moduli in datotek.

#### 5.6.1. Glavni program

Sestavlja ga glava in telo programa.

Glavo programa sestavljajo globalni ukazi, naslov programa, označitev točnosti spremenljivk s čimer povečamo prostorsko učinkovitost in glavni menu. Menü mora biti prijazen do uporabnika. Ob vnosu nepravilnega argumenta dobimo avtočno in pisano opozorilo, kurzor pa se vrne na mesto nepravilno vnešenega argumenta. S tem je onemogočen premik teksta menu-ja po zaslonu. Pri tovorjenju ladje velikokrat vnašamo ali spremenjamamo le neko značilno skupino podatkov in takoj preidemo k zaključnemu računu stabilnosti. Tako značilno skupino podatkov vsebuje podprogram. Namen glavnega menu-ja je, da omogoča hiter dostop do takih podprogramov. Poleg tega nam glavni menu prikaže osnovne ladijske podatke, odpira in briše datoteke, ter vnaša v datoteke začetne vrednosti spremenljivk.

V telesu programa se nahajajo rutine za izvajanje operacij katere se večkrat ponavljajo in modul z delnimi podprogrami, kateri omogočajo izvajanje menu-ja.

#### 5.6.2. Podprogrami

Ločimo dve vrsti podprogramov. Prvo skupino podprogramov tvorijo tisti podprogrami, v katerih posamezen podprogram združuje značilno skupino podatkov. To so podprogrami za tovor, goriva, maziva, balast in pitno vodo. Drugo skupino podprogramov tvorijo podprogram za zaključni račun stabilnosti, podprogram za izpis podatkov in podprogram za risanje plana tovora. Vsaka skupina podprogramov ima svojo značilno strukturo programa.

Kot primer strukturiranosti prve skupine podprogramov si ogledimo podprogram za tovor.

Glavo podprograma tvorijo lokalni ukazi, označitev točnosti spremenljivk in menu podprograma. Menu podprograma omogoča izbiro strani zaslona. Število strani in vsebino vpisov na njih določata število vrstic na zaslolu in željena hitrost izvajanja računskih operacij. Tako ima podprogram za tovor tri strani. To so strani za tovor na krovu, tovor v medkrovju in tovor v spodnjih skladilskih ladje. Nadalje menu omogoča izvrševanje posebnih operacij. Te predstavljajo razstovorjanje vsake od teh treh skupin tovorov z enim ukazom. To povečuje časovno učinkovitost dela s programom.

Sledi ukaz za povratek v glavni menu.

Telo podprograma sestavljajo rutine za ponavljajoče se operacije in moduli. Vsaki strani zaslona in vsaki posebni operaciji pripada lasten modul. Moduli so končno sestavljeni iz delnih podprogramov. Vsakemu argumentu pripada lasten delni podprogram. Moduli, ki pripadajo raznim stranem podprograma, imajo enako strukturo. Najprej se iz datotek izvrši čitanje začetnih ali že vnašenih argumentov. Sledi vnos novih argumentov ali sprememb posameznega ter procesiranje pripadočih funkcijskih vrednosti. Sledita izpis argumentov in rezultatov v datoteke, ter povratek v menu podprograma. Pri modulih za posebne operacije čitanje odpade, procesiranje in izpis v datoteko pa se vrši ob zadanim pogoju z enim ukazom. Tako zasnovani moduli so avtonomni.

Avtonomnost modulov in strukturiranost programa omogočata, da lahko spremenimo samo en argument na poljubni strani. Po zaključitvi te strani so vsi podatki takoj dostopni za zaključni račun stabilnosti.

Kot primer strukturiranosti druge grupe podprogramov si oglejmo podprogram za zaključni račun stabilnosti.

Glavo programa tvorijo izpis naslova programa, lokalni ukazi in označitev točnosti spremenljivk.

Telo programa tvorijo trije moduli. Program prvega modula prečita iz datotek podatke, kateri so potrebni za račun stabilnosti. Sledi modul s programom postopkovno usmerjenega tipa, s katerim računamo stabilnost. V tretjem modulu se nahajajo delni podprogrami za opozorila v primerih nepravilnega tovorjenja ladje. Takemu opozorilu sledi abort podprograma in povratek v glavni program, izpis dokumentacije pa je onemogočen.

#### 5.6.3. Robni pogoji

Sele na tem mestu lahko dokončno odgovorimo na vprašanje o problemu robnih pogojev. Za funkcije iz Knjige stabilnosti, katere so podane za argument sonde, bi na to vprašanje lahko odgovorili že prej. Funkcijске vrednosti teh funkcij so na krajiščih intervalov točno definirane. Drugače pa je pri funkcijah, katere so podane za argument vgreza. Te se namreč nahajajo v podprogramu za zaključni račun stabilnosti. Funkcijске vrednosti le teh so na spodnjem krajišču intervala točno določene z vgrazom, ki pripada lahki ladji. Problemi pa bi lahko nastopili v zgornjem delu intervala. Te robne probleme pa rešuje agoraj opisani modul za opozorila pri nepravilnem tovorjenju ladje, katerim sledi abort podprograma. V tako zasnovanem programu ni več opaziti problemov robnih pogojev.

#### 5.6.4. Datoteke

Glavni program odpira datoteke za značilne grupe podatkov. To so datoteke za shranjevanje argumentov, izračunanih tež in ročic, vrednosti svobodnih površin in rezultatov zaključnega računa. Začetne vrednosti vpišuje v datoteko glavni program. Spremenjene vrednosti vpišujemo v datoteke z moduli. Podatki iz datotek so vedno dostopni za zaključni račun, izpis dokumentacije ali risanje plana tovora.

Tako strukturiran program za računalniško tovorjenje ladje omogoča hitro, operativno in varno tovorjenje ladje.

#### 5.7. Velikost sistema

Poskusni uporabniški program za računalniško tovorjenje ladje je bil izdelan za ladjo tipa Concord C. Te ladje imajo nosilnost 18.000 ton, osem skladiščnih prostorov in 28 tankov za goriva, maziva, balast in pitno vodo. Ta števila uvrščajo ta tip ladij v spodnji srednji velikostni razred ladij. Ladij tega tipa ima podjetje Slovenska plovba Piran pet.

Poskusni program izpoljuje vse zahteve, katere so za računalniško tovorjenje ladij opisane v poglavju 5.2. Program je strukturiran in vsebuje avtonome module.

Na osnovi tega poskusnega programa in ekstrapolacije lahko ocenimo velikost in hitrost delovanja računalniškega sistema za tovorjenje ladij.

S stališča prostorske učinkovitosti programske opreme zavzema program za ladjo na ravnici kobilici, tovorjenje generalnega tovora in izračune vadolne in začetne prečne stabilnosti 34 kB pomnilniškega prostora. Če programiramo funkcijске vrednosti že za argument trima, se program poveča na 188 kB.

Casovna učinkovitost takega programa je dvakratnik večja od sedanjih tabelaričnih postopkov. Ker so funkcije podane za argument sonde in trima, je na računalniški sistem močno priklopiti senzorje. Z njimi bi bila casovna učinkovitost sistema glede na tabelarične postopke povečana do pedesetkrat. Pravilna nastavitev senzorjev pa bi povečala prostorsko učinkovitost.

Ce programu dodamo program za tovorjenje razsutih tovorov, se le ta poveča za dodatnih 16 kB. Če dodamo že program za kriwilje stabilnosti in izpis podatkov, potrebujemo dodatnih 17 kB programa. S temi dodatnimi programi ostane casovna učinkovitost celotnega programa ista.

Program za tovorjenje kontejnerjev bi zahteval dodatnih 17 kB. Pri tem pa bi casovna učinkovitost celotnega programa padla izpod agoraj omenjenih casovnih učinkovitosti. Bistveno pa je, da je računalniški čas tovorjenja kontejnerjev manjši od realnega časa za dejansko tovorjenje kontejnerjev na ladjo, česar tabelarični postopki ne omogočajo.

Vsi zgoraj navedeni programi bi tvorili program velikosti 158 kB. Program te velikosti bi avtonomno izvajal vse izračune, katere lahko za ladjo tipa Concord C danes vršimo na osnovi Knjige stabilnosti in tabel sondar, razen računov upogibnih momentov in strižnih sil.

Zgoraj omenjeni programski opremi bi morala pripadati ustrezna aparatorična oprema. Aparatorična oprema bi morala zadoščati tudi zahtevam za delovanje na ladji, katere smo opisali v poglavju 4. Pripadajoči tiskalnik bi moral izpisovati dokumente na formatu A4 s hitrostjo 80 znakov v sekundi.

Opisani računalniški sistem za tovorjenje ladje predstavlja sistem srednjega razreda za ladjo srednje velikosti. Velikost sistema pa se spremeni glede na drugačno velikost ladje ali želje naročnika.

Vačinoma se danes nahajajo na ladjah manjši sistemi. Vgrajeni pa so tudi veliko večji sistemi. Nahajajo se na velikih tankerjih, kjer je tovorjenje in istovorjanje tekodičnih tovorov v celoti računalniško kmiljeno.

Programska oprema velikih sistemov vsebuje že druge programe. Če dodamo programe funkcij za argument lista, le ti sami lahko dosegajo velikost do 600 kB. Dodati moramo programe za račun upogibnih momentov, stršnih sil, grafične prikaze v barvah, računalniško krmiljenje tovorjenja, programe za ukrepe v primeru prodora vode in programe za optimizacijo tovorjenja. Tako lahko programsko opremo velikih sistemov ocenimo na red velikosti MB. Pripadajoča aparatura opreme zahteva zaslone visoke grafične ločljivosti, risalnike za format A3, A/D pretvornike in dobro senzorsko tehnologijo.

#### 6. ZAKLJUČEK

Članek je opisal široko uporabo informacijskih in računalniških sistemov v sodobnem pomorskom prometu in ladjedelnству. Prikazano je sedanje stanje in naše možnosti za vključitev v razvoj in izdelavo tovrstne sodobne tehnologije.

Naše možnosti so na področju že obstoječe komunikacijske tehnologije in nadalnjem razvijanju meteoroološkega informacijskega sistema na Jadranu. Veliko zanimanja za nadaljevanje razvijanja komercialno-operativnega informacijskega sistema v podjetju za kontejnersko službo je

sedaj pri slovenskem ladjarju.

Imamo možnost razvoja ekspertnega sistema za nego bolnika na ladji.

Velike možnosti pa imamo za izdelavo ladijskih informacijskih podsistemov, kateri zahtevajo le računalniško tehnologijo. To so podsistemi za administracijo, zaloge, upravno in pravni, ter podsistem za tovor.

Kot primer ponovimo primerjalne prednosti, katera imamo pred tujimi proizvajalci pri izdelavi opisanega računalniškega sistema za tovorjenje ladij. Domači ladjar ali ladjedelničar določita, na katero ladjo bo sistem postavljen in kakšna bo njegova velikost. Za kontejnersko ladjo bi račun verjetno pokazal, da se investicija za uvožen sistem izplača v enem letu. Nadaljnji račun bi pokazal, da je programska oprema takega tipa sistema doma petkrat cenejša kot v tujini. Poleg tega je cena dinarska. Tu imamo torej dve prednosti. Prva je prihranek pri nabavi opreme za ladjarje in ladjedelnice. Druga pa je prodor in prodaja našega znanja na domače in tujje tržišče.

Po uveljavitvi naših proizvodov na domačem in tujem tržišču, bi s razumno politiko can ustvarili akumulacijo za nadaljni razvoj in razširjeno reprodukcijo.

**UDK: 681.3.05**

**Izv. prof. dr. Nikola Pavešić, dipl. ing.  
Fakulteta za elektrotehniko u Ljubljani  
Izv. prof. dr. Slobodan Ribarić, dipl. ing.  
VVTŠ KoV JNA, Zagreb**

U članku je opisana izvedba paralelnog sustava za raspoznavanje rukom pisanih numeričkih znakova. Sustav se temelji na teoriji dvodimenzionalnih prilagodjenih filtera i primjeni procesora viših hijerarhijskih razina. U prvom dijelu članka dane su teorijske osnove dvodimenzionalnih prilagodjenih filtera i izvorne definicije procesora različitih hijerarhijskih razina. U drugom dijelu članka opisana je izvedba visokoparalelnog sustava za raspoznavanje koji za osnovu ima procesore hijerarhijske razine  $H_2$  i  $H_1$ .

**THE PARALLEL CHARACTER RECOGNITION SYSTEM:** In this paper we describe realization of the parallel system for the recognition of handwritten numerical characters. The system is based on the theory of two-dimensional matched filters and application of processors from higher hierarchical levels. In the first part of the paper we describe theoretical aspects of two-dimensional matched filters and we give original definitions of processors from different hierarchical levels. In the second part of the paper the realization of highly parallel pattern recognition system is presented. The system has processors from hierarchical levels  $H_1$  and  $H_2$  as the basic elements. The experimental results are given.

## 1. UVOD

U posljednjih desetak godina interes za područje digitalne obrade i raspoznavanje slika u stalnom je porastu. Taj interes je usmjeren u dva glavna pravca [1]:  
a) poboljšanje vizualnog izgleda slike, odnosno pretvaranje slike u pogodniji oblik za interpretaciju od strane čovjeka,  
b) obrada i pretvaranje slike u oblik pogodan za automatsku percepciju i strojnu interpretaciju.

Pravac istraživanja opisan pod b) bio je uvjetovan prodom računala u poslovne i industrijske sredine i prouzrokovao je razvoj uređaja koji se obično nazivaju zajedničkim imenom - uređaji za izravni unos podataka s dokumenata ili optički čitači znakova (OCR - Optical Characters Reader). Prema složenosti uređaji OCR mogu se razvrstati u tri razreda [2]:  
a) jednostavni uređaji za čitanje kodova (npr. bar code) ili zapisa s magnetnom tintom,  
b) uređaji srednje razine složenosti koji se upotrebljavaju za izravan unos podataka s dokumenata, čekova, lječničkih recepata i sl. Skup ulaznih znakova je tipiziran [3].  
c) Složeni uređaji za raspoznavanje rukom pisanih znakova (npr. brojeva, brojčano-slovcanih znakova, Kataloških znakova i sl. [3]).



Slika 1. Blok-sхема tipičnog sustava za raspoznavanje znakova

Slika 1 prikazuje blok-sхемu tipičnog sustava za raspoznavanje znakova. On se sastoji od:

- . jedinice za unos i digitalizaciju slike,
- . podsustava za lociranje i segmentaciju znakova,
- . preprocesora,
- . podsustava za izlučivanje osnovnih značajki,
- . podsustava za klasifikaciju.

Složenost pojedinih komponenti sustava zavisi od njegove namjene: u jednostavnim uređajima OCR sa malim skupom tipiziranih ulaznih znakova neke komponente (npr. preprocesor) mogu biti izostavljene, dok u složenim sustavima za raspoznavanje pojedine komponente su izvedene tako da imaju bazu znanja i mehanizam za zaključivanje, odnosno predstavljaju ekspertne sustave [4],[5].

Upotreba sklopova izvedenih u tehnologiji visokog stupnja integracije (LSI) u konstrukciji uređaja OCR poboljšala je omjer performansa/cijena i omogućila primjenu egzaktnijih metoda u postupku raspoznavanja. U članku je opisana izvedba paralelnog sustava za raspoznavanje rukom pisanih znakova. Postupak raspoznavanja temelji se na primjeni dvodimenzionalnih prilagodjenih filtera.

## 2. DVODIMENZIONALNI PRILAGOĐENI FILTERI

H.C. Andrews [6] je teoriju L.G. Turina [7] o jednodimenzionalnim prilagodjenim filterima proširio na dvodimenzionalne prilagodjene filtere. Osnovna karakteristika tih filtera je prijenosna funkcija koja u određenoj točki izlazne funkcije linearog sustava maksimizira omjer signal-šum ( $S/N$ ).

U ovom odjeljku izvest ćemo prijenosnu funkciju za dvodimenzionalni prilagodjeni filter u slučaju kada se

ulazna funkcija sastoji od signala  $f_1(x,y)$  kojem je aditivno primješan šum  $n_1(x,y)$ :

$$g_1(x,y) = f_1(x,y) + n_1(x,y). \quad (1)$$

Izlazna funkcija  $g_0(x,y)$  sastoji se od signala  $f_0(x,y)$ , koji je prouzrokovani signalom  $f_1(x,y)$  prisutnim na ulazu u sustav, i od šuma  $n_0(x,y)$ , koji je posljedica šuma  $n_1(x,y)$  prisutnog na ulazu u sustav.

Pretpostavimo da je šum proces koji je stacionaran i ergodički u autokorelacijskoj  $R_{n_1}(\tau, T)$  sa spektralnom gustoćom:

$$S_{n_1}(u,v) = \mathcal{F}[R_{n_1}(\tau, T)], \quad (2)$$

gdje je  $\mathcal{F}$  Fourierov operator.

Izlazna spektralna gustoća slučajnog šuma  $n_0(x,y)$  dana je izrazom:

$$N = \iint_{-\infty}^{+\infty} S_{n_1}(u,v) \cdot |H(u,v)|^2 du dv, \quad (3)$$

gdje je  $H(u,v)$  prijenosna funkcija linearnega sustava.

Ako je  $F_1(u,v) = \mathcal{F}[f_1(x,y)]$  tada je Fourierova transformacija izlazne funkcije  $f_0(x,y)$ :

$$\mathcal{F}[f_0(x,y)] = \mathcal{F}[f_1(x,y)] \cdot H(u,v), \quad (4)$$

Što u vremenskom prostoru odgovara konvoluciji:

$$f_0(x,y) = f_1(x,y) \otimes h(x,y).$$

Energija signala  $S$  u točki  $(\xi, \eta)$  dana je sa:

$$\begin{aligned} S &= |f_0(\xi, \eta)|^2 \\ &= \left| \iint_{-\infty}^{+\infty} F_1(u,v) \exp\{j(u\xi+v\eta)\} du dv \right|^2 \quad (5) \\ &= \left| \iint_{-\infty}^{+\infty} F_1(u,v) H(u,v) \exp\{j(u\xi+v\eta)\} du dv \right|^2 \end{aligned}$$

Upotreboom jednadžbe (5) i (3) dobivamo omjer signala - šuma koji se treba maksimizirati:

$$S/N = \frac{\left| \iint_{-\infty}^{+\infty} F_1(u,v) H(u,v) \exp\{j(u\xi+v\eta)\} du dv \right|^2}{\iint_{-\infty}^{+\infty} S_{n_1}(u,v) |H(u,v)|^2 du dv} \quad (6)$$

Pomoću Schwarzove nejednadžbe slijedi da je omjer (6) maksimalan [6] ako je

$$H(u,v) = K \frac{\bar{F}_1(u,v) \exp\{-j(u\xi+v\eta)\}}{S_{n_1}(u,v)}, \quad (7)$$

gdje je  $K$  proizvoljna kompleksna konstanta i  $\bar{F}_1(u,v)$  konjugirano kompleksna vrijednost spektra signala ulazne funkcije. Jednadžba (7) predstavlja optimalnu prijenosnu funkciju koja maksimizira omjer  $S/N$  u točki  $(\xi, \eta)$ .

### 3. HIJERAHIJA PROCESORA

Procesori su važna komponenta digitalnog sustava za raspoznavanje. Oni gotovo izravno utječu na performansu sustava. U ovom dijelu članka predlažemo izvornu klasifi-

kaciju procesora s obzirom na broj koraka koji su potrebni za računanje aritmetičkih i logičkih izraza.

Aritmetički izraz  $E$  možemo definirati kao pravilno tvoren niz sastavljen najmanje iz jedne od četiri aritmetičke operacije  $\{+, -, *, /\}$ , lijevih i desnih zagrada (ukoliko su potrebne) i atoma koji su konstante ili varijable [8]. Aritmetički izraz sastavljen od  $n$  atoma označavat ćeemo sa  $E<n>$ .

Logički izraz  $L$  je pravilno tvoren niz sastavljen najmanje iz jedne logičke operacije, lijevih i desnih zagrada (ukoliko su potrebne) i atoma koji su logičke varijable ili konstante. Logički izraz  $L$  sastavljen od  $n$  atoma označavat ćeemo sa  $L<n>$ .

Od izvedbe procesora zavisi broj koraka  $T$  koji je potreban za računanje aritmetičkih  $E<n>$  i logičkih  $L<n>$  izraza.

#### 3.1 Procesor hijerarhijske razine $H_0$

##### Tvrđnja 1

Primjenom potrebnog broja procesora sa ulazima samo za dva atoma (procesor izvodi binarne i unarne operacije) aritmetički izraz  $E<n>$  može se izračunati u

$$T[E<n>] \geq \lceil \log_2 n \rceil \quad (8)$$

gdje  $\lceil x \rceil$  označava gornju cijelobrojnu vrijednost broja  $x$ . Dokaz tvrdnje 1 je trivijalan [8].

##### Tvrđnja 2

Broj potrebnih koraka za računanje logičkog izraza  $L<n>$  pomoću procesora s ulazima za samo dva atoma je

$$T[L<n>] \geq \lceil \log_2 n \rceil. \quad (9)$$

##### Definicija 1

Procesor koji izvršava osnovne aritmetičke i logičke operacije, te ima ulaze za dva operanda i zadovoljava tvrdnje 1 i 2 naziva se procesor  $p_0$  ili procesor hijerarhijske razine  $H_0$ .

Procesor  $p_0$  je komponenta većine današnjih računalских sustava i predstavlja jednu od osnovnih značajki arhitekture računala koja se zasniva na von Neumannovom modelu računala.

Paralelno računanje nekog aritmetičkog izraza primjenom potrebnog broja procesora razine  $p_0$  obično se prikazuje tzv. stablom redukcije po razinama. Na primjer, slika 2 prikazuje računanje izraza  $E<9> = a*b*c + d*c*f + g*h*i$ .



Slika 2. Stablo redukcije po razinama za  $E<9>$  uz pomoc procesora  $p_0$

### 3.2 Procesor hijerarhijske razine $H_1$

Jednovrsni aritmetički izraz  $E_u^{<n>}$  je pravilno tvoren niz sastavljen samo od jedne vrste aritmetičkih operacija (ili +, ili -, ili \*, ili /), lijevih i desnih zagrada (ukoliko su potrebne) i n atoma koji su konstante ili varijable.

Na sličan način možemo definirati jednovrsni logički izraz:  $L_u^{<n>}$  je pravilno tvoren niz sastavljen od jedne vrste logičkih operacija, lijevih i desnih zagrada (ukoliko su potrebne) i n atoma koji su logičke konstante ili varijable.

#### Tvrđnja 3

Procesor  $p_1$  neka je takav da ima m ulaza; ( $m > 2$ ) i izvodi m-arne operacije. Upotrebom potrebnog broja procesora  $p_1$  jednovrsni aritmetički izraz izračunava se u:  $TCE_u^{<n>} \geq \lceil \log_m n \rceil$  koraka. (10)

#### Tvrđnja 4

Broj koraka za računanje jednovrsnog logičkog izraza  $L_u^{<n>}$  pomoću potrebnog broja procesora  $p_1$  je:

$$TCL_u^{<n>} \geq \lceil \log_m n \rceil. \quad (11)$$

#### Definicija 2

Procesor koji izvodi jednovrsne aritmetičke i logičke operacije i ima  $m > 2$  ulaza za atome (izvodi m-arne operacije), te zadovoljava tvrdnje 3 i 4, naziva se procesor  $p_1$  ili procesor hijerarhijske razine  $H_1$ .

Primjeri izvedbe procesora hijerarhijske razine  $H_1$  prikazan je u radu N. Konvarasa, gdje je opisan procesor za istovremeno zbrajanje m n-bitnih podataka [9]. Slika 3 prikazuje primjer računanja aritmetičkog izraza  $E^{<9>} = a * b * c + d * e * f + g * h * i$ , gdje se  $a * b * c$ ,  $d * e * f$  i  $g * h * i$  mogu promatrati kao tri jednovrsna aritmetička izraza  $E_{u_1}$ ,  $E_{u_2}$  i  $E_{u_3}$ , a njihovi rezultati kao operandi za jednovrsni aritmetički izraz sastavljen od tri atoma.



Slika 3. Računanje  $E^{<9>}$  uz pomoć procesora  $p_1$

### 3.3 Procesor hijerarhijske razine $H_2$

Procesor hijerarhijske razine  $H_2$  predstavlja neku

vrstu „računskog demona“. Namjerno smo upotrijebili izraz koji je koristio O.G. Selfridge za opisivanje postupka učenja u sustavima za raspoznavanje uzorka [10], jer se procesor u hijerarhijskoj razini  $H_2$  korjenito razlikuje od onoga što pod izrazom „procesor“ podrazumijevamo u računalskim znanostima. Na primjer, slika 4 prikazuje inačicu procesora koji se djelotvorno upotrebljava u sustavu za obradu slike RADIUS (tvrtka Hyghes Research). Iako ovaj procesor nema sve značajke procesora hijerarhijske razine  $H_2$  može nam poslužiti kao dobra ilustracija u kojoj mjeri procesori mogu odstupati od onoga što pod tim izrazom podrazumijevamo. Procesor (sl. 4) upotrebljava simbolički način predstavljanja brojeva (tzv. residualni brojevni sustav). Ulazni podatak se jednoznačno predstavlja kao ostatak dijeljenja sa bazama  $B_1$ ,  $B_2$ ,  $B_3$  i  $B_4$  gdje su baze izabrane kao prim brojevi ( $B_1 = 31$ ,  $B_2 = 29$ ,  $B_3 = 23$  i  $B_4 = 19$ ). Točnost predstavljanja brojeva je  $B_1 \cdot B_2 \cdot B_3 \cdot B_4 = 2^{10 \cdot 6}$ . Središnji dio procesora je memorija RAM koja se upotrebljava kao "look up" tablica za „računanje“ funkcija  $f(a,b)$ , gdje su  $a$  i  $b$  ulazni podaci. Procesor je „programabilan“, odnosno računalo domaćin puni tablicu u zavisnosti od tipa funkcije  $f$ .



Slika 4. Procesor u sustavu RADIUS

Očigledno je da procesor u računalu RADIUS nema potpuno zbrajalo, sklop za posmak i druge sklopove koji su karakteristični za procesor u von Neumannovom računalu, međutim on djelotvorno izvodi složene aritmetičke operacije kao što je npr. konvolucija s jezgrom od  $5 \times 5$  elemenata [11].

#### Definicija 3

Procesor  $p_2$  ili procesor hijerarhijske razine  $H_2$  opisan je trojkom:

$$p_2 = (U, I, \mu), \quad (12)$$

gdje je  $U$  skup raspoloživih atoma aritmetičkog ili logičkog izraza,  $I$  skup rezultata aritmetičkih ili logičkih operacija koje se izvode nad raspoloživim atomima i  $\mu$  je funkcija:

$$\mu : U \rightarrow I.$$

Funkcija  $\mu$  predstavlja preslikavanje skupa raspolo-

živih atoma, u skladu s aritmetičkim ili logičkim izrazom, u skup rezultata.

Procesor  $p_2$  u jednom koraku računa aritmetički ili logički izraz bez obzira na tip operacije (jednovrsna ili raznovrsna) i broj operanada n.

Primjeri izvedbi procesora  $p_2$  su funkcionalna memorijska [12] i 2-D procesorski segment u sustavu Cytocomputer [13].

Slika 5 prikazuje primjer računanja aritmetičkog izraza  $E < 9> = a * b * c + d * e * f + g * h * i$  pomoću procesora  $p_2$ .



Slika 5. Računanje  $E < 9>$  uz pomoć procesora  $p_2$

Procesori u razinama  $H_0$ ,  $H_1$  i  $H_2$  imaju takve značajke da vrijedi slijedeće:

Ako neki procesor p ima svojstva hijerarhijske razine  $H_2$ , tada taj procesor ima i svojstva procesora razine  $H_1$  i  $H_0$ .

Neka je procesor p iz razine  $H_2$ . Ograničimo funkciju p samo na jednovrsne operacije i neka je  $m > 2$ . Tada procesor poprima značajke procesora razine  $H_1$ . Ako uvedemo i dodatno ograničenje  $m = 2$  dobivamo procesor hijerarhijske razine  $H_0$  (u skladu s definicijama 1-3).

#### 4. ORGANIZACIJA SUSTAVA ZA RASPOZNAVANJE

Sustav za raspoznavanje rukom pisanih numeričkih znakova oblikovan je pomoću deset dvodimenzionalnih prilagodjenih filtera. Svakom razredu uzorka  $w_i$ ;  $i = 0, 1, \dots, 9$  priredjena je prijenosna funkcija  $H_i(u, v)$ . Slika 6 prikazuje organizaciju sustava. Svi prilagodjeni filtri imaju zajednički ulaz koji je ujedno i ulaz u sustav za raspoznavanje. Izlazi iz dvodimenzionalnih prilagodjenih filtera su spojeni s jedinicom za detekciju maksimalne vrijednosti.



Slika 6. Organizacija sustava za raspoznavanje

Uzlazni podaci - rukom pisane brojke - ispisani su na posebnim obrascima (sl. 7). Znakovi su napisani u kvadratima označenim svjetloplavim okvirima dimenzija  $7 \times 10$  mm i u međusobnoj udaljenosti dva milimetra.

0 0 0 1 1 1 2 2 2 3 3 3 4 4

4 5 5 5 6 6 7 7 8 8 9 9

Slika 7. Uzlazni podaci napisani u obrascima

TV kamera s odgovarajućim upravljačkim sklopovima pretvara sliku u analogni signal, a digitalizator upravljan računalom pretvara sliku u matricu dimenzija  $16 \times 16$  slikevih elemenata. Analizom spektra i određivanjem graničnih frekvencija signala utvrđeno je da dimenzije matrice  $16 \times 16$  zadovoljavaju i da se u skladu sa Shannonovim teoremom uzlazni signal može rekonstruirati [16]. Mnoge baze podataka sustava za raspoznavanje imaju slične dimenzije uzlaznih uzoraka (npr. Highleymanova baza podataka ima matricu dimenzija  $12 \times 12$  [3], a neki komercijalni sustavi imaju i manje dimenzije (npr.  $9 \times 7$  [14])). Digitalizator kvantizira svaki slikovni element u 256 razina (8 bita). Analiza histograma pokazala je da su oni bimodalni, te su za opis uzorka rukom pisanih znakova dovoljne samo dvije razine. Binarnu sliku dobili smo postupkom uspoređivanja s pragom p, gdje je prag p zavisao od osvjetljenosti slike, vrste i boje pisaljke te vrste i boje podloge. Slike smo binarizirali u odnosu na prag p koji se nalazi na minimumu između dva vrha histograma [15]. Histogrami su dobiveni uz pomoć uzlaznih uzoraka iz skupa za učenje. Slika 8 prikazuje binarizirane matrice uzlaznih uzoraka.



Slika 8. Binarizirane matrice uzlaznih uzoraka

Da bismo provjerili djelotvornost sustava za raspoznavanje, sustav smo simulirali na računalu CYBER 72/24. Simulacijski programi su napisani u Fortranu i sastoje se od devet nezavisnih modula tako da nam omogućava djelotvorno mijenjanje i eksperimentiranje sa sustavom za raspoznavanje [16]. Kao ulaz u simulator upotrebljeni su binarizirani uzorci.

Simulacija je podijeljena u dvije faze. Prva faza, koja odgovara fazu učenja sustava za raspoznavanje, izvršava se pomoću sedam programskih modula. Ti moduli određuju signalnu komponentu spektra ulazne funkcije, spektralnu gustoću šuma i prijenosne funkcije filtera. Zbog jednostavnosti simulacije prijenosne funkcije se određuju u frekventnom prostoru primjenom brze Fourierove transformacije (FFT).

#### 4.1 Određivanje signalne komponente ulazne funkcije

Pomoću skupa uzoraka za učenje  $\{g_i(x,y)\}$  odredili smo skup statističkih funkcija:

$$St_i(x,y) = P_i(g_i(x,y) = 1 | \omega_i), \quad (13)$$

za  $x = 0,1,2,\dots, 15$  i  $y = 0,1,2,\dots, 15$ , gdje je  $\omega_i \in \{0,1,2,\dots, 9\}$  razred uzorka.

Primjer funkcije  $St_i(x,y)$  prikazan je na slici 9 i predstavlja vjerojatnost (u postocima) pojavljivanja jedinice u pojedinim elementima matrice uzorka 0.

Skup funkcija  $St_i(x,y)$  se preslikava u skup signala  $f_{Ii}(x,y)$  pomoću slijedeće relacije:

$$\begin{aligned} f_{Ii}(x,y) &= 1 \text{ ako je } St_i(x,y) > q_i, & i \\ f_{Ii}(x,y) &= 0 \text{ ako je } St_i(x,y) \leq q_i, \end{aligned} \quad (14)$$

gdje je  $q_i \in \{q_0, q_1, \dots, q_9\}$  određen eksperimentalno.

Budući da je transformacijsko jezgro separabilno i simetrično Fourierovu transformaciju, odnosno spektre signala  $F_{Ii}(u,v)$ ;  $i = 0,1,\dots, 9$  dobivamo sljednim računanjem  $F_{Ii}(u,x)$  i  $F_{Ii}(u,v)$  pomoću brze Fourierove transformacije.

#### 4.2 Određivanje spektralne gustoće šuma

Šum za pojedini ulazni uzorak određujemo kao razliku:

$$n_{Ik}^i(x,y) = g_{Ik}^i(x,y) - f_{Ik}^i(x,y), \quad (16)$$

$k = 1,2,\dots, M_i$ ,

$M_i$  je broj uzoraka za učenje u razredu  $\omega_i$ ;  $i = 0,1,2,\dots, 9$ .

Spektralnu gustoću računamo pomoću izraza:

$$S_{n_I}^i(u,v) = \frac{1}{M_i} \sum_{k=1}^{M_i} |F_{Ik}^i(x,y) \cdot w(x,y)|^2 \quad (17)$$

Pojedine funkcije  $n_{Ik}^i(x,y)$  smo umnožili s Hammingovom funkcijom [17] zato da bismo umanjili Gibbonov utjecaj [18].

Pomoću Huangovog teorema [19] možemo Hammingovu funkciju napisati u obliku:

$$\begin{aligned} w(x,y) &= 0,54 + 0,46 \cos \frac{2\pi}{16} \sqrt{x^2 + y^2} \\ \text{za } x \text{ i } y &\in \{0,1,2,\dots, 15\} \text{ i} \\ w(x,y) &= 0 \end{aligned} \quad (18)$$

za  $x \text{ i } y \notin \{0,1,2,\dots, 15\}$ .

STATISTIČNA SЛИKA UZORKA 0



Slika 9. Primjer funkcije  $St_i(x,y)$

Izraz [17] računamo primjenom brzih postupaka za određivanje autokorelacijske funkcije [20], [21].

Za svaki razred uzorka  $\omega_i$ ,  $i = 0,1,\dots, 9$  možemo sada odrediti prijenosnu funkciju dvodimenzionalnog prilagodjenog filtra: ( $\xi = n = 0$ ):

$$H_i(u,v) = \frac{\bar{F}_{Ii}(u,v)}{S_{n_I}^i(u,v)} \quad (19)$$

Time je postupak učenja sustava za raspoznavanje završen.

#### 4.3 Rezultati raspoznavanja

Druga faza simulacije odgovara procesu raspoznavanja. Na ulazu sustava dovodi se nepoznati uzorak. Preostala dva programska modula daju odziv filtera i razvrstavaju uzorak na temelju maksimalne vrijednosti odziva.

Opisani sustav za raspoznavanje smo testirali na četiri zbirke rukom pisanih numeričkih znakova.

##### Pokus I

Prva zbirka sastoji se iz 150 numeričkih znakova. Brojke su pisane tušem i tehničkim pismom (sl. 10). Sustav je bez greške pravilno razvrstao uzorke.

##### Pokus II

Druga zbirka sastoji se iz 50 numeričkih znakova koji su napisani kemijskom olovkom i „normalnim“ pismom (sl. 11). Rezultati raspoznavanja su i u ovom slučaju 100% pravilno razvrstani.

0 0 0 0 0 0 0 0 0 0 0 0  
 0 1 1 1 1 1 1 1 1 1 1 1  
 1 1 2 2 2 2 2 2 2 2 2 2  
 2 2 2 3 3 3 3 3 3 3 3 3  
 3 3 3 3 4 4 4 4 4 4 4 4  
 4 4 4 4 4 5 5 5 5 5 5 5  
 5 5 5 5 5 6 6 6 6 6 6 6  
 6 6 6 6 6 6 7 7 7 7 7 7  
 7 7 7 7 7 7 7 7 7 7 7 7  
 8 8 8 8 8 8 8 8 9 9 9 9  
 9 9 9 9 9 9 9 9 9 9 9 9

Slika 10. Brojke pisane tušem i tehničkim pismom

0 0 0 0 0 1 1 1 1 2 2 2  
 2 2 3 3 3 3 3 4 4 4 4 4 5 5  
 5 5 5 6 6 6 6 7 7 7 7 7  
 8 8 8 8 9 9 9 9 9 9 9

Slika 11. Zbirka ulaznih podataka sa drugi pokus

0 0 0 0 0 0 0 0 1 1 1 1 1 1  
 2 2 2 2 2 2 2 3 3 3 3 3 3  
 4 4 4 4 4 4 4 5 5 5 5 5 5  
 6 6 6 6 6 6 7 7 7 7 7 7 7  
 8 8 8 8 8 8 9 9 9 9 9 9

Slika 12. Dio zbirke ulaznih podataka sa treci pokus

Pokus III

Sastavili smo zbirku iz 77 rukom pisanih numeričkih znakova. Znaci su pisani kemijskom olovkom. Neki od znakova nisu bili zaključeni (npr. 0 ili 9) (sl. 12). I u ovom slučaju rezultat raspoznavanja bio je 100%.

Pokus IV

Sastavili smo zbirku iz 132 znaka. Znakove smo pisali tako da smo dozvolili 20% promjene u visini i širini znakova (sl. 13). U ovom slučaju točno razvrstanih znakova bilo je 88,64%.

0 0 0 0 0 0 0 0 0 0 0 0  
 1 1 1 1 1 1 1 1 1 1 1 1  
 2 2 2 2 2 2 2 2 2 2 2 2  
 3 3 3 3 3 3 3 3 3 3 3 3  
 4 4 4 4 4 4 4 4 4 4 4 4  
 5 5 5 5 5 5 5 5 5 5 5 5  
 6 6 6 6 6 6 6 6 6 6 6 6  
 7 7 7 7 7 7 7 7 7 7 7 7  
 8 8 8 8 8 8 8 8 8 8 8 8  
 9 9 9 9 9 9 9 9 9 9 9 9

Slika 13. Dio zbirke ulaznih podataka sa četvrti pokus

## 5. SINTEZA SUSTAVA ZA RASPOZNAVANJE

Slika 14 prikazuje blok dijagram sustava za raspoznavanje. Izvedba gore opisanog sustava za raspoznavanje jednostavnija je ako se zadatak raspoznavanja izvodi u vremenskom prostoru. Na temelju gore opisanog postupka simulacije - u prvoj fazi odredjene su prijenosne funkcije filtera  $H_i(u,v)$  u frekventnom prostoru.



Slika 14. Blok-dijagram sustava sa raspoznavanje

Vrijednosti izlazne funkcije dvodimenzionalnih prilagođenih filtera  $g_{0i}$ ,  $i = 0, 1, 2, \dots, 9$  u točki  $(0,0)$  su odredjene izrazom:

$$g_{0i} = \sum_{x=0}^{N-1} \sum_{y=0}^{N-1} \mathcal{F}^{-1} [\bar{H}_i(u,v)] g_{II}(x,y), \quad (20)$$

gdje  $\mathcal{F}^{-1}$  označava inverznu Fourierovu transformaciju, a  $\bar{H}_i(u,v)$  konjugirano kompleksnu vrijednost prijenosne funkcije  $H_i(u,v)$ .  $N = 16$ .

Jednadžba (20) predstavlja, u stvari, konvoluciju  $h(x,y) \otimes g_{ij}(x,y)$  u točki  $(0,0)$ .

Računalo domaćin (CYBER 72/24) u fazi inicijalizacije sustava za raspoznavanje prosljedjuje vrijednosti komponenata prijenosnih funkcija filtera sustava za raspoznavanje (sl. 14). Sustav može biti tako oblikovan da su komponente prijenosne funkcije  $h$  za pojedine filtre čvrsto upisane (PROM memorija). Međutim, primjenom veze računalo domaćin - sustav omogućavamo veću prilagodljivost (programabilnost) sustava za raspoznavanje. Vrijednosti  $g_{oi}(0,0)$  i  $i = 0, 1, 2, \dots, 9$  mogu se dobiti u jednom koraku ako se upotrijebe procesori  $p_2$  odnosno „računski demoni“ (definicija 3), (sl. 15).



Slika 15. Procesor  $p_2$

Na primjer, za računanje vrijednosti izlazne funkcije dvodimenzionalnog prilagodenog filtera  $g_{oi}(0,0)$  procesor  $p_2$  ima 256 ulaznih varijabli  $g_{ij}(0,0)$ ,  $g_{ij}(0,1), \dots, g_{ij}(15,15)$  i isto toliko atoma - ulaznih konstanti  $h_i(0,0), h_i(0,1), \dots, h_i(15,15)$ . Procesor  $p_2$  mogao bi se realizirati kao "look-up" tablica sa svim pohranjenim kombinacijama suma  $h_i(x,y)$  budući da je  $g_{ij}(x,y) \in \{0,1\}$  (slike ulaznih uzoraka su binarizirane).

Općenito, vrijednost izlazne funkcije  $g_{oi}(0,0)$  dobivala bi se tako da se na adresne ulaze memorije (u kojoj je pohranjena tablica) dovede binarna kombinacija koja odgovara vrijednosti  $g_{ij}(x,y)$ ;  $x = 0, 1, 2, \dots, 15$  i  $y = 0, 1, 2, \dots, 15$ . Na nesreću, za takvu izvedbu potrebna je memorija vrlo velikog kapaciteta ( $2^{256}$  lokacija). Upravo zbog toga prilikom praktične izvedbe postupak računanja izraza (20) razdijelit ćemo u dva segmenta (sl. 16). U prvom se računaju djelne sume produkta  $\Delta_k = h_i(x,y) g_{ij}(x,y)$ :

$$\Delta_k = \sum_{y=0}^7 h_i(c, y + 8 \cdot \ell) g_{ij}(c, y + 8 \cdot \ell), \quad (21)$$

za  $k = 1, 2, \dots, 32$ , gdje je  $c = \lceil (k/2) \rceil - 1$  i  $\ell = (k-1) \bmod 2$ . Označava gornju cijelobrojnu vrijednost  $x-a$ .

U drugom segmentu dobivamo  $g_{oi}(0,0)$ , pomoću procesora  $p_1$  (definicija 2), kao vrijednost jednovrsnog aritmetičkog izraza:

$$g_{oi}(0,0) = \sum_{k=1}^{32} \Delta_k \quad (23)$$

Procesor  $p_2$  koji računa djelnu sumu produkata  $\Delta_k$



Slika 16. Računski modul s procesorima  $p_2 - p_1$

izведен je kao "look-up" tablica RAM sa samo 256 lokacija. Ulazni operandi u procesoru su  $g_{ij}(x,y)$ , gdje je  $x = c + 8 \cdot \ell, \dots, 7 + 8 \cdot \ell$ ,  $y = 0, 1, 2, \dots, 15$  i  $\ell$  su definirani izrazom (22).

Atomi-konstante  $h_i(x,y)$  i sve kombinacije njihovih suma (256 kombinacija) su pohranjene u procesoru. Na primjer, procesor  $p_2$  koji u jednom koraku računa djelne sume produkta  $\Delta_1$  izведен je kao memorija sa slijedećim sadržajima:

| Adresa (binarno) | Sadržaj                                             |
|------------------|-----------------------------------------------------|
| 0 0 0 0 0 0 0 0  | 0                                                   |
| 0 0 0 0 0 0 0 1  | $h_i(0,0)$                                          |
| 0 0 0 0 0 0 1 0  | $h_i(0,1)$                                          |
| 0 0 0 0 0 0 1 1  | $h_i(0,0) + h_i(0,1)$                               |
| 0 0 0 0 0 1 0 0  | $h_i(0,2)$                                          |
| 0 0 0 0 0 1 0 1  | $h_i(0,0) + h_i(0,2)$                               |
| .                | .                                                   |
| .                | .                                                   |
| 1 1 1 1 1 1 1 1  | $h_i(0,0) + h_i(0,1) + h_i(0,2) + \dots + h_i(0,7)$ |
| ...              | ...                                                 |

Konstante  $h_i(0,0), h_i(0,1), \dots, h_i(15,15)$  odredjene su u fazi učenja klasifikatora, a njihove djelne sume izračunate su i pohranjene u memoriju. Analize su pokazale [16] da je za zapis pojedine konstante dovoljna duljina riječi od dvanaest bita.

Adresa "look-up" tablice je, u stvari, osmorka koja se sastoji od vrijednosti slikevnih elemenata  $g_{ij}(x,y)$ .

Vrijednost  $g_{oi}(0,0)$  dobiva se u jednom koraku upotrebom procesora  $p_1$  higerarhijske razine  $H_1$ . Arhitektura procesora koji istovremeno računa sumu  $m; (m > 2)$ ,  $n$ -bitnih brojeva opisana je u radu N. Konvarasa et al.

[9]. Slika 16 prikazuje organizaciju dvodimenzionalnog prilagodenog filtera koji je realiziran u dva segmenta pomoću procesora  $p_2$  i  $p_1$ . Ocijenimo kapacitet "look-up" tablica sustava za raspoznavanje znakova na bazi dvodi-

menzionalnih prilagodjenih filtera. Ukupni kapacitet memorije  $C$  potreban za izvedbu potrebnog broja procesora  $p_2$  u sustavu za raspoznavanje je:

$$C = c_p \cdot n_p \cdot M \cdot d \text{ [bita]}, \text{ gdje je:}$$

$c_p$  - broj rječi memorije jednog procesora  $p_2$  koji računa djelnu sumu produkta  $\Delta_k$ ,  
 $n_p$  - broj procesora potrebnih za izvedbu jednog prilagođenog filtra,  
 $M$  - broj razreda uzoraka (broj dvodimenzionalnih prilagodjenih filtera),  
 $d$  - duljina rječi izražena u bitovima.

Za sustav opisan u ovom radu  $C$  je:

$$C = 256 \times 32 \times 10 \times 16 = 10 \times 2^{17} \text{ bita} \quad (24)$$

odnosno 84920 rječi duljine šesnaest bita.

Selektor maksimuma rješava se programski ili primjenom integriranih sklopova s tom funkcijom [23].

## 6. ZAKLJUČAK

U radu smo pokazali kako se teorija dvodimenzionalnih prilagodjenih filtera može primijeniti u izvedbi sustava za raspoznavanje znakova. Simulacija sustava za raspoznavanje pokazala je da je sustav djelotvoran posebno za tipizirane znakove ili rukom pisane znakove čije su varijacije po visini i širini manje od 20%. Upotrebom procesora iz viših hijerarhijskih razina prikazali smo model sustava koji je sačuvao visoki stupanj paralelizma svojstven ovom načinu raspoznavanja. U završnom dijelu članka prikazali smo putove praktične izvedbe paralelnog sustava upotrebom LSI komponenti.

## 7. LITERATURA

1. E.C. Lyons, Digital Image Processing: An Overview, Computer, Vol. 10, No. 8, August 1977, str. 12-14.
2. L.D. Harmon, Automatic Recognition of Print and Script, Proc. of the IEEE, Vol. 60, No. 10, October 1972, str. 1165-1176.
3. C.Y. Suen, et al., Automatic Recognition of Hand-printed Characters - The State of the Art, Proc. of the IEEE, Vol. 68, No. 4, April 1980, str. 469-487.
4. D.A. Rosenthal, R. Baycsy, Visual and Conceptual Hierarchy: A Paradigm for Studies of Automated Generation of Recognition Strategies, IEEE Trans. on PAMI, Vol. PAMI-6, No. 3, May 1984, str. 319-325.
5. A.M. Nazif, M.D. Levine, Low Level Image Segmentation: An Expert System, IEEE Trans. on PAMI, Vol. PAMI-6, No. 5, September 1984, str. 555-577.
6. H.C. Andrews et al., Computer Techniques in Image Processing, Academic Press, 1970.
7. L.G. Turin, An Introduction to Matched Filters, IRE Trans. on Information Theory, June 1960, str. 311-329.
8. D.J. Kuck, A Survey of Parallel Machine Organization and Programming, ACM Computing Surveys, Vol. 9, March 1977, str. 29-60.
9. N. Konvaras et al., A Digital System for Simultaneous Addition of Several Binary Numbers, IEEE Trans. on Computers, Vol. C-17, October 1968, str. 992-997.
10. O.G. Selfridge, Pandemonium: A Paradigm for Learning, u: Pattern Recognition (ed. L. Uhr), J. Wiley & Sons, New York, 1966.
11. G.R. Nudd, Concurrent Systems for Image Analysis, u: VLSI for Pattern Recognition and Image Processing, (ed. K.S. Fu), Springer-Verlag, Berlin, 1984, str. 107-132.
12. P.L. Gardner, Functional Memory and Its Microprogramming, Implications, IEEE Trans. on Computers, Vol. C-20, No. 7.
13. R.M. Laugheed et al., Cytocomputers: Architectures for Parallel Image Processing, Proc. Workshop Picture Data Descr. and Management, Pacific Grove Calif. August 27-28, 1980, str. 281-286.
14. S.T. Tou, R.C. Gonzales, Pattern Recognition Principles, Addison-Nesley. Pub. Com., 1974.
15. A. Rosenfeld, A. Kak, Digital Picture Processing, Academic Press, New York, 1976.
16. N. Pavešić, L. Gyergyek, Character Recognition System Based on Two-Dimensional Matched Filters, Electrotechnical Review, Vol. 41, No. 3-4, 1974, p. 13-16.
17. B. Gold, C.M. Rader, Digital Processing of Signals, McGraw Hill, New York, 1969.
18. A. Papoulis, The Fourier Integral and its Applications, McGraw Hill, New York, 1962, str. 30-31.
19. T.S. Huang: Two-Dimensional Windows, IEEE Trans. on Audio and Electroacoustics, AU-20, No. 1, March 1972, str. 88-90.
20. H.C. Andrews, A High Speed Algorithm for the Computers, C-17, No. 4, 1968, str. 373.
21. T.G. Stockham, High-Speed Convolution and Correlation, 1966 Spring Joint Computer Conf. AFIPS Conf. Proc., str. 229-233.
22. B.G. Batchelor (ed.), Pattern Recognition, Ideas in Practice, Plenum Press, New York, 1978.
23. S. Ribarić, N. Pavešić, Mikroprocesorski klasifikator numeričkih znakova s mrežom memorijskih komponenti LSI, Informatica 2/3, 1983, str. 162-167.

PLOT 5 – JEDAN JEDNOSTAVNI  
PROGRAMSKI SISTEM ZA  
GRAFIČKE TERMINALE  
I KOORDINATNE CRTAČE

INFORMATICA 4/86

UDK: 681.3.022.06 PLOT 5

Jozo J. Dujmović i Miodrag Levnać  
Elektrotehnički fakultet Beograd

U radu se opisuje PLOT5 – jedan jednostavni sistem programske podrške za grafičke terminalne i koordinatne crtace. Sistem je projektovan za potrebe inženjerskih aplikacija kod kojih su zahtevi za grafikom ograničeni na jednostavno i efikasno crtanje linijskih crteža. Osnovni zahtev koji je postavljen za PLOT5 je bio da se korisnik može u najkratcu vremenu osposobiti za njegovo korišćenje, a da istovremeno može sa njim da proizvodi najslodenje linijske crteže uključujući familije krivih, dvodimenzionalne i trodimenzionalne objekte. PLOT5 je napisan na FORTRAN-u i lako je prenosiv. Implementiran je na računarima VAX/VMS i trenutno podržava simultani rad sa grafičkim terminalima tipa Tektronix serije 4110 i koordinatnim crtacima tipa CALCOMP 81.

PLOT5 – A SIMPLE SOFTWARE FOR GRAPHIC TERMINALS AND PLOTTERS. The paper presents PLOT5 – a simple software system supporting graphic terminals and plotters. The system is designed for general engineering users interested in simple and efficient production of line drawings. The basic requirement fulfilled by PLOT5 is to enable its user to quickly learn how to use the system for producing complex line drawings (e.g. families of curves, two-dimensional, and three-dimensional objects). PLOT5 is written in FORTRAN, and it is highly portable. It is implemented on VAX/VMS systems and it currently simultaneously supports graphic terminals Textronix 4110 series, and CALCOMP 81 plotters.

## 1. UVOD

Prvi sistemi za grafički prikaz rezultata inženjerskih proračuna pojavili su se početkom šezdesetih godina. Na primer, popularni računari za naučno-tehničke primene kao što su IBM 1620 i kasnije IBM 1130 koristili su koordinatni crtac 1627 koji je omogućavao crtanje linijskih crteža [1]. Crtanje je redovno realizovano iz FORTRAN programa pozivajući skup od 5 potprograma (SCALE, GRID, CHAR, PLOT, i POINT) čija je namena bila uvođenje faktora razmere, crtanje koordinatnih osa, ispisivanje tekstova, crtanje linijskog segmenta i crtanje markera [2]. Najznačajnija osobina ovog grafičkog sistema bila je njegova jednostavnost i efikasnost: korisnici su mogli da nauče osnovno programiranje rada sa crtatem za približno 60 minuta.

Kasniji razvoj kretao se dominantno u pravcu usavršavanja interaktivne računarske grafike [3,4]. Pri tome je došlo do razvoja velikog broja nekompatibilnih grafičkih uređaja i do brojnih jednak nekompatibilnih osnovnih softverskih sistema za njihovu podršku. Naravno, na taj način je softver koji koristi grafičke uređaje postao neprenosiv, pa se pojavila hitna potreba za standardizacijom u ovoj oblasti [5]. U ulozi standarda za sada se pojavljuje GKS [6,7] koji definiše preko 100 osnovnih standardnih funkcija koje omogućavaju široki spektar najrazlicitijih grafičkih primena. Nažalost, univerzalnost GKS-a je dobijena po cenu gubitka jednostavnosti. Tako korisnik za crtanje najprostije krive mora da pozove od 10 do 30 raznih GKS funkcija, a priručnik za GKS uzima znatno više od 100 strana. Prema tome, korisnici koji žele da primenjuju GKS moraju uložiti znatan napor da njime ovlađaju i za veći broj korisnika koji nisu specijalisti za računarsku grafiku, vec povremeno koriste grafičke uređaje za prikaz određenih rezultata, ovakav prilaz može da bude neefikasan.

Imajući u vidu navedene probleme u ovom radu je predložen jedan efikasan sistem za linijsku grafiku čija će upotreba može savladati u roku od 2 sata. Sistem je razvijen kao generalizacija grafičkog sistema za IBM 1130 i u početku je imao za cilj da omoguti jednostavan prelaz korisnicima sa IBM 1130 na VAX/VMS sisteme. Baziran je na 5 osnovnih potprograma i odatle naziv PLOT5. Ovi potprogrami se mogu pozivati iz FORTRAN programa, a takođe i iz drugih jezika koji omogućavaju isti način prenosa argumenata. Pri razvoju PLOT5 sistema utinjen je pokušaj da se, zadrežavajući jednostavnost u rukovanju, u sistem ipak ugradи što više savremenih osobina koje omogućavaju moderni grafički raster terminali i crtaci u boji. Nadalje, posvećena je posebna pažnja efikasnosti implementacije čije su bitne odlike sledeće:

1. Nazavisanost od grafičkog uređaja koja se ogleda u tome da se uređaj biru jednim jedinim identifikatorom u programu i prelaz sa uređaja na uređaj može se obaviti bez prekidanja rada.
2. Automatsko odsecanje svih delova crteža van zadate prikazne površine time je omogućena maksimalna upotrebljivost slike u svim uslovima.
3. Realizacija sistema u vidu delimično povezanog "reentrant" modula, čime su svedeni na minimum kako utrošak memorijskog prostora za izvršne verzije programa, tako i vreme povezivanja sa korisničkim programima.

Trenutno je PLOT5 sistem implementiran na grafičkim terminalima serije TEKTRONIX 4110 i koordinatnim crtacima tipa CALCOMP 81, a u toku

su implementacije za nekoliko drugih grafičkih uređajeva. Rad sa grafičkim uređajima se obavlja tako da se osnovne funkcije grafičkog prikazivanja podataka realizuju koristenjem pet PLOT5 potprograma sa sledećom namenom:

1. Inicijalizacija grafičkog uređaja i definicija parametara preslikavanja.
2. Crtanje koordinatnih osa i mreže sa kotiranjem.
3. Crtanje tačaka i drugih oznaka na željenom mestu ekran-a.
4. Crtanje prave linije od trenutne tačke do određene tačke.
5. Ispisivanje tekstova uz crtež.

Detaljan opis ovih funkcija sledi u nastavku.

## 2. PRIKAZNA POVRŠINA, AKTIVNA POVRŠINA I KORISNIKOV PROSTOR

Ekran grafičkog terminala i prikazna površina koordinatnog crtača su pravougaonici razlititih fizikalnih dimenzija. Pri realizaciji programske podrške za grafičke uređaje uobičajeno je da se "prikazna površina" ("display") meri u normalizovanim jedinicama, tako da je uvek  $0 \leq x \leq x\text{dim} \leq 1$  i  $0 \leq y \leq y\text{dim} \leq 1$ . Pri tome se podrazumeva da važi jedna od dve mogućnosti:

$$\begin{aligned} & x\text{dim} < y\text{dim} = 1, \\ \text{ili} \quad & y\text{dim} < x\text{dim} = 1. \end{aligned}$$

U slučaju grafičkih uređajeva TEKTRONIX 4105 i CALCOMP 81 važi  $x\text{dim}=1$  pri čemu je:

$$\begin{aligned} y\text{dim} &= 0.765 \text{ za grafički terminal TEK 4105 i za} \\ &\text{kopir aparat TEK 4695} \\ &= 0.8284 \text{ za koordinatni crtač Calcomp 81.} \end{aligned}$$

Velicine pravougaone prikazne površine su  $200 \times 153$  mm za grafički terminal i kopir aparat i  $338 \times 280$  mm za koordinatni crtač Calcomp 81.

Prikazna površina grafičkog uređaja data je na slici 1. Redovno korisnik ne koristi celu prikaznu površinu. Pod "aktivnom površinom" ("viewport") podrazumeva se onaj deo prikazne površine na koji korisnik namerava da ograniči svoj crtež.



Slika 1.

Sa druge strane, "korisnikov prostor" ("window") je u opštem slučaju pravouglja oblast u korisnikovom koordinatnom sistemu koja obuhvata sve ono što korisnik namerava da posmatra (slika 2.) Korisnikov prostor se po X osi proteže od XMIN do XMAX a po Y osi od YMIN do YMAX, gde su XMIN, XMAX, YMIN, i YMAX zadati u korisnikovim jedinicama i prema tome predstavljaju proizvoljne racionalne brojeve. Kod prikazivanja na grafičkim uređajima

korisnikov prostor se preslikava na aktivnu površinu.



Slika 2.

Dimenzije aktivne površine ( $sx$  i  $sy$ ) kao i koordinate njenog levog donjeg ugla ( $px$  i  $py$ ) zadaju se u koordinatama jediničnog kvadrata pa prema tome moraju da zadovolje uslove

$$\begin{aligned} 0 \leq px < 1, \quad 0 \leq py < y\text{dim}, \\ 0 \leq px+sx \leq 1, \quad 0 \leq py+sy \leq y\text{dim}. \end{aligned}$$

Na primer, korisnik može da nacrta kvadratnu sliku najvećeg formata birajući  $px=py=0$ ,  $sx=sy=y\text{dim}$ .

Prema tome, celokupno grafičko preslikavanje može se definisati sa skupom od sledećih 10 parametara:

|                            |                                                                            |
|----------------------------|----------------------------------------------------------------------------|
| $x\text{dim}, y\text{dim}$ | = parametri prikazne površine (fiksno definisan za svaki konkretni uređaj) |
| $px, py, sx, sy$           | = parametri aktivne površine                                               |
| $XMIN, XMAX, YMIN, YMAX$   | = parametri korisničkog prostora                                           |

Delovi crteža mogu da izadju i van okvira aktivne površine a i van okvira prikazne površine. Na crtačima i na grafičkim terminalima se delovi crteža van prikazne površine uvek automatski odsecaju bez bilo kakvih posledica na deo crteža koji se nalazi na prikaznoj površini. Delovi crteža van aktivne površine mogu se takođe automatski odsecati, ali samo na eksplicitan zahtev korisnika dat u potprogramu SCALE.

## 3. BOJE, PISALJKE I KOPIRANJE CRTEŽA

Grafički terminal radi sa 8 boja koje su kodirane brojevima 0, 1, ..., 7. Sistem PLOT5 daje ovim brojevima, prema standardu TEKTRONIX-a, sledeće početne vrednosti:

|            |                  |
|------------|------------------|
| 0 - crno   | 4 - tamno plavo  |
| 1 - belo   | 5 - svetlo plavo |
| 2 - crveno | 6 - ljubičasto   |
| 3 - zeleno | 7 - zuto         |

Navedene vrednosti mogu se po potrebi menjati koristeći "setup" proceduru terminala ali u svakom momentu broj prisutnih boja koje terminal simultano prikazuje ne može biti veći od 8. Prema tome, u svim programima koji slede pod pojmom "boja" podrazumeva se jedna cifra koja je interpretacija definisana gornjom tabelom. Pri tome terminal podrazumeva da je boja pozadine crteža početno definisana sa kodom 0 pa je stoga pozadina uvek crna (neosvetljena). Ako se želi to izmeniti onda se mora intervenisati u "setup" proceduri sa kojom se može kodu 0 dodeliti proizvoljna boja.

ili odrediti da boji pozadine ne odgovara kod 0, već neki drugi od postojećih kodova. Crtež se sa ekrana može direktno kopirati na papir, pri čemu se koristi kopir aparat TEK 4695. Kopiranje traje oko 4 minuta, pa ga treba koristiti sa merom i to uvek samo za konačne rezultate.

Koordinatni crtac ima 8 pozicija za pisaljke koje mogu biti u raznim bojama i/ili u raznim debeljinama. Promena pisaljke programske je ekvivalentna promeni boje na grafičkom terminalu. Početni razmestaj pisaljki u 8 raspoloživih kucista obavlja se pre početka rada rutno od strane operatora. Naravno, pisaljke se mogu menjati i u toku rada ako se za to predviđi odgovarajuća pauza.

#### 4. INICIJALIZACIJA UREDJAJA I DEFINISANJE PARAMETARA PRESLIKAVANJA

Da bi se korisniku olakšalo programiranje svih PLOTS potprogrami za rad sa grafičkim uređajima su isti za sve uređaje. Naravno, fizičke osobine uređaja i način komuniciranja sa njima se međusobno razlikuju. Stoga je na početku rada neophodno definisati uređaj sa kojim se namerava raditi, izvršiti inicijalizaciju uređaja i uvesti parametre preslikavanja. To se postiže pozivom potprograma

```
CALL SCALE ( ID, px,py, sx,ay,
              XMIN,XMAX, YMIN,YMAX )
```

pri čemu je ID identifikator grafičkog uređaja i načina odsecanja:

| ID | = 1 , za grafički terminal TEK 4105  
| | = 2 , za koordinatni crtac Calcomp 81.

Ako je ID>0 onda se odsecanje obavlja na granici prikazne površine, a ako je ID<0 onda se odsecanje obavlja na granici aktivne površine.

Smisao velicina px,py, sx,ay, XMIN,XMAX, YMIN,YMAX je jasan sa slikama 1 i 2. Pri tome ponavljamo da su px,py,sx,ay izraženi u delovima jediničnog kvadrata (tj. u normalizovanim koordinatama), dok su XMIN,XMAX, YMIN,YMAX izraženi u korisnikovim jedinicama koje će se isključivo koristiti u ostalim PLOTS potprogramima. Korisnikov prostor obuhvata pravougaonik

```
XMIN <= X <= XMAX
YMIN <= Y <= YMAX ,
```

pri čemu XMIN, XMAX, YMIN, i YMAX mogu biti proizvoljne pozitivne, nulte ili negativne velicine, time se određuje gde će biti koordinatni potetak (vidljiv unutar ili na rubu slike, ili nevidljiv izvan slike). To znači da se tačka korisnikovog prostora sa koordinatama XMIN,YMIN preslikava u tačku sa koordinatama px,py prikazne površine (tj. u levi donji ugao aktivne površine).

Prilikom crtanja na koordinatnom crtalu (a i na drugim grafičkim uređajima) najčešće se polazi od željenih dimenzija slike koje se zadaju u dužinskim jedinicama (cm ili mm). To su:

H = horizontalna dimenzija (širina) slike  
V = vertikalna dimenzija (visina) slike.

Velicine H i V određuju fizike dimenzije aktivne površine. Sa druge strane, fizike

dimenzije prikazne površine (horizontalna dimenzija HH i vertikalna dimenzija VV) konstantne su i zavise od uređaja. Korisnik takođe redovno zeli da njegova slika ima donju (horizontalnu) marginu i levu (vertikalnu) marginu čije su dimenzije HM i VM respektivno. Koristeći zadate velicine H, V, HH, VV, HM i VM mogu se direktno izračunati parametri aktivne površine. Ako je  $xdim=1$  ovi parametri su:

$$\begin{aligned} px &= VM/HH, \quad py = HM/VM \\ sx &= H/HH, \quad sy = V/VM \end{aligned}$$

i mogu se direktno uneti u poziv potprograma SCALE.

Potprogram SCALE definiše trenutno koristeni uređaj koji se može tokom rada menjati. Tako će, na primer, pozivom CALL SCALE(1,...) biti korisniku dodeljen grafički terminal na koga će se odnositi svi naredni PLOTS potprogrami. Ako se u istom programu zatim izvrši poziv CALL SCALE(2,...) onda će se grafički terminal osloboditi i korisniku dodeliti crtac na koga će se zatim primenjivati preostali potprogrami. Novi poziv CALL SCALE(1,...) oslobadja crtac (i drugi korisnici ga mogu odmah koristiti) i opet zauzima grafički terminal. Treba napomenuti da se pri promeni grafičkog uređaja po pravilu menjaju parametri prikazne i aktivne površine u potprogramu SCALE, ali pozivi svih ostalih potprograma ostaju neizmenjeni.

#### 5. CRTANJE KOORDINATNIH OSA I MREŽE SA KOTIRANJEM

Ova funkcija se obavlja pozivom

```
CALL GRID ( DX, NX, DY, NY, ID )
```

gde su DX i DY velicine jednog podeoka (t.j. razmak između dve susedne linije koordinatne mreže) po x i y koordinati izražene u korisnikovim jedinicama, NX i NY predstavljaju broj označenih podintervala na koje je izdeljen svaki podeok (ako nema podintervala onda je NX=NY=1), a ID je četvorocifreni identifikator načina crtanja definisan sa četiri cifre, okab, sledećeg značenja:

o = pravougaoni okvir korisnikove slike  
(0 = bez okvira, 1 = sa okvirom slike)  
k = kotirane ose (0 = bez ose, 1 = sa osama i kotiranjem)  
m = mreža (0 = bez mreže, 1 = mreža od punih linija, 2 = mreža od dužih crtica, 3 = mreža od kracić crtica [na grafičkom terminalu to su tačkice], što je veća vrednost za m to je rad crtata sporiji)  
b = boja (kodirano sa identifikatorom boje 0,...,7)

Ako ose ne prolaze kroz korisnikovu sliku onda se u slučaju ID=110b automatski kotiraju sve tetiri strane okvira, a u slučaju ID=010b se crtaju one dve kotirane strane okvira koje su najbliže koordinatnim osama. U slučaju ID=10mb nema kotiranja, pa vrednosti NX i NY nemaju uticaja. Kad god se traži mreža automatski se crta i (kotirani ili nekotirani) okvir.

#### 6. CRTANJE TAČAKA I DRUGIH OZNAKA NA ŽELJENOM MESTU PRIKAZNE POVRŠINE

Ispisivanje željene oznake u tački X,Y (izraženo u korisničkim koordinatama) realizuje se pozivom

## CALL POINT ( X, Y, ID )

gde identifikator ID definise tip oznake sa dve ili tri cifre pri čemu zadnja cifra (b) označava boju oznake :

```
4105 i 81
=====
1b = .
2b = + (mali plus)
3b = + (veći plus)
4b = X (veći iks)
5b = veci kvadrat
6b = *
=====
```

Samo 81

```
=====
7b = < | strelice za
8b = > | koordinatne
9b = ^ | ose i oznake
10b = v | tačaka
11b = y
12b = mali ispunjeni kvadrat
13b = mali neispunjjeni kvad.
14b = x (manji iks)
=====
```

Samo 4105

```
=====
15b = 0 (nula)
16b = kvadrat sa tačkom unutra
17b = ispunjeni kvadrat
18b = romb
19b = ispunjeni romb
```

Identifikator ID može biti i negativan. U tom slučaju X i Y su u korisnikovim jedinicama izražene velicine RELATIVNOG POMAKA iz date polazne tačke (t.j. X i Y se ne izražavaju u odnosu na koordinatni početak vet u odnosu na trenutni položaj ukazatelja ekrana). Tip oznake određen je absolutnom vrednošću identifikatora ID, na način prikazan gornjom tabelom.

U slučaju grafičkog terminala potprogram POINT se može primeniti i za brisanje ekrana, što se realizuje pomoću identifikatora ID=0. U tom slučaju X označava broj sekundi čekanja pre brisanja ekrana a Y označava broj sekundi čekanja posle brisanja ekrana. Stoga, na početku programa, u većini slučajeva treba primeniti poziv CALL POINT(0.,0.,0); crtac na ovo ne reaguje.

## 7. CRTANJE PRAVE LINIJE OD TRENUTNE TAČKE DO ODREDISNE TAČKE

U svakom momentu pisaljka crtaca ili ukazatelj ekrana grafičkog terminala se nalaze u nekoj tački prikazne površine. Ovu tačku nazivamo trenutna pozicija i označavamo sa A. Neka su X,Y koordinate proizvoljne odredisne tačke B. Tačke A i B mogu se spojiti pravom linijom pomoću poziva

## CALL LINE ( X, Y, ID )

pri čemu su X i Y izraženi u korisnikovim jedinicima. Ako je ID>0 onda su X i Y u absolutne koordinate u odnosu na koordinatni početak. Ako je ID<0 onda su X i Y u korisnikovim jedinicama izražene velicine relativnog pomaka iz polazne tačke A (t.j. X i Y se ne izražavaju u odnosu na koordinatni

početak vet u odnosu na trenutni položaj). Tip linije i boja (b) su određeni absolutnom vrednošću identifikatora ID na sledeći način:

|    |   |                                              |             |
|----|---|----------------------------------------------|-------------|
| 1b | = | pomak bez crtanja linije                     |             |
| 2b | = | ===== (puna linija)                          |             |
| 3b | = | ..... (tačkasta linija)                      |             |
| 4b | = | - - - - - (tačka - crta)                     |             |
| 5b | = | - - - - - (crtkana linija - kratke crticice) |             |
| 6b | = | - - - - - (crtkana linija - duge crticice)   |             |
| 7b | = | - ... - ... - .. (tri tačke - crta)          | [Samo 4105] |
| 8b | = | __ - - - - (duga crta - kratka crta)         |             |
| 9b | = | __ - - - - (crtkana linija - dugi razmak)    |             |

## 8. ISPISIVANJE TEKSTOVA UZ CRTEŽ

Na korisnikovoj slici moguće je ispisivati proizvoljne tekstove pomoću potprograma

## CALL TEXT ( X, Y, DATA, F, ID )

pri čemu argumenti imaju sledeću interpretaciju:

X,Y = koordinate levog donjeg ugla teksta izražene u korisnikovim jedinicama.

DATA = podatak koji se ispisuje: može biti znakovnog, celobrojnog ili racionalnog tipa.

F = veličina koja označava format ispisivanja na sledeći način:

F = <ukupan broj znakova>, ako je DATA niz znakova ili ceo broj

F = <ukupan broj znakova>.<broj znakova desno od decimalne tačke>, za slučaj da je DATA racionalan broj.

ID = [-]juvbst (identifikator, do 7 cifara) kojim se određuje nagib slova, ugao linije teksta, veličina slova, boja, smer, i tip teksta na sledeći način:

Negativan identifikator označava za CALCOMP 81 slova nagiba 75 stepeni, a pozitivan identifikator slova nagiba 90 stepeni (kod grafičkog terminala nagib slova je uvek 90 stepeni).

U = ugao linije teksta sa +x osom dat u stepenima (1 do 3 cifre, pri čemu je u >= 0). Koordinatni crtac ovaj ugao može da tačno prikaže, dok grafički terminal vrši zaokruživanje zadatog ugla na najbliži multipl od 90 stepeni.

v = oznaka veličine slova iz skupa {0,1,...,9} kojom se određuje sirina slova prema sledećoj tabeli:

sirina slova u mm.

| v   | 0   | 1   | 2   | 3   | 4   | 5   | 6    | 7    | 8    | 9  |
|-----|-----|-----|-----|-----|-----|-----|------|------|------|----|
| TEK | 2.1 | 2.1 | 4.2 | 6.3 | 8.4 | 10  | 12.6 | 14   | 16.5 | 19 |
| CAL | 1.2 | 1.8 | 2.4 | 3.0 | 3.6 | 4.2 | 7.2  | 12.6 | 20   | 30 |

Za koordinatni crtac CALCOMP 81 visina slova se određuje automatski

- i iznosi 3/2 širine. Za TEKTRONIX 4105 visina slova je 7/5 širine.
- b = boja teksta (0,1,...,7)
- s = smer ispisivanja iz skupa od 4 smera u odnosu na liniju koju definiše odabrani ugao u ( 0=desno, 1=gore, 2=levo, 3=dole ).
- t = tip teksta kojim se određuje šta se ispisuje, na sledeći način:
- t = 1, ako je DATA celobrojnog tipa
  - t = 2, ako je DATA racionalnog tipa
  - t = 3, ako je DATA znakovnog tipa

## 9. IMPLEMENTACIJA PLOTS SISTEMA

Grafički sistemi koji nude mogućnosti kao PLOTS, u tipičnom slučaju se sastoje od stotinak potprograma i prevedeni mogu sauzimati od 50KB na više. To znači da bi praktično svaki grafički program morao obuhvatiti celokupan proces povezivanja i da bi izvršna verzija svakog programa bila opterećena sa celokupnim softverom grafičkog sistema. Na taj način se pored gubitka vremena dolazi do potpuno neprihvatljive situacije u kojoj se na diskovima nalazi onoliko kopija celokupnog grafičkog softvera, koliko ima grafičkih programa. U uslovima velikog broja korisnika i velikog broja malih grafičkih programa ovo može da bude izuzetno ozbiljan problem. Zbog toga je neophodno da implementacija grafičkog softvera zadovolji dva fundamentalna zahteva:

1. Parcijalno povezivanje svih grafičkih potprograma sa izuzetkom najvišeg nivoa time se formira bazični grafički modul
2. Fiksno i jednokratno instaliranje bazičnog grafičkog modula u memoriju računara tako da je istovremeno dostupan svim korisničkim grafičkim programima.

PLOTS sistem zadovoljava navedena dva zahteva. Parcijalnim povezivanjem su potprogrami SCALE, GRID, POINT, LINE i TEXT jednom za uvek povezani sa svim potprogramima koji se dalje lančano pozivaju i tako je formiran bazični grafički modul. Proses poverzivanja korisničkog programa sa bazičnim grafičkim modulom je tada veoma brz jer se svodi na realizaciju samo onoliko veza koliko u korisničkom programu ima poziva osnovnih PLOTS potprograma. Sa druge strane, izvršni programi su veoma mali jer obuhvataju jedino korisničke instrukcije i veze sa bazičnim grafičkim modulom. Naravno, za ovakav način implementacije neophodna je i odgovarajuća podrška operativnog sistema koja je u slučaju VMS-a raspoloziva.

## 10. PRIMERI PRIMENE PLOTS SISTEMA

Verovatno najčešći primer primene grafičkih sistema je crtanje familija krivih. Stoga je u nastavku prikazan jedan opšti program za ispitivanje osobina familije krivih prema sledenim zahtevima:

- (1) Korisnik prikazuje familiju krivih na grafičkom terminalu zadajući interaktivno koordinate korisničkog prostora XMIN, XMAX, YMIN, YMAX time bira i proizvoljno uvećava deo XY ravnji koji zeli da posmatra.

```

C-----+
C   CRTANJE FAMILIJE KRIVIH NA TERMINALU I !
C   KOORDINATNOM CRTACU !
C-----+
C   HH,VV = Dimenzije prikazne površine u mm
C   H ,V = Zeljene velicine aktivne površine
C   (velicina crteza) u mm
C   HM,VM = Sirine horizontalne i vertikalne
C   marge u mm
C   SS = Dimenzije sirine slova u mm
C   IS1 = Ident. zeljene sirine slova (kote)
C   IS2 = Id. zeljene sirine slova (naslov)
C   NX,NY = Broj kotiranih podeoka duž osa
C   NK = Opseg u kome se kreće parametar
C   familije krivih K (-NK <= K <= NK)
C   NSEG = Broj linijskih segmenata po krivoj
C-----+
C   DIMENSION HH(2), VV(2), H(2), V(2),
C   * HM(2), VM(2), SS(0:9,2), IS1(2), IS2(2)
C   CHARACTER*30      NASLOV ! Naslov slike
C-----+
C   DATA HH, VV /200., 338., 153., 280./,
C   * H, V /110., 102., 110., 102. /
C   DATA SS /
C   * 2.1,2.1,4.2,6.3,8.4,10.,12.6,14.,16.5,19.
C   * 1.2,1.8,2.4,3.,3.6,4.2,7.2,12.6,20.,30./
C   DATA IS1/1,1/, IS2/2,4/, NX,NY/10,10/,
C   * NK/5/, HM,VM/36.,80.,45.,30./, NSEG/150/
C-----+
C   Familija krivih sa parametrom K
C   F(X,K) = 4*SIN(0.9*K) + (X-2*K)**2
C   NASLOV = 'Primer familije parabola'
C   DO WHILE (.TRUE.) ! Početak glavne petlje
C-----+
C   Unos parametara i izbor uređaja
C   PRINT *, 'XMIN,XMAX,YMIN,YMAX, Tip',
C   * ' uređaja (1-terminal, 2=plotter) ? '
C   READ *, XMIN, XMAX, YMIN, YMAX, ID
C   IF (ID .LT. 1 .OR. ID .GT. 2) STOP
C-----+
C   Inicijalizacija uređaja i definisanje
C   parametara preslikavanja
C   CALL SCALE( ID,
C   * VM(ID)/HH(ID), HM(ID)/HH(ID),
C   * H(ID)/HH(ID), V(ID)/HH(ID),
C   * XMIN, XMAX, YMIN, YMAX ) ! Brisanje ekrana
C-----+
C   Prikaz koordinatne mreže
C   PODEOKX = (XMAX-XMIN) / NX
C   PODEOKY = (YMAX-YMIN) / NY
C   CALL GRID(PODEOKX, 2, PODEOKY, 2, 1131)
C-----+
C   Ispisivanje naslova i kotiranje osa
C   S = SS(IS1(ID),ID) ! Sirina slova u mm
C   SIR = S*(XMAX-XMIN)/H(ID) ! Dim slova u
C   VIS = 1.5*S*(YMAX-YMIN)/V(ID) ! kor.jed.
C   CALL TEXT(XMIN,YMAX+VIS/2,NASLOV,30,
C   * 1000*IS2(ID) + 103)
C   DO 1 = 0, NX ! Kotiranje X ose
C   XI = 1 * PODEOKX + XMIN
C   CALL TEXT( XI-2.5*SIR, YMIN-2*VIS,
C   * XI, 4.1, 1000*IS1(ID) + 102 )
C   END DO
C   DO 1 = 0, NY ! Kotiranje Y ose
C   YI = 1 * PODEOKY + YMIN
C   CALL TEXT( XMIN-5.5*SIR, YI,
C   * YI, 4.1, 1000*IS1(ID) + 102 )
C   END DO
C-----+
C   Prikaz krivih F(X,K)
C   CALL SCALE(-ID) ! Promena granice odsec.
C   DX = (XMAX - XMIN) / NSEG
C   DO K = -NK,NK ! K = Parametar krive
C   CALL LINE( XMIN, F(XMIN,K), 11)
C   DO IX = 1,NSEG ! Petlja za crta-
C   X = XMIN + DX*IX ! nje jedne krive
C   CALL LINE( X, F(X,K), 21 )
C   END DO
C   END DO
C   CALL LINE( XMIN, YMIN, 11 ) ! Povratak
C   END DO ! na granicu aktivne
C   STOP ! površine na kraju rada
C   END

```

- (2) PLOTS programi vrše automatsko ispisivanje odgovarajućih vrednosti koordinata uz ose.
- (3) Kada se interaktivno odabere pogodan korisnički prostor onda se slika prikazuje na crtaču.

Ovakav rad je omogućen činjenicom da PLOTS automatski odseca delove familije krivih van aktivne površine i automatski postavlja koordinatni sistem na odgovarajuće mesto na aktivnoj površini. Prikazani program je pisan tako da služi kao paradigma primene PLOTS sistema. Može se univerzalno koristiti za prikazivanje familija krivih i stoga koristi niz parametara definisanih u DATA specifikacijama. Modifikacijom ovih parametara program se može lako prilagoditi drugim

primenama. I pored jednostavnosti (samo tridesetak instrukcija) ovaj program prikazuje koordinatni sistem, koordinatnu mrežu, kotiranje x i y osa, ispisivanje naslova slike, crtanje niza krivih i podešavanje proizvoljne veličine crteža uz simultani interaktivni rad na dva grafička uređaja i efekte zumiranja. Ovakvim programom se omogućava svestrana analiza osobina familija krivih i njihov kvalitetan grafički prikaz. U poredjenju sa univerzalnim grafičkim sistemima navedeni PLOTS program je znatno kompaktniji i lakši za korištenje.

PLOTS sistem se može uspešno koristiti i u slučaju programa za realizaciju složenijih linijskih crteža. Jedan takav primer primene PLOTS sistema ilustruje slika 5.



Slika 3.



Slika 5.



Slika 4.

#### REFERENCE

- [1] IBM, "IBM 1627 Plotter", (GA26-5710).
- [2] IBM, "IBM 1130/1800 Plotter Subroutines", (GC26-3755).
- [3] Newman, W.M., and R.F. Sproull, "Principles of Interactive Computer Graphics". Second Edition, McGraw-Hill, 1981.
- [4] Foley, J.D. and A. Van Dam, "Fundamentals of Interactive Computer Graphics". Addison-Wesley, 1983.
- [5] ACM SIGGRAPH Committee, "Status Report of the Graphics Standards Committee", Computer Graphics 13(3), August 1979.
- [6] Hopgood, F.R.A., D.A. Duce, J.R. Gallop, and D.C. Sutcliffe, "Introduction to the Graphical Kernel System (GKS)". Academic Press, 1983.
- [7] Enderle, G., K. Kansy, and G. Pfaff, "Computer Graphics Programming / GKS - The Graphics Standard". Springer-Verlag 1984.

Institut Jožef Stefan, Ljubljana  
UDK: 681.3.02

Jurij Šilc, Borut Robič

Članek predstavlja prvi procesor s podatkovno pretokovno arhitekturo. Notranja krožna pipeline organizacija, ki temelji na podatkovnem vodenju, daje procesorju veliko moč. Bogat nabor ukazov je prirejen tako, da je procesor zelo uporaben za hitro obdelavo slikovnih in govornih signalov. Potreba po takšnih obdelavah se pojavlja v računalnikih pete generacije.

Data Flow Architecture Based Processor - A new data flow architecture based processor is described. The processor employs token based data flow and pipelined architecture to achieve a very high throughput rate in the realm of digital image and speech processing.

## 1. UVOD

Pri načrtovanju sistemov za obdelavo slik smo običajno prisiljeni poiskati kompromis med hitrostjo in fleksibilnostjo sistema. Okornost in pogodbost sistem, ki ga sestavljata miniračunalnik za obdelavo slike in masovni pomnilnik za njeno shranjevanje, sta nesprejemljivi za delo v realnem času. Z dodatkom posebne materialne opreme se hitrost obdelave poveča, toda žal na račun fleksibilnosti, saj vsaka spremembra programske opreme narekuje spremembu materialne opreme. Omenjeni razkorak med hitrostjo in fleksibilnostjo sistema je moč omiliti z uporabo programabilnega slikovnega procesorja, ki se odlikuje s podatkovno vodeno arhitekturo.

## 2. PODATKOVNO PRETOKOVNI PROCESOR

V nasprotju s von Neumannovimi procesorji, ki delujejo na podlagi dostave ukazov, temelji delo podatkovno pretokovnega procesorja na zbiranju in obdelavi paketov (tokens).

### 2.1. Osnovna arhitektura procesorja

Podatkovno pretokovni procesor ne rabi dostave ukaza. Namesto tega vsebuje grafini pomnilnik (tabeli povezav in točk), v katerega se pred pričetkom izvrševanja vpisajo programski podatki. Pretok podatkov se vrši s pomočjo paketov, ki vsebujejo naslov procesorja, identifikator, podatkovno ter krmilno polje. Med pretokom po procesorju paket še nekajkrat spremeni vsebino in dolžino, kot bo razvidno iz kasnejšega opisa.

Notranja krožna pipeline arhitektura (Slika 1) omogoča procesni enoti neprekinitno delovanje. Procesna enota vsebuje množilnik in ALU, ki omogoča standardne aritmetično logične operacije. Nabor ukazov je širši kot pri večini klasičnih procesorjev.



Slika 1: Krožna pipeline arhitektura podatkovno pretokovnega procesorja.

### 2.2. Večprocesorski podatkovno pretokovni sistem

Večprocesorski podatkovno pretokovni sistem sestavlja kaskada podatkovno pretokovnih procesorjev, povezanih z glavnim procesorjem, kot je prikazano na Sliki 2.



Slika 2: Podatkovno pretokovni računalnik.

Komunikacija med podatkovno pretokovnim procesorjem in okolico poteka s posočjo vhodno-izhodnega krmilnika. Glavni procesor pošlje paket podatkovno pretokovnemu procesorju. Iz naslovnega polja paketa podatkovno pretokovni procesor ugotovi, da je paket namenjen njemu ter ga v tem primeru sprejme, izloči naslovno polje in pošlje v pretok - najprej v grafini pomnilnik (tabelo povezav). Paket, ki ni namenjan danemu procesorju, se nespremenjen pošlje v istem ciklu preko vhodno-izhodnega krmilnika naslednjemu procesorju. Procesor je tako za tuje pakete transparenten. Torej vsak podatkovno pretokovni procesor zbira svoje pakete.

### 2.3. Delovanje podatkovno pretokovnega sistema

Delovanje podatkovno pretokovnega računalnika, kot ga prikazuje Slika 2, ilustrirajmo z naslednjim primerom. Dan naj bo program za izračun  $E = (A+B)*(A-B)$ , opisan s podatkovno pretokovno programske grafov 6 (Slika 3). Graf 6 lahko razbijemo na tri podgrafe  $G_1$ ,  $G_2$  in  $G_3$ . Ker se lahko izvršujejo  $G_1$  in  $G_2$  vzopredno, ju je mogoče vpisati v dva različna podatkovno pretokovna procesorja  $P_1$  in  $P_2$ .  $G_3$  lahko vpisemo v katerikoli procesor, npr. v  $P_1$ . Program se prične izvrševati takoj, ko glavni procesor pošlje vhodna paketa A in B. Tako mora za izvršitev operacije C = A + B procesor  $P_1$  prejeti paketa, ki nosita vrednosti A in B, če pa nato lahko izvrši operacijo '+'. Vhodna paketa lahko prispeva v poljubnem zaporedju, taj je procesor sposoben razpoznavati pakete in jih hraniti v paketnem pomnilniku. Iz opisa podgrafe  $G_1$ , ki se nahaja v njegovem grafnem pomnilniku, je ugotovljeno, da paketa A in B pripadata preko operacije '+' paketu C, zato ju združi in pošlje v procesno enoto. Vrednost, ki je rezultat izvršitve v procesni enoti, se vstavi v paket in opremi z oznako C. Istodobno se v procesorju  $P_2$  izračuna paket D, ki ga  $P_2$  pošlje glavnemu procesorju. Ker je C vhodni paket nove operacije, ki se mora izvršiti v istem procesorju  $P_1$ , se shrani v njegov paketni pomnilnik, dokler iz glavnega procesorja ne prispe paket D. Tedaj sta v procesorju  $P_1$  oba paketa za izvršitev operacije '\*' in že prej opisani postopek se ponoviti. Vidimo, da zagotavlja pravilna izbiro predhodno vpisanega podgrafa izkoristanje vsebovane vzoprednosti ter neprekinjeno delo procesorjev.



Slika 3: Podatkovno pretokovni graf za izračun  $E = (A+B)*(A-B)$ .

### 3. PODATKOVNO PRETOKOVNI PROCESOR μPD7281

Primer podatkovno pretokovnega procesorja je NEC μPD7281, katerega moč temelji na krožno organizirani pipeline arhitekturi ter bogates naboru ukazov. μPD7281 je prvi VLSI čip, ki deluje po načelih podatkovno pretokovne arhitekture [3]. Ta omogoča vedno udinkovitost procesorja v mnogih večprocesorskih aplikacijah, kot sta procesiranje slik ter razpoznavanje vzorcev na področju umetne inteligence, kjer se uporabljajo algoritmi za dvodimensionalno konvolucijo, povečavo, pomanjšavo in rotacijo. Njegova udinkovitost postane oditna predvsem pri procesiranju slik v realnem času, kjer dobrega izkoristila vsebovane vzoprednosti uporabljenih algoritmov. μPD7281 ni uporaben le pri procesiranju slik, temveč tudi pri zahtevnih numeričnih izračunih, kot so matrično matrično množenje, matrično vektorsko množenje, aritmetika s plavajočo vejico ter izračuni transcedentnih funkcij v realnem času.

#### 3.1. Pipeline organizacija procesorja

Kot je prikazano na Sliki 4 sestavlja procesor deset funkcionalnih enot: vhodni krmilnik (IC), izhodni krmilnik (OC), tabela povezav (LT), tabela točk (FT), paketni pomnilnik (DM), vrsta (Q), procesna enota (PU), izhodna vrsta (OQ), generator naslovov in krmilnik pretoka (AG&FC) ter osveževalni krmilnik (RC).



IC: vhodni krmilnik (Input Controller)  
 OC: izhodni krmilnik (Output Controller)  
 LT: tabela povezav (Link Table)  
 FT: tabela točk (Function Table)  
 DM: paketni pomnilnik (Data Memory)  
 Q: vrsta (Queue)  
 PU: procesna enota (Processing Unit)  
 OQ: izhodna vrsta (Output Queue)  
 AG&FC: generator naslovov (Address Generator) in krmilnik pretoka (Flow Controller)  
 RC: osveževalni krmilnik (Refresh Controller)

Slika 4: Architektura procesorja μPD7281.

### 3.2. Vhodni IC in izhodni OC krmilnik

32 bitni vhodni paket vstopi v IC v obliki, kot jo prikazuje Slika 5.

|    |     |    |         |         |
|----|-----|----|---------|---------|
| 4  | 1   | 7  | 4       | 16      |
| MN | I2I | ID | I CTRLI | podatki |

Slika 5: 32 bitni vhodno-izhodni paket.

IC primerja lastni naslov, ki mu je bil dodeljen ob resetu, z MN poljem vhodnega paketa. Če se naslova ne ujemata, se tuji paket takoj prenese v OC. Pakete takšnih oblik imenujejo PASS paketi. Če pa se naslova ujemata, se MN polje izloži in tako spremenjen paket poslje v LT. IC hkrati ugotavlja, če je v procesorju prostor za novi paket in ga po potrebi zadrži. OC posilja 32 bitne izhodne pakete, katerih oblika je enaka vhodnim paketom (Slika 5). Izhodni paketi so bodisi podatkovni paketi iz 08, statusni paketi, ki jih generira OC v primeru napak, dump paketi ali tuji vhodni paketi, dabljeni iz IC, ki se tu imenujejo PASSO paketi.

Tuji paket na vhodu (vh. paket PASS):

|        |    |         |         |
|--------|----|---------|---------|
| MN'10I | ID | I CTRLI | podatki |
|--------|----|---------|---------|

Tuji paket na izhodu (izh. paket PASSO):

|        |    |         |         |
|--------|----|---------|---------|
| MN'10I | ID | I CTRLI | podatki |
|--------|----|---------|---------|

Opomba: MN' se ne ujema z MN danega procesorja.

### 3.2.1. Načini delovanja:

Procesor lahko deluje v treh načinih: normalnem (Normal), testnem (Test) in prekinitvenem (Break) načinu. Po hardverskem resetu je procesor v normalnem načinu delovanja. V tem načinu poteka vpis, branje in izvrševanje podgrafa. V testnem načinu delovanja je omogočeno testiranje izvrševanja. Procesor preide v testni način, ko sprejme vhodni paket SETBRK. Če med delovanjem pride do nasičenja vrste DG ali GG, preide procesor v prekinitveno delovanje, opisano z vhodnim paketom SETMD. V prekinitveni način lahko preide procesor tudi iz testnega načina, tako da dobi paket CBRK. V prekinitvenem načinu delovanja je omogočeno dumpanje. Iz obih načinov se vrne v normalni način po sprejetju vhodnega paketa CRESET.

Prehod v testni način (vh. paket SETBRK):

|        |    |        |                |
|--------|----|--------|----------------|
| MN 10I | ID | I0110I | M(1) Count(15) |
|--------|----|--------|----------------|

Opomba: M=1 prekini izvrševanje po Count ciklih  
M=0 prekini po Count dostopih do LT lokacije, naslovljene z ID

Prehod v prekinitveni način (vh. paket CBRK):

|          |        |
|----------|--------|
| 0000010I | I0100I |
|----------|--------|

Vrsta prekinitvenega načina (vh. paket SETMD):

|        |        |                     |
|--------|--------|---------------------|
| MN 10I | I0101I | par. za prek. način |
|--------|--------|---------------------|

Opomba: Parametri za prekinitveni način določajo stopnjo vhodnih osejitev ter njihovo trajanje.

Sporočilo o napaki (izh. paket ERR):

|          |         |        |                      |
|----------|---------|--------|----------------------|
| 0000010I | 0000000 | I0100I | MN(4)MODE(4)0005T(5) |
|----------|---------|--------|----------------------|

Programski reset (vh. paket CRESET):

|        |        |
|--------|--------|
| MN 10I | I0100I |
|--------|--------|

Opomba: Programski reset povzroči le nadaljevanje izvrševanja v normalnem načinu, za razliko od hardverskega, ki resatira tabele ter dodeli naslove procesorjem.

### 3.2.2. Vpis podgrafa:

Predhodni vpis podgrafa poteka s pomočjo vhodnih paketov SETLT, SETFTR, SETFTL in SETFTT.

Vpis povezave v LT (vh. paket SETLT):

|        |           |        |                 |
|--------|-----------|--------|-----------------|
| MN 10I | adr. v LT | I1100I | podatki za v LT |
|--------|-----------|--------|-----------------|

Vpis točke v FTR (vh. paket SETFTR):

|        |           |        |                  |
|--------|-----------|--------|------------------|
| MN 10I | adr. v FT | I1101I | podatki za v FTR |
|--------|-----------|--------|------------------|

Vpis točke v FTL (vh. paket SETFTL):

|        |           |        |                  |
|--------|-----------|--------|------------------|
| MN 10I | adr. v FT | I1110I | podatki za v FTL |
|--------|-----------|--------|------------------|

Vpis točke v FTT (vh. paket SETFTT):

|        |           |        |                  |
|--------|-----------|--------|------------------|
| MN 10I | adr. v FT | I1111I | podatki za v FTT |
|--------|-----------|--------|------------------|

### 3.2.3. Izpis podgrafa:

Vsebino LT in FT lahko beremo s pomočjo paketov RDLT, RDFTR, RDFTL in RDFTT, ki pomenijo zahtevo po branju. Prebrana vsebina lokacij v LT in FT pa se nahaja v izhodnih paketih LTRDD, FTTRDD, FTLRDD in FTTRDD.

Zahteve za branje iz LT (vh. paket RDLT):

|        |           |        |
|--------|-----------|--------|
| MN 10I | adr. v LT | I1000I |
|--------|-----------|--------|

Prebrani podatki iz LT (izh. paket LTRDD):

|          |           |        |               |
|----------|-----------|--------|---------------|
| 0000010I | adr. v LT | I1000I | podatki iz LT |
|----------|-----------|--------|---------------|

Zahteve za branje iz FTR (vh. paket RDFTR):

|        |           |        |
|--------|-----------|--------|
| MN 10I | adr. v FT | I1001I |
|--------|-----------|--------|

Prebrani podatki iz FTR (izh. paket FTTRDD):

|          |           |        |                |
|----------|-----------|--------|----------------|
| 0000010I | adr. v FT | I1001I | podatki iz FTR |
|----------|-----------|--------|----------------|

Zahteve za branje iz FTL (vh. paket RDFTL):

|        |           |        |
|--------|-----------|--------|
| MN 10I | adr. v FT | I1010I |
|--------|-----------|--------|

Prebrani podatki iz FTL (izh. paket FTLRDD):

|          |           |        |                |
|----------|-----------|--------|----------------|
| 0000010I | adr. v FT | I1010I | podatki iz FTL |
|----------|-----------|--------|----------------|

Zahteve za branje iz FTT (vh. paket RDFTT):

|        |           |        |
|--------|-----------|--------|
| MN 10I | adr. v FT | I1011I |
|--------|-----------|--------|

Prebrani podatki iz FTT (izh. paket FTTRDD):

|          |           |        |                |
|----------|-----------|--------|----------------|
| 0000010I | adr. v FT | I1011I | podatki iz FTT |
|----------|-----------|--------|----------------|

### 3.2.4. Izvrševanje podgrafa:

Ko je podgraf vpisan v procesor, se lahko prične njegovo izvrševanje - pretok podatkov po podgrafi. Procesor dobi vhodne podatke (operand) s pomočjo vhodnih paketov EXEC, rezultate pa vrne s paketi OUTD.

Vhodni podatki (vh. paket EXEC):

|        |    |         |         |
|--------|----|---------|---------|
| MN 10I | ID | I00CSII | operand |
|--------|----|---------|---------|

Izhodni podatki (izh. paket OUTD):

|        |    |         |          |
|--------|----|---------|----------|
| MN 10I | ID | I00CSII | rezultat |
|--------|----|---------|----------|

### 3.2.5. Dumpanje:

V prekinitvenem načinu delovanja je omogočeno tudi opazovanje vsebine delov paketov. V ta namen se uporablja vhodni paket DUMP ter pripadajoči izhodni paket DUMPD.

Zahteve za izpis dane polje (vh. paket DUMP):

|        |      |         |        |
|--------|------|---------|--------|
| MN 10I | x(4) | DUMP(3) | I0111I |
|--------|------|---------|--------|

Izpisana vsebina polja (izh. paket DUMPD):  
**100001010(4)DUMP(3)ID11111** dumpani podatki :  
Opomba: glede na bite DUMP(3) dobimo:  
DUMP(3) dumpani podatki  
000 x(5) G0(5) D0(6)  
001 x(4) u(1) ID(7) CTLF(4)  
010 DATA(16)  
011 x(3) u ID(7) x C S C S  
100 xx FTL(spodnjih 12) xx  
101 DATA (16)  
110 DATA (16)  
111 x(9) ID(7)

SEL polje FT paketa določa tip ukaza. Ukazi so lahko tipa OUT, GE, PU ali AG/FC. Ukazi tipa OUT narekujejo neposreden prenos paketa v Q. Ukazi tipa GE se uporabljajo za generiranje paketov znotraj procesorja. PU ukazi omogočajo aritmetično logične operacije, AG/FC ukazi pa služijo AG&FC enoti pri delu z DM. Pri ukazih tipa PU se uporablja FTL polje, pri ostalih ukazih pa tudi FTR in FTT polje.

### 3.3. Tabela povezav LT

LT je 128 X 16 bitni dinamični RAM. V LT vstopi 28 bitni paket kot ga prikazuje Slika 6.

| 1   | 7   | 4    | 16      |
|-----|-----|------|---------|
| IUI | ID' | CTLF | podatki |

Slika 6: 28 bitni LT paket.

Identifikator LT paketa, ki ga pošlje IC, služi za naslovitev lokacije v LT. Vsebina naslovljene lokacije vsebuje 6 bitni naslov lokacije v tabeli točk (FTA), 7 bitni identifikator (ID'), FTRC bit in 2 bitno seleksijsko polje (SEL). Prikazana je na Sliki 7.

| 6        | 7   | 1   | 2    |
|----------|-----|-----|------|
| 128 X 16 | FTA | ID' | ISEL |

Slika 7: Vsebina lokacije v LT.

ID LT paketa se nadomesti z novim ID', vsebovanim v naslovljeni lokaciji v LT. Torej vsakokrat, ko paket preide čez LT, dobi novi identifikator. LT paketu se dodajo še FTA, FTRC in SEL polje. FTA polje služi za dostop do lokacije v FT. FTRC bit in SEL polje pa služita pri določanju tipa ukaza.

| SEL | Tip ukazov |
|-----|------------|
| 11  | AG/FC      |
| 01  | PU         |
| 10  | GE         |
| 00  | OUT        |

Opomba: Tipi ukazov so opisani v poglavju 3.11.

### 3.4. Tabela točk FT

FT je 64 X 40 bitni dinamični RAM. Vanj vstopajo paketi, ki jih pošlje LT v obliki, kot jo prikazuje Slika 8.

| 1   | 7   | 4    | 2    | 1 | 6   | 16      |
|-----|-----|------|------|---|-----|---------|
| IUI | ID' | CTLF | ISEL | I | FTA | podatki |

Slika 8: 37 bitni FT paket.

FTA polje je naslov lokacije v FT, katere vsebino sestavljajo 14 bitno polje FTL, 16 bitno polje FTR in 10 bitno polje FTT, ki vsebujejo kraljine podatke o različnih tipih ukazov. FT lokacijo prikazuje Slika 9.

| 14      | 16  | 10  |     |
|---------|-----|-----|-----|
| 64 X 40 | FTL | FTR | FTT |

Slika 9: Vsebina lokacije FT.

### 3.5. Generator naslovov in krmilnik pretoka AG&FC

AG&FC generira naslove lokacij v DM ter krmili njihovo branje in vpisovanje. AG&FC ugotavlja, če prispeški paket vsebuje ukaze z enim ali dvema operandoma. Če potrebuje en operand, se paket prenese direktno v Q. Če pa potrebuje ukaz dva operandova, morata biti na voljo obe, da se lahko prenese v Q. Paket, ki vsebuje prevega izmed prispeških operandov, se začasno shranji v DM, dokler ne prispe paket z drugim operandom. Ko paket z drugim operandom izstopi iz FT, AG&FC generira naslov lokacije v DM, v kateri je shranjen paket s prvim operandom in pošlje obe v Q.

### 3.6. Paketni pomnilnik DM

DM je 512 X 18 bitni dinamični RAM, ki služi za hranjenje prvega od prispeških operandov ukaza. Paket, ki je nosilec drugega operanda, vstopi v DM v obliki prikazani na Sliki 10.

| 1   | 7   | 2    | 7   | 5     | 14  | 11    | 16      |
|-----|-----|------|-----|-------|-----|-------|---------|
| IUI | ID' | ISEL | DMA | IPUFI | FTL | ICISI | podatki |

Slika 10: 54 bitni DM paket.

Polje DMA vsebuje naslov lokacije v DM v kateri je shranjen prvi operand. Podatki o ukazu namenjenem PU se nahajajo v FTL. DM se uporablja tudi za začasno hranjenje drugih, npr. vhodno-izhodnih podatkov.

### 3.7. Vrsta Q

Q je 48 X 60 bitni dinamični RAM, ki služi kot FIFO pomnilnik. Paketi, ki vstopajo v Q, nastanejo iz DM paketa tako, da se DMA polje izloči in nadomesti z vsebino lokacije DM na katero je prej kazalo polje DMA (prvi operand). Q zadasno hrani pakete, namenjene v PU ali QG. Q je razdeljen v dva FIFO pomnilnika: 32 X 60 bitno podatkovno vrsto (DQ) in 16 X 60 bitno generatorsko vrsto (GQ). DQ je namenjen ukazom tipa PU, OUT in AG/FC in hrani pakete, ki so namenjeni v PU ali QG. Vrsta DQ pa je namenjena le ukazom tipa GE, ki generirajo nove pakete. Vrsta DQ zadržuje izhodne pakete, da je izhodna vrsta Q polna. Podobno DQ zadržuje pakete, namenjene v PU, če je le-ta zasedena. Nekritočno posiljanje paketov v krožni obtok bi lahko privelo do nasledenja vrste Q, zato je delovanje Q omejeno s slededečo zahtevo: če se v DQ nahaja osem ali več paketov, je branje iz GQ onesmogeno, če pa je v DQ manj kot osem paketov, ima branje iz GQ višjo prioritetno od branja iz DQ. Do nasledenja vrste Q bi lahko prišlo če v primeru, ko bi bila hitrost procesiranja manjša od hitrosti prihajanja novih vhodnih paketov v procesor. Zato v primeru, ko se v DQ nahaja več kot 23 paketov, procesor preide v prekinutveni način delovanja, s čimer se izogne nasledenju Q.

### 3.8. Izhodna vrsta Q

DQ je  $8 \times 32$  bitni stacionarni RAM, organiziran kot FIFO pomnilnik. Služi zadansnemu shranjevanju izhodnih paketov, prispevih iz DQ, ki se nato preko OC posljejo na izhodno podatkovno vodilo. Če je DQ poln, pošlje ustrezen signal v DG, ter preneha sprejemati pakete. DQ paket se ujema s Q paketom.

### 3.9. Procesna enota PU

PU izvršuje ukaze tipa PU in GE. Koda PU ukaza se nahaja v polju FTL PU paketa. Ukazi tipa GE se uporabljajo za generiranje novih paketov, kopiranje posameznih ali skupin paketov in spremenjanja vsebine CTLF polja. Če potrebuje PU za izvršitev ukaza ved kot en cikel, pošlje signal vrsti Q in IC, ki zadrži njuno delovanje. PU paket je po obliki enak Q paketu.

### 3.10. Osveževalni krmilnik RC

RC avtomatično generira pakete za osveževanje vseh dinamičnih RAMov v procesorju. Paket, ki ga generira RC, vstopi v IC, ter nato po vrsti GE v LT, FT, DM in Q in vsakokrat povzroči osvežitev ustreznega RAMa. Po prihodu v Q se osvežitveni paket uniči.

### 3.11. Nabor ukazov

Kot smo omenili v poglavju 3.4. obstajajo štirje tipi ukazov: AG/FC, PU, GE in OUT.

#### 3.11.1. Ukazi tipa AG/FC:

Tip AG/FC vsebuje 16 ukazov, ki jih razdelimo v tri skupine: AG, FC in AG/FC tip. Ukazi tipa AG so: RDCYCS, RDCYCL, WRCYCS, WRCYCL, RDWR in RDIDX. Ukazi tipa FC so: PICKUP, COUNT, CUT, DIVCYC, DIV, DIST, CONVO, SAVE in CNTGE. Ukaz QUEUE pa je tipa AG/FC.

Ukazi tipa AG/FC so opisani v FTR polju tabele FT, kjer zgornji štirje biti predstavljajo operacijsko kodo. Ostali del polja FTR in polje FTT pa vsebujejo ostale parametre AG/FC ukazov. Pomeni ukazov tipa AG/FC so:

- QUEUE: shrani prvi prispevki operand dvo mestnega ukaza v DM.
- RDCYCS: ciklično branje podatkov iz izbranega področja v DM, kjer je največja dolžina področja 16 lokacij.
- RDCYCL: enako kot RDCYCS, le da je največja dolžina področja 256 lokacij.
- WRCYCS: ciklično vpisovanje podatkov v izbrano področje v DM, kjer je največja dolžina področja 16 lokacij.
- WRCYCL: enako kot WRCYCS, le da je največja dolžina področja 256 lokacij.
- RDWR: branje ali vpisovanje v DM. Z bitom FTRC izbiramo bodisi branje ali vpis.
- RDIDX: branje iz DM.
- PICKUP: izloči vsak n-ti paket in mu pripredi ID + 1.
- COUNT: podvoji vsak n-ti paket in mu pripredi ID + 1.
- DIVCYC: na vsakih n paketov izloči prvi in med njimi in jim pripredi ID + 1.

- DIV: po vsakem prihodu paketa s FTRC = 1 se naslednjim n paketom ID ne spremeni, ostali pa se pripredi ID + 1 (paket s FTRC = 1 se uniči).
- DIST: zaporedje vhodnih paketov vsebuje pakete s FTRC = 0 ali 1. Po prihodu j-tega paketa s FTRC = 1 se vse nadaljnje pakete, ki imajo FTRC = 0 in naslednjemu paketu s FTRC = 1, pripredi ID + (j MOD k).
- SAVE: uporablja se pri nastavljanju ID polja.
- CUT: po vsakem prihodu paketa s FTRC = 1 se se ta paket skupaj z naslednjimi n paketi uniči, ostali pa ostanejo nespremenjeni.
- CONVO: uporablja se za kumulativno računanje, npr. vsot in produktov.
- CNTGE: uporablja se pri generiranju več kot 16 kopij danega paketa (skupaj z ukazom COPYBK tipa GE, ki je opisan spodaj). Konstante k, m in n so podane v FTT polju.

#### 3.11.2. Ukazi tipa PU:

Ukazi tipa PU so shranjeni v FTL polju tabele FT. Uporabnih je le 12 spodnjih bitov, med katerimi so biti 0 do 4 operacijska koda ukaza, preostali biti pa se uporabljajo za dodatno informacijo o številu operandov (eden ali dva), legi operandov pri nekomutativnih operacijah, številu rezultatov (eden ali dva) ter tipu primerjave, podanju z biti PNZ (EQ, LT, LE, GT, GE in NE). Ukazi tipa PU so:

- Logični: OR, AND, EXOR, ANDNOT in NOT.
- Aritmetični: ADD, SUB, MUL, INC, DEC, NOP in ADDSC, SUBSC, MULSC ter NOPSC. Ukazi \*SC najprej izračunajo operacijo \* in vrnejo lego skrajnega levega setiranega bita.
- Premikalni: SHL in SHR ter SHLBRY in SHRBRY, kjer ukaza #BRV predhodno obrneta vrstni red bitov.
- Primerjalni: CMPNOM, CMP in CMPXCH. Vhodna operanda A in B se primerjata na način podan s PNZ poljem. Rezultata primerjave sta X in Y, kot sledi

| C <sub>x</sub> S <sub>x</sub> | X                | C <sub>y</sub> S <sub>y</sub> | Y                |       |
|-------------------------------|------------------|-------------------------------|------------------|-------|
| pri PNZ=FALSE                 | 0 0              | 0000H                         | 0 0              | 0000H |
| pri PNZ=TRUE                  | 1 0              | 0001H                         | 1 0              | 0000H |
| CMP pri PNZ=FALSE             | 0 S <sub>x</sub> | A                             | 0 S <sub>y</sub> | B     |
| pri PNZ=TRUE                  | 1 S <sub>x</sub> | A                             | 1 S <sub>y</sub> | B     |
| CMPXCH pri PNZ=TRUE           | C S <sub>x</sub> | A                             | C S <sub>y</sub> | B     |
| pri PNZ=FALSE                 | C S <sub>x</sub> | A                             | C S <sub>y</sub> | A     |

- Operacije nad biti: GET1, SET1 in CLR1.
- Testiranje bitov: ANDMSK in ORMSK.
- Pretvorba podatkov: CVT2AB in CVTAB2. CVT2AB pretvori 16 bitni operand, zapisan v sistem z dvojškim komplementom, v 17 bitno besedo v sistemu predznak-absolutna vrednost. Predznak se nahaja v bitu S. Drugi ukaz je inverzen prvemu. Ob prakoritevbi se postavi bit C.
- Popravki pri dvojni natančnosti: ADJL. Če imata besedi, s katerima je zapisan večnatančnosti operand, različna predznaka, ju ADJL popravi.
- Kumulativno seštevanje: ACC. Ukaz povzroči seštevanje podatkovnih polj v zaporedju paketov. Vsebina vsakega prispevka paketa se pristeže k delni vsoti v registru ACC. Paketi v zaporedju so bodisi tipa 1 ali 2. Paket tipa 1 se po pristejanju svoje vsebine zbrise, paket tipa 2 pa po pristejanju svoje vsebine prevzame vsebino registra ACC.
- Kopiranje kontrolnega bita: COPYC.

#### 3.11.3. Ukazi tipa GE:

Ukazi tipa GE so opisani v polju FTL tabele FT. Operacijsko kodo sestavljata dva bita, preostali biti pa določajo, če je treba operanda pred vstopom v Q zamenjati, število operandov ter število kopij pri generiranju paketov. V to skupino sodijo trije ukazi:

- COPYBK: generiranje bloka kopij danega paketa. Vsi novi paketi imajo enak ID kot originalni paket, le zadnji ima ID + 1. Vrednosti v podatkovnih poljih se lahko povečujejo ali zmanjšujejo za konstantno vrednost.
- COPYM: generiranje skupine kopij danega paketa z različnimi ID. Podatkovno polje se lahko spreminja podobno kot pri ukazu COPYBK.
- SETCLT: branje ali spremicanje vsebine tabel LT in FT. Ukaz SETCLT omogoča programe, ki se sami spreminjajo, saj se uporablja v času izvajanja grafa.

#### 3.11.4. Ukazi tipa OUT:

Ukazi tipa OUT so opisani v FTL polju tabele FT. Polje vsebuje podatke o tem, da nastopa OUT ukaz samostojno ali skupaj z nekim AG/FC ukazom, te je treba operanda pred vstopom v OG izmenjati, operacijsko kodo OUT ukaza ter naslov procesorja MN, kateremu je namenjen izhodni paket. Lobimo dva ukaza tipa OUT:

- OUT1: povrži prenos 32 bitnega paketa na izhodno vodilo. Paket vsebuje podatek, njegov identifikator, ter naslov procesorja, kateremu je namenjen.
- OUT2: povrži prenos 64 bitnega paketa na izhodno vodilo. Ukaz se uporablja pri poglijanju števil z dvojno natančnostjo.

#### 3.12. Nadini povezovanja μPD7281

Procesorji μPD7281 se povezujejo v večprocesorski sistem na dva osnovna nadina: kaskadni in krožni. Pri kaskadnem povezovanju ni potrebna dodatna materialna oprema. Največ 14 čipov povezujemo neposredno, kot prikazuje Slika 11. Izmenjava vhodno-izhodnih paketov poteka s pomočjo signalov zahteva/potrditev (REQ/ACK).



Slika 11: Povezovanje procesorjev μPD7281.

Za krožno arhitekturo je potrebna dodatna materialna oprema, zato je v razvoju podprtvi tip MAGIC (Memory Access and General bus Interface Chip).

#### 3.13. Programiranje μPD7281

Bogat nabor ukazov omogoča zelo učinkovito programiranje problemov s področja obdelave signalov ter zahtevnega numeričnega računanja. Za ilustracijo si oglejmo realizacijo linearnega digitalnega filtra (5), podanega z enačbo

$$y(k) = \sum_{i=1}^N a(i)y(k-i) + \sum_{i=1}^M b(i)u(k-i),$$

kjer je  $u(k)$  vhodni in  $y(k)$  izhodni signal. Pripadajoči program (graf), zapisan v 'strojnem' jeziku, prikazuje Slika 12.



Slika 12: Rekurenčni izračun digitalnega filtra.

Seveda je razvit tudi zbirni jezik, ki omogoča lažji opis programskega podgrafa [23]. Tudi uporabo zbirnika ilustrirajo na primeru linearnega digitalnega filtra, tokrat realiziranega v prostoru stanj, kot ga podajata enačbi

$$\begin{aligned} x(k+1) &= Ax(k) + bu(k) \\ y(k) &= cx(k) + du(k), \end{aligned}$$

kjer so  $A$ ,  $b$ ,  $c$  in  $d$  usredzne matrike in vektorji. Program bi se v primeru, ko so matrike in vektorji enodimenzionalni, glasil:

```
EQUATE HOST = 0;
MODULE PROC1 = 1;
INPUT P1,P2,P3,P4,P5,P6;
OUTPUT P13,P14;
LINK P7 = T1 (P1, P2);
LINK P8 = T2 (P3, P4);
LINK P9 = T3 (P2, P5);
LINK P10 = T4 (P4, P6);
LINK P11 = T5 (P7, P8);
LINK P12 = T6 (P9, P10);
LINK P13 = T7 (P11, );
LINK P14 = T8 (P12, );
FUNCTION T1 = MUL,QUEUE(Q1,1);
FUNCTION T2 = MUL,QUEUE(Q2,1);
FUNCTION T3 = MUL,QUEUE(Q3,1);
FUNCTION T4 = MUL,QUEUE(Q4,1);
FUNCTION T5 = ADD,QUEUE(Q5,1);
FUNCTION T6 = ADD,QUEUE(Q6,1);
FUNCTION T7 = OUT1(HOST,0);
FUNCTION T8 = OUT1(HOST,0);
MEMORY Q1 = AREA(1);
MEMORY Q2 = AREA(1);
MEMORY Q3 = AREA(1);
MEMORY Q4 = AREA(1);
MEMORY Q5 = AREA(1);
MEMORY Q6 = AREA(1);
```

Zgornji program se izvaja samo v procesorju PROC1, dejprav je v algoritmu prisotna določena stopnja vzporednosti. Težava je v tem, da je potencialna vzporednost slabo razvidna, saj je to le enodimenzionalni zapis programskega (pod)grafa. Zato običajno poteka programiranje tako, da najprej konstruiramo programski graf, določimo vzporedno izvršljive podgrafe ter jih zapisemo v zbirniku. Zgornji program izhaja iz grafa, ki je podan na Sliki 13. Opazimo, da se lahko levni (izračun  $x(k+1)$ ) in desni (izračun  $y(k)$ ) del grafa izvršujejo vzporedno, zato levni del pripeljemo procesorju PROC1, desni del pa procesorju PROC2. Ustrezna programa, ki sta v tem primeru zelo podobna, sta podana na Sliki 13. Razlika med njima je le v tem, da PROC1 pošilja rezultat procesorju PROC2, medtem ko procesor PROC2 pošilja rezultat glavnemu procesorju HOST.

```

EQUATE PROC2 = 2;
MODULE PROC1 = 1;
INPUT P1,P2,P3,P4;
OUTPUT P13;
LINK P7 = T1 (P1, P2);
LINK P8 = T2 (P3, P4);
LINK P11 = T5 (P7, P8);
LINK P13 = T7 (P11, );
FUNCTION T1 = MUL,QUEUE(Q1,1);
FUNCTION T2 = MUL,QUEUE(Q2,1);
FUNCTION T5 = ADD,QUEUE(Q5,1);
FUNCTION T7 = OUT1(PROC2,D);
MEMORY Q1 = AREA(1);
MEMORY Q2 = AREA(1);
MEMORY Q5 = AREA(1);

```



```

EQUATE HOST = 0;
MODULE PROC2 = 2;
INPUT P2,P4,P5,P6;
OUTPUT P14;
LINK P9 = T3 (P2, P5);
LINK P10 = T4 (P4, P6);
LINK P12 = T6 (P9, P10);
LINK P14 = T8 (P12, );
FUNCTION T3 = MUL,QUEUE(Q3,1);
FUNCTION T4 = MUL,QUEUE(Q4,1);
FUNCTION T6 = ADD,QUEUE(Q6,1);
FUNCTION T8 = OUT1(HOST,D);
MEMORY Q3 = AREA(1);
MEMORY Q4 = AREA(1);
MEMORY Q6 = AREA(1);

```

Slika 13: Realizacija digitalnega filtra v prostoru stanj.

Pri večini programskih grafov je določanje vzporedno izvršljivih podgrahov zahtevno, kar narekuje razvoj metod za avtomatično iskanje vzporednosti ter optimizacijo glede na število uporabljenih procesorjev [4]. Zelo dobrodošel bi bil grafični zbirnik za generiranje kode neposredno iz programskega grafa ter pascalski ali C prevajalnik za generiranje in optimizacijo programskih grafov.

je v vseh procesorjih cel programski graf, vanj pa vstopajo le podatki o pripadajoči podslike. Razbitje glede na graf (program) pa pomeni, da prvi procesor opravi premik slike, drugi noremiranje, tretji rotacijo itd. To pomeni, da je v vsakem procesorju drug podgraf in vanj vstopajo podatki o celi sliki. Seveda pa je razbitje grafa smiselnlo le tedaj, ko se lahko podgrafi izvršujejo vzporedno.

#### 4. ZAKLJUČEK

Rezultati testov opravičujejo uporabo večprocesorske arhitekture z μPD7281 [1]. Tako npr. rotacija binarne slike velikosti 512 X 512 točk zahteva 0.6s pri krožni povezavi treh procesorjev; en procesor pa potrebuje 1.5s. Za izračun funkcije  $\cos(x)$  potrebuje en procesor 40μs, kaskada treh procesorjev pa 15μs. V splošnem se čas obdelave eksponentno zmanjšuje z večanjem števila uporabljenih procesorjev, kar pa ne neomejeno, saj se pri večjem številu procesorjev pojavijo zastoji pri pretoku vhodnih izhodnih paketov med procesorji. Zato je odvisno od same aplikacije, ali jo bomo razbili glede na podatke ali na programski graf. Vzemo npr. obdelavo slike, ki obsega naloge kot so premik, noremiranje, rotacija itd. Če se odločimo za razbitje glede na podatke, razbijemo sliko na podslike, tako da se vsaka podslika istočasno obdelava v svojem procesorju. To pomeni, da

#### 5. LITERATURA

- [1] Chong Y.M.: Data Flow Chip Optimizes Image Processing, Computer Design, Oct. 15, 1984, pp.97-103
- [2] Jeffery T.: The μPD7281 Processor, Byte, November 1985, pp.237-246
- [3] μPD7281 Image Pipelined Processor, NEC Electronics, February 1985
- [4] Robić B., J.Silc: On Choosing a Plan for the Execution of Data Flow Program Graph, Informatica 3/86
- [5] Ohba N., T.Saito, Y.Hoshiko: Signal Processing on a Data-Flow Processor, Microprocessing and Microprogramming 14, 1984, pp.17-27

UDK: 681.3-181.4

Branko Mihailovič, Slavko Mavrič, Peter Kolbezen  
Institut »Jožef Stefan«, Ljubljana

Transputer je osnovni VLSI materialni gradnik večprocesorskih sistemov, ki za povezovanje z ostalimi transputerji v sistemu koristi "point-to-point" komunikacijske povezave. Jezik OCCAM je osnovni programski gradnik vedtransputerskega sistema (VTS). S tem jezikom opisemo VTS kot zbir procesov, ki se izvajajo sočasno in med seboj komunicirajo na nivoju sporočil preko definiranih komunikacijskih kanalov.

TRANSPUTER - THE BASIC COMPONENT OF MULTIPROCESSOR SYSTEMS - The Transputer is a basic VLSI hardware component of multiprocessor systems with communication links for point-to-point connection to other transputers. Occam is a language that enable a multiprocessor system to be described as a collection of processes that operate concurrently and communicate using messages passing via named channels.

## 1. Uvod

Danes je popolnoma jasno, da tudi ekonomskih preprek ni več, ki bi zavirale gradnjo "močnih" računalniških sistemov; in sicer takšnih, ki v sebi združujejo naprimer 1000 sočasno delujočih procesorjev. Takšen računalnik je preprosto "prilagojen" aplikaciji v smislu popolne izkorisťenosti inherentnih sočasnosti. Takšno gledanje je vodilo tudi strokovnjake firme INMOS pri načrtovanju transputerja. Čemu so transputerji in tudi njim podobne komponente namenjene?

- Namenjene so načrtovanju standardnih računalniških produktov v smislu lažjega programiranja in uporabe let-teh,
- pridobivanju kar največje učinkovitosti s temi komponentami zgrajenih sistemov,
- koriščenju novih razvojnih smeri v VLSI tehnologiji in sicer znotraj kompatibilnih družin,
- načrtovanju takšnih programabilnih komponent s pomočjo katerih bi gradili sisteme z velikim številom sočasno delujočih računalniških sistemov.

Transputer, ki je zaščiteno ime za mikrorazunalnik (mikroprocesor), je po velikosti in funkcijah primerljiv z mikroprocesorji kot sta NS 16032 ali I 80286, vendar je pri njem uporabljena povsem drugačna teoretska osnova pri načrtovanju velikih računalniških sistemov.

Transputer je zgrajen tako, da je lahko povezan z ostalimi transputerji v takojmenovani mreži paralelnih procesov. Vsak od transputerjev izvaja točno določeno opravilo (proses) z

minimalno izgubo procesnega časa in minimalnim balastom, ki se lahko pojavi v fizični povezavi med transputerji. Pri računalnikih, ki potrebujejo velike podatkovne baze, ki so programirani v naravnih jezikih in omogočajo tudi druge "inteligentne" aktivnosti, predstavlja sočasno procesiranje eno od bistvenih lastnosti takšnih računalnikov. Če želimo to dosegiti z medsebojnim povezovanjem konvencionalnih procesorjev, naletimo na praktično nerešljive probleme varnega dodeljevanja virov, synchronizacije pri takojmenovanih paralelnih vodilih in podobno. V transputerski arhitekturi koristimo visoko stopnjo sočasnega izvajanja procesov. Ta je zagotovljena preko takojmenovanega decentraliziranega računalniškega modela. Lokalni procesi se izvajajo nad lokalnimi podatki, med seboj pa takšni procesi komunicirajo preko hitrih komunikacijskih kanalov z izmenjavo sporočil. Tako izbran način lokalnega procesiranja in komuniciranja narekuje temeljite spremembe v konceptu programiranja in načrtovanju novih algoritmov.

Sobščeno z razvojem transputerja, je potekal razvoj na majhnem (22 rezerviranih besed), izbranem jeziku, imenovanem OCCAM. Namenjen je programiranju transputerjev, odnosno je njihov zbirni jezik. Osnovna lastnost (in prednost) tega jezika je ta, da je ustvarjen za programiranje sočasnih aktivnosti v vedtransputerskem sistemu; to je za udinkovito implementacijo transputerskega sistema.

## 2. Zgradba sistema

Na tem mestu je potrebno povdariti naslednje: Zgradba tako samega transputerja kot

transputerskega sistema je definirana z OCCAM-om. S tem, da smo arhitekturo definirali na tem nivoju pomeni, da lahko na eni strani transputerski sistem zgradimo z različnimi, danes že standardnimi komponentami, na drugi strani pa lahko tak sistem optimiziramo za različne aplikacije.

Glavna sestavna dela transputerja sta 32 bitni RISC (reduced instruction set computer) in zelo hiter RAM pomnilnik (4K besed). Čip je narejen v 2. mikronski CMOS tehnologiji. 5MHz. ura mu omogoča, da izvrši 10 milijonov instrukcij na sekundo, kar zdaleč presega zmognost današnjih mikroradijalnikov. Blok shemo transputerja prikazuje slika 1.

Transputerji standardne Von-Neumannove strukture se povezujejo med seboj s pomočjo štirih komunikacijskih povezav in tako tvorijo sistem, katerega lahko pogledamo z dveh strani. Prvi, logični pogled nam pove, kako je sistem med seboj povezanih transputerjev načrtovan in programiran. Drugi pogled, imenovan fizični, nam pove, kako so VLSI komponente med seboj povezane in kmiljene.



## 2.1. Logična zgradba transputerskega sistema

Pri podrobnejšem opisu logične zasnove sistema, je potrebno opozoriti na osnovno nadele tega vidika in to je, da lahko transputer in transputerski sistem programiramo (poleg OCCAM-a) tudi v drugih visokih programskej jezikih, transputer pa bo prevedene programe zagotovo učinkovito izvajal. Program, ki ga transputer izvaja je formalno ekvivalenten procesu v OCCAM-u. Proses je tako materialni in programski gradnik vstop-izstoparskega sistema. Mrežo transputerjev direktno popisujemo z OCCAM-skim programom. Načrtovanje VTS pomeni v bistvu povezovanje množice procesov med seboj. Notranja zgradba procesne enote (transputerja) je na tem nivoju prikrita in povsem nepomembna. Proses, ki ga takšna enota izvaja, je popolnoma določen s pomočjo podatkov, ki jih procesna enota sprejema odnosno oddaja.

Jezik OCCAM se popolnoma podreja temu konceptu. Tisto kar je v OCCAM-u definirano kot proces, je dejansko realizirano kot transputer. Pravimo, da se v transputerju izvaja množica takojmenovanih komunikacijskih procesov, ki v svoji notranji zgradbi koristijo "point-to-point" komunikacijske

povezave. Slednje so izvedene tako, da omogočajo preprosto povezovanje med transputerji in s tem enostavno gradnjo VTS. Našteto nekaj prednosti, ki jih imajo PTP kot povezave v primerjavi z vodili v VPS:

- Ni nikakršnih spornosti v komunikacijah med elementi VPS, ne glede na število transputerjev v sistemu.
- Ni nikakršnega povečanja obremenitve komunikacijskih poti pri povezaniem številu transputerjev v sistemu.
- Zaradi povezovanja sistema ne more priti do zasišenja v takoimenovanem komunikacijskem območju. Vse povezave med transputerji so kratke in imajo lokalni značaj.

Komunikacijske poti so grajene tako, da omogočajo preprosto programiranje večtransputerskega sistema. Gre za enostavno obravnavanje sodobnosti v komunikacijah. Synchronizacija med procesi na vseh štirih komunikacijskih poteh je avtoatska in ne zahteva nikakršnega dodatnega programiranja. Podatki se med transputerji prenašajo serijsko. Na pravilno sprejete podatke transputer odgovori s potrditvijo.

## 2.2. OCCAM model

V OCCAM-u se procesi povezujejo tako, da tvorijo sistem sočasnih kontinuiranih procesov. Vsak proces ima začetek, akcijski del in konec. Akcijski del lahko ponovno sestavljajo bodisi sekvenčni proces ali parallelni proces. V vsakem OCCAM-skem programu lodičemo tri osnovne procese: vhodni, prireditveni ter izhodni proces. Prireditveni proces postavi določene vrednosti spremenljivk in izračuna vrednost nekega izraza. Vhodni in izhodni proces skrbita za prenos vrednosti med occamskimi spremenljivkami po takoimenovanih occamskih kanalih. Zapis

c ! x

pomeni prenos vrednosti spremenljivke x v kanal z imenom c; odnosno

c ? y

pomeni zapis vrednosti iz kanala c v spremenljivko y. Seveda so kanali, tako kot spremenljivke deklarirani na začetku procesa, ki določene kanale uporablja. Prireditveni proces ima naslednjo obliko:

v := e

kar pomeni, da spremenljivka v prejme vrednost izraza e.

Poleg opisanih treh osnovnih procesov, predstavljajo konstrukti najpomembnejši del jezika OCCAM. Lodičemo štiri osnovne konstrukte in sicer: sekvenčni, parallelni, pogojni in izbirni. Osnovna lastnost konstruktorjev je ta, da se zadržajo s karakteristično označbo česar sledi lista osnovnih procesov. Sekvenčni konstrukt je ponazorjen na sliki 2a.

| SEQUENTIAL | PARALLEL | IF     | ALTERNATIVE |
|------------|----------|--------|-------------|
| P1         | P1       | pogoj1 | Vhod1       |
| P2         | P2       | P1     | P1          |
| P3         | P3       | pogoj2 | Vhod2       |
|            |          | P2     | P2          |
|            |          |        |             |
|            |          |        |             |

a) b) c) d)

SLIKE 2

Izvrševanje vsakega naslednjega procesa se začne takrat, ko je predhodni končan. V primeru paralelnega konstruktta (slika 2b) se vsi procesi izvajajo sčasno, konstrukt pa se zaključi takrat, ko so končani vsi procesi. Veljavnost pogoja 1 je pogoj za izvrševanje procesa P1 (slika 2c). V primeru na sliki 2d pa bo proces P1 začel z izvrševanjem takrat, ko se bo izvršil vhodni proces 1.

Tako kot v sekvenčnih jezikih, poznamo tudi tu tipe, deklariranje, polja, posebnost pa predstavlja takoimenovano oblikovanje occamskega programa. V occamu zapisan program se lahko izvaja na enem ali več transputerjih, zato mora biti ustrezno temu pravilno oblikovan. Razvojni sistem namreč omogoča, da se program, ki se bo izvajal na vseh transputerjih, tudi pravilno "porazdeli" med njih. Oblikovanje programa (configuration of occam program) ne upliva na logično zasnovo programa. Z konstruktom PLACED PAR se namreč zagotovi, da se bo vsak proces, podan v paralelnem konstruktu, lahko izvajal na svojem transputerju.



Slika 3

### 2.3. Transputer T424

Procesor z naborom instrukcij je zasnovan tako, da omogoča:

- učinkovito uporabo jezika OCCAM, posebno pri izvajaju večjega števila procesov,
- enostavno prevajanje programa, pri vsem tem pa ni potrebno definirati arhitekture na nižjem nivoju,
- izvajanje programov na procesorjih z različnimi dolžinami besed, in sicer brez predhodnega dodatnega prevajanja,
- lociranje programa in delovnega pomnilniškega prostora kjerkoli v pomnilniku transputerja,

Na učinkovitost celotnega transputerskega sistema pa vplivata v glavnem dva činitelji: število besed v celotnem programu in hitro izvajanje le-tega. Posebna skrb je posvečena ravno drugemu činitelju, saj se tako pomnilniške kot aritmetično-logične operacije izvršijo v enem ali kvajem v dveh ciklih.

Procesor koristi za naslavljjanje pomnilniških lokacij linearни adresni prostor, pri tem pa ne razlikuje med notranjim delovnim pomnilnikom in dodanim zunanjim pomnilnikom. Osnovni element linearnega adresnega prostora je kazalec, ki je sestavljen iz dveh delov:

naslova pomnilniške besede ter kazalca zloga znotraj pomnilniške besede. Posebni instrukciji (load local pointer, word subscript) podrobnejše opisujeta strukturo pomnilniške besede.

Procesor je organiziran tako, da koristi pri izvajajanju sekvenčnih procesov šest registrov. S pomočjo treh registrov lahko oblikuje sklad, shranjuje operande, odnosno parametre klicanih podprogramov. Eden od registrov je namenjen shranjevanju kazalca na vsebino delovnega pomnilnika, drugi pa hrani kazalec naslednje instrukcije, ki se bo izvršil.

Izhodišče za procesorsko multipleksiranje, odnosno dodeljevanje procesorskega časa je podano v multiprogramskem jedru. Aktiven proces čaka na izvršitev potem, ko je uvrščen na listo aktivnih procesov (slika 3). Dodeljevanje procesorskega časa med procese je v multiprogramskem jedru definirana z določeno prioriteto (fixed priority). Z occamskim konstruktom PRI PAR, česar sledi lista procesov, določimo prioriteto procesom, da se leti izvajajo na enem transputerju. Procesor pozná dva prioritetsna nivoja. Prosesi z nižjo prioriteto se izvajajo samo če ni procesov z višjo prioriteto; njihovi krajsi deli (opravila) pa se izvršujejo v periodično dodeljevanih časovnih rezinah. Proses z višjo prioriteto lahko prekine proces z nižjo prioriteto, vendar največ za dolžino ene rezine.



SLIKA 4



SLIKA 5

Vse instrukcije imajo enak format (osem bitne dolžine). Zgornji štirje biti so funkcijski kod, spodnji štirje pa podatkovna vrednost. Takšen instrukcijski format omogoča, da ima procesor preprost in hiter dekodni mehanizem. Tudi dostavni mehanizem je preprost in hiter. Če je procesor 32 bitni pomeni, da v vsakem dostavnem ciklu sprejme 4 instrukcije.

Pri nadrtovanju transputerskega sistema se postavlja verjetno najpomembnejše vprašanje, kako je z komunikacijami med procesi. Rekli smo že, da se lahko več procesov izvaja sčasno na enem transputerju ali pa na mreži transputerjev (slika 4). V obeh primerih so v OCCAM-u za komunikacijo med procesi definirani takoimenovani komunikacijski kanali. V prvem primeru poteka komunikacija med procesoma preko ene pomnilniške besede; komunikacija med transputerji pa poteka preko takoim. point-to-point povezav. Tako kot v occamskem modelu, se komunikacija lahko začne, ko sta

vhodni in izhodni proces za to pripravljena, kar pomeni, da transputer za sinhronizacijo ne koristi vmesnega pomnilnika. Podatki se med transputerji prenabavo serijsko. Transputer, ki je drugemu posredoval podatke podatka, da mu slednji sprejem tudi potrdi (slika 5).

#### 4. Zaključek

Zaključimo prispevek z naslednjim: Sam transputer ima v bistvu v standardno arhitekturo okvirjen sorazmerno velik delovni pomnilnik in po številu instrukcij skromen a hiter procesor. Komunikacije znatno prenabavo (klijub vodilu) so zelo hitre. Enako hitre so tudi komunikacije med transputerji. Skratka, transputer odstopa od danes že zastarelega koncepta enoprocесorskih računalnikov, katerih osnova je izredno zahtevna programska oprema in pri katerih je že vprašljiva učinkovitost celotnega sistema. Danes poznamo že takojšnje interpretacijske sheme za visoke programske jezike, ki omogočajo uporabo preprostih, a zelo učinkovitih

instrukcij in prevajanje na nivoju, ki je višji od nivoja mikrokoda. To pomeni boljše razmerje materialna/programska oprema in tem poenostavljena sistemsko programska oprema velikih večprocesorskih sistemov.

#### 5. Literatura

- [1] INMOS Limited, OCCAM language overview, November 1985.
- [2] INMOS Limited, Transputer architecture, November 1985.
- [3] INMOS Limited, IMS T414 Transputer, November 1985.
- [4] Dick Pountain, The Transputer and its special language, OCCAM, BYTE, August 1984
- [5] Brian Meal, Multiprocessor solution in OCCAM to an NP-complete problem, Microprocessors and Microsystems, Vol. 9, No.4, Maj 1985.

UDK: 681.327.8.01

Iztok Tvrdy  
Institut Jožef Stefan, Jamova 39, Ljubljana

V članku podajam najprej opis splošnih ciljev razvoja teleinformatike. Pojasnjujem prihajajoči ISDN ter funkcije in telematske storitve v njegovem okviru. Posebno pozornost posvečam integraciji govora in podatkov v distribuiranih komutacijskih sistemih, saj predstavlja zahtevo po integraciji tisti problem, ki je najbolj vzpodbudil razrast teleinformatike. Omenjam tudi odnos med tehnologijo in zmožnostmi PBX in LAN, ki je zanimiv za nadaljnji razvoj; pri tem navajam tudi generacijsko klasifikacijo PBX. Na koncu podajam še pregled CCITT priporočil, s poudarkom na serijah V, X, I in T. Na kratko se dotikam tudi lokalnih računalniških mrež in njihove standardizacije.

**NEW TELEMATIC SERVICES ENVIRONMENT AND ISDN:** General goals of developing the teleinformatics are described in the paper. ISDN, its functions and telematic services are clarified. Problems of Voice/Data integration in distributed switching systems are carefully inspected. For the future development, interesting relations among technology and abilities of PBXs and LANs are briefly discussed. Generations of PBXs are classified. Overview of CCITT recommendations (with emphasis of the series V, X, I and T), LANs and their standardization are given at the end of the paper.

## 1. Uvod

Cilji oziroma vizije razvoja teleinformatike kot presečnega področja telekomunikacij in računalništva pokrivajo vse do trenutnih razvojnih nalog pa vse do smernic evolucije teleinformatike in s tem tudi informacijske družbe. Poglavitni del premišljevanja o bodočih telekomunikacijskih omrežjih tvori prihajajoči ISDN (Integrated Services Digital Network, po načelu Digitalno omrežje z integriranimi storitvami).

ISDN je digitalno omrežje, prizerno za prenos informacij med dvema ali več točkami v enakem formatu, na glede na izvorno naravo podatkov (govor, podatki, besedilo ali slike).

ISDN naj bi nastal kot nadgradnja z združitvijo zmožnosti vseh dosedanjih specializiranih omrežij (telefonskega in telegrafskega omrežja, javnega omrežja za prenos podatkov, različnih privatnih omrežij) ter s hkratno implementacijo novih, doslej še ne načrtovanih zmožnosti.

Tako omrežje bo omogočalo številne funkcije. Nekaterim od njih pravimo (zaradi kompleksnosti problematike, ki jo pokrivajo) s posebno besedo telematske storitve. Uporabniško orientirane funkcije v okviru ISDN pa imenujemo tudi telestoritve.

Pri specifikaciji telematskih storitev (in telestoritev) se naslanjamamo na referenčni model odprtih sistemov povezovanja (ISO OSI RM), ki nam nudi strukturiran pogled na način komunikacije med dvema ali več uporabniki. Za izvedbo storitev potrebujemo linijo brez napak med končnima uporabnikoma (oziroma procesoma), torej govorimo tedaj le o višjih nivojih referenčnega modela OSI.

Omenimo še dolgoročnejšo perspektivo: širokopasovni ISDN, preko katerega bomo lahko prenasečali tudi običajne televizijske kanale in HI-FI radio signale. Tako naj bi bil širokopasovni ISDN tudi nadgradnja kabelske televizijske oziroma sedanjega "broadcastinga".

## 2. Odnos PBX / LAN

Zaradi potrebnih velikih vlaganj v izvedbo javnega ISDN in v zvezi s tem zaradi njegove počasne in postopne izgradnje se bo področje ISDN najprej in najintenzivnejše razvijalo na tako imenovanem zasebnem področju. Zato je za nadaljnji razvoj zlasti zanimiv odnos med tehnologijo in zmožnostmi PBX (naročniške telefonske centrale - NTC) in LAN (lokalne računalniške mreže). Se na dolgo tega ni bilo jasno, katera rešitev je superiorna na področju komunikacij bodočnosti: lokalna računalniška mreža ali naročniška telefonska centrale.

Lokalne računalniške mreže lahko omogočajo zelo hiter prenos podatkov, vendar je zmogljivost mreže, glezano s strani enega uporabnika, obratno sorazmerna s številom hkratnih uporabnikov mreže. Zato je LAN primeren za prenos in komutacijo podatkov, toda zelo težko izvaja (obsežen) prenos govora. Na drugi strani pa na zmogljivost kanala, ki ga vzpostavi uporabnik skozi PBX, število drugih hkratnih uporabnikov ne vpliva. Zato je PBX zelo primeren za govor, manj pa za obsežen prenos podatkov, saj tak prenos zaradi relativne počasnosti zelo dolgo traja. Analogni PBX starejše tehnologije imajo tudi zelo slabe prenosne karakteristike, tako da tudi po tej strani ovirajo prenos podatkov, pri digitalnih PBX pa se ta situacija je pravoj izboljšuje.

Na osnovi dolga tradicije in čedalje hitrejšega razvoja tehnologije se je izoblikovala naslednja generacijska klasifikacija PBX od ročnih in elektromehanskih sistemov prve generacije do sodobnih neblokirajočih distribuiranih sistemov četrte generacije, ki bodo integrirali tehnologiji LAN in PBX:

- 1. generacijo PBX predstavljajo ročni in elektromehanski sistemi v analogni tehnologiji, ki podpirajo le prenos govora;
- 2. generacijo PBX predstavljajo distribuirani računalniško vodeni sistemi (običajno že v povsem digitalni tehnologiji), ki imajo le omejeno zmogočnost prenosa podatkov kot dodatek k prenosu govora;
- 3. generacijo PBX predstavljajo neblokirajoči sistemi, to so taki, ki imajo že v zasnovi zmogočnost takega prenosa in komunikacije podatkov in govora, da zmorajo prenati vse prometne obremenitve z vseh priključkov hkrati;
- 4. generacijo PBX pa predstavljajo sistemi, ki združujejo prednosti lokalnih računalniških mrež (LAN) (prilagojenost hitremu prenosu podatkov) in PBX tretje generacije (majhna občutljivost za promet, vrojena zmogočnost učinkovitega prenosa govora).

Sistemi četrte generacije integrirajo tehnologiji PBX in LAN najpogosteje tako, da je LAN povezovalni element med PBX, PBX pa služi kot serverji.

Vse doslej so bili računalniško krmiljeni PBX sprogramirani nestrukturirano, in šele v zadnjem času se je ideologija sedemnivojskega OSI modela uveljavila tudi na tem področju. Četrta generacija PBX nudi osnovo za razvoj ISPBX ("ISDN PBX" ozicoma "Integrated Services PBX"), ki bo nudil integrirane storitve na podlagi ustreznih standardov. Po svetu so se že začeli pojavljati prvi ISPBX, ki pa rahlo odstopajo od dosedaj sprejetih standardov in priporočil (Plessey). V nadaljevanju si bomo ogledali, kaj sploh pomeni pojem "integracija" v tem konceptu ter kakšni standardi so že sprejeti in kakšne še pričakujemo.

### 3. Klasifikacija podatkov

Podatke v širšem smislu lahko razdelimo na štiri karakteristične oblike:

- **podatki v ožjem smislu** imajo zelo strukturirano naravo in so organizirani v obliki datotek, zapisov in polj ter so z tem zelo primerni za organizacijo v obliki podatkovnih baz; procesiranje podatkov je odvisno tudi od kategorije - ločimo znanstvene in poslovne podatke;
- **besedila** imajo manj strukturirano naravo od zgoraj omenjenih podatkov; osnovne enote pri urejanju in procesiranju besedil so besede, stvari, odstavki, strani in dokumenti; vendar so zmogočnosti avtomatskega procesiranja besedil (brez uporabnikove ali operaterjeve navzočnosti) bistveno manjše kot pri podatkih (v ožjem smislu);
- **slike** imajo še slabšo strukturiranost - enoto predstavljata tu točka (pixel) in celo stran ozicoma slika; obsežnost informacije o sliki pa pri kolikor toliko sposobnosti resoluciji močno naraste;

- **govor** je najpomembnejša oblika podatkov (v širšem smislu) in bo še dolgo zavzemal več kot 90% vseh prometnih zmogljivosti PBX; načelno nima nobene fizično očitne strukture, pri njegovem shranjevanju na magnetne računalniške medije pa lahko s pridom uporabljamo le zapis v obliki datotek.

Pri vsaki od navedenih oblik podatkov so poleg strukturiranosti važne še naslednje značilnosti:

- obseg (nevarenost "eksplozije podatkov" pri določenih načinih uporabe),
- hitrost prenosa in
- možne osnovne operacije nad njimi.

Shematični pogled na klasifikacijo podatkov je prikazan na sliki 1, s komunikacijami kot "lepilom" na sredi. Oprema, ki je vrinsa znotraj dřtkanega okvirja, lahko uporablja komunikacijski podsistemi, medtem ko oprema zunaj okvirja te možnosti nima.

Pri komuniciranju lahko posamezne oblike podatkov med seboj kombiniramo, nekatere kombinacije pa so za uporabnika izjemno atraktivne:

- videokonferanca na primer zahteva simultani prenos govora in slike,
- pri elektronski pošti ozicoma v izmenjavi dokumentov so kombinirana besedila, podatki in slike, itd.

Na sliki 1 je vmes med področji prikazana tudi oprema za tak kombiniran simultan prenos različnih oblik podatkov.

Integriran prenos vseh vrst podatkov ozicoma integracija storitev pomeni, da omrežje za prenos ne ve in ne sreča vadeti, s kakšnimi oblikami podatkov ozicoma s kakšnimi storitvami se ukvarja, ampak mora izvesti "prozoren" prenos dane informacije (v obliki govorcev bitov).

### 4. Struktura sistema z integracijo govora in podatkov

Glede na v prejšnji točki opredeljene značilnosti podatkov potrebujemo komutacijski sistem za učinkovit prenos vseh oblik podatkov na čim bolj enak način (integrirano). Njegova struktura naj bi bila tako, da ima:

- sposobnost komutacije, zasnovane na popolnoma digitalnem prenosu podatkov,
- neblokirajočo arhitekturo,
- združevanje prednosti LAN (prilagojenost hitremu prenosu podatkov) in PBX (majhna občutljivost za promet, vrojena zmogočnost učinkovitega prenosa govora) ter s tem povezano.
- zmogočnost operacij (ki so doslej omejene le na posamezne PBX) na nivoju mreže;
- vsaj predvideno možnost kasnejše razširitve na širokopasovni prenos podatkov.

Komunikacijski sistemi, ki bodo sedaj instalirani, pa morajo imeti tudi še dve drugi važni sposobnosti:

- polno uporabljati obstoječo, instalirano opremo za govorne in podatkovne komunikacije in
- imeti tako strukturo, da se bo dalo enostavno dodajati novo standardno govorno in podatkovno opremo, ki bo predvidoma v kratkem na voljo na tržišču.

diskovne in tračne enote, delovni pomnilnik, OCR, tiskalniki, risalniki, operacijski sistemi, uporabniški in aplikativni programi



Slika 1. Klasifikacija podatkov in ustrezena oprema

### **S. Terminali**

Za izvedbo raznih telematskih storitev in različnih funkcij (ter s tem povezanim oblikovanjem podatkov) uporabljamo zelo različno terminalno opremo, od "dobrega starega" analognega telefona do specializiranih posebnih naprav za povsem določens namene. Ogledimo si le dva splošna tipa terminalov, ki bosta po predvidevanjih v bodoče najbolj razširjena.

To sta:  
- digitalni telefon in  
- delovna postaja.

Digitalni telefon je funkcionalno podoben analognemu telefonu, le da govor takoj pretvori v digitalno obliko, omogoča pa tudi izmenjavo raznih sporočil med centralo in telefonom, ki jih telefon izpisuje na LCD prikazovalniku.

Delovna postaja je enota s tipkovnico in prikazovalnikom (ekranom) za ustvarjanje, popravljanje in shranjevanje podatkov, besedil in slik za izpis na zaslon, izpis na tiskalnik ali za komunikacijo z drugimi sistemmi; ima možnost prenosa poljubne vrste podatkov preko telefonske linije (IVD (Integrated Voice & Data) terminal); nudi možnost uporabe različnih programov za poslovno in osebno rabo (elektronski urnik, kalkulator, procesorji besedil, preglednice, OCR (Optical Character Recognition)).

#### 4. *Tetraenatite* stortitve

Sedaj, ko vemo, kaj želimo prenašati (vse vrste podatkov, na integriran način), z čim prenašati podatke (omrežje, ISDN) in z čim oblikovati podatke (terminali), moramo povedati še, za kaj in kako bomo uporabili te podatke: za izvedbo raznih telematskih storitev.

V okviru CCITT priporočil so specificirane naslednje telematske storitve:

- javni faksimile,
  - teleteks in
  - videoteks.

Te tri storitve so sorazmerno precej dobro standardizirane; določen je način delovanja teh storitev v mednarodnem prometu, specifične so zahteve za terminala za izvajanje teh storitev, dejanska izvedba storitev na nacionalnem nivoju pa je prepuščena posameznim PTT organizacijam.

Javni faksimile je kopiranje na daljavo odobritevanje slike (dokumenta,...) pri pošiljalju, prenos tako generiranih podatkov skozi omrežje in reprodukcija slike na ponocni strani.

Teleteks služi za urejanje, oblikovanje, prenos in shranjevanje besedil med različnimi uporabniki. V bistvu je teleteks izboljšani teleks glede na kvaliteto dokumentov in hitrost prenosa.

Videoteks je storitev za dostop (in ažuriranje) javnih podatkovnih baz za izvedbo različnih poizvedovanj, pa tudi za elektronsko pošto.

Poleg teh treh obstoji še celo množica drugih, bolj ali manj definiranih storitev. Navedimo jih le nekaj:

Elektronska pošta je storitev za prenos besedil ali podatkov (v ozjemu smislu) med različnimi uporabniki. Sestavljajo jo naslednje funkcije: urejanje ter oblikovanje, posiljanje, prenos, sprejem, archiviranje in brisanje pošte.

V različnih virih pa z elektronsko pošto povezujejo še naslednja področja:

- MHS (Message Handling Systems) je sistem za izmenjavo sporočil med uporabniki, definiran v okviru X.400 CCITT priporočil in se uporablja predvsem za realizacijo elektronske pošte;
- predvsem na Japonskem vključujejojo med elektronsko pošto tudi "poštni faksimile" ali "komunicirajoče inteligentne kopirne stroje", saj so ugotovili, da je za sporočila, pisana s katakano, tak način prenosa najprimernejši;
- nekateri si pod elektronsko pošto predstavljajo le del videoteksa;
- v zaprtih sistemih (v Sloveniji na primer DeltaNet) se pojavljajo programski produkti s tem imenom, ki poleg običajnih funkcij zahtevajo še osebno vreditev pošte osebam brez dostopa do terminala, pismo s povratnico, itd.

Telekonferanca je storitev, ki omogoča dve ali več skupinam ljudi medsebojno hkratno komuniciranje na govorni in/ali vidni način. Telekonference razvrščamo v naslednje kategorije:

- zgoli avdio-konferanca se omejuje le na prenos govora in je lahko fiksna oziroma vnaprej določena (traja neprekiniteno) ali pa jo naročnik ali posredovalec vzpostavi z izbiranjem;
- audiografska konferanca je avdio-konferanca z dodano zmožnostjo prenosa grafične informacije, običajno s pomočjo elektronskih tabel in elektronskih skicirk, faksimile naprav in mikrofilmov;
- videokonferanca kombinira prenos govora, grafike in slik udeležencov; prenos slik je lahko na način počasne TV (slow-scan), lahko je običajni (analogni) prenos ali pa komprimirani video (prenesejo se le spremembne na sliki);
- računalniška konferanca je storitev, s katero se medsebojno povezujejo udeleženci konference s pomočjo svojih terminalov v nekem centralnem računalniku.

Večino sedaj obstoječih videokonferenc po svetu uporabljajo za poslovne sestanke in le nekaj procentov za izobraževanje in nadaljnje usposabljanje.

Kabelska televizija, HI-FI radio in teletekst so danes marsikje že delajoče storitve, vendar le v okviru posebnih omrežij. Zanje lahko pričakujemo, da se bodo v okviru širokopasovnega ISDN omrežja združile z ostalimi telestvami.

## 7. Ekspertni sistemi v teleinformatiki

Z leti postajajo centralne oziroma njihove zmožnosti multiplexiranja vse večje, kontrolni sistemi zanje pa vse kompleksnejši (z nazivom kontrolni sistemi imenujemo vso programsko opremo od sistemskih in aplikativnih pa vse do administrativne ter podprtne programske opreme). Z uporabo mikroprocesorjev smo dosegli zelo močne, fleksibilne kontrolne sisteme, hkrati pa je močno narasla tudi težavnost odkrivanja napak v njih. Za testiranje, vzdrževanje in modificiranje sistemov zato čedalje bolj prihaja do veljave (kot skoraj edina možna rešitev) uporaba metod umetne inteligence oziroma ekspertnih sistemov.

Naredimo še kratek pregled možnih ekspertnih sistemov v okviru teleinformatike:

- testiranje nove oziroma popravljane programske opreme v PBX,
- načrtovanje konfiguracij PBX central oziroma privatnih omrežij na osnovi PBX central tretje ali četrte generacije z materialnega in programskega stališča glede na potrebe kupca ter hkratna določitev arhitekture in celotnega designa tega sistema,
- načrtovanje uporabniške prijaznih vmesnikov v teh sistemih,
- nadzor nad stanjem kablov v omrežju in odkrivanje ter sporočanje okvar,
- diagnosticiranje izpadov napajanja v elektronskih PBX,
- upravljanje z informacijami (inteligentne podatkovne baze),
- vzdrževanje opreme,
- razpoznavanje in interpretacija različnih signalizacij (pomembno pri motnjah, zakasnitvah, ...),
- razvrščanje in dodeljevanje resursov za telekonference,
- diagnosticiranje izpadov satelitskega prenosa in delovanja,
- zasledovanje in navigacija satelitov, itd.

Seveda zadnja dva primera za nas žal še nista primerna.

## 8. Standardizacija

Na kratko preglejmo CCITT priporočila, s poudarkom na serijah V, X, I in T.

Serija V se ukvarja s podatkovnimi komunikacijami preko telefonskega omrežja.

Serija X se ukvarja z omrežji za prenos podatkov:

- zmožnosti;
- vmesniki;
- prenos, signalizacije in preklopovanje;
- vidiki omrežja;
- vzdrževanje;
- OSI (odprtvi sistemi povezovanja);
- medsebojno sodelovanje;
- MHS (sistemi za prenos in obdelavo sporočil).

Serija I vsebuje priporočila za ISDN:

- I.100: splošni pregled (okvirna zgradba in terminologija; opis ISDN; splošne metode oblikovanja; smeri razvoja);
- I.200: zmožnosti storitev (vidiki storitev; prenosne storitve; telestoritve);
- I.300: splošni vidiki in funkcije omrežja (funkcionalni principi omrežja; referenčni modeli (protokoli in funkcionalna arhitektura modela, hipotetične referenčne povezave); principi očetevljenja, naslavljanja in usmerjanja; tipi povezav; zahtevane lastnosti (povezovanje s pomočjo tokokrogovnega ali paketnega preklapljanja));
- I.400: vmesniki med uporabnikom in omrežjem (splošni vidiki vmesnikov med uporabnikom in omrežjem (referenčne konfiguracije, struktura kanalov in zmožnosti dostopa); aplikacije vmesnikov med uporabnikom in omrežjem; priporočila nivoja 1 (vmesniki za bazično in za primarno hitrost); priporočila nivoja 2 (LAPD); priporočila nivoja 3; multiplexiranje, prilagajanje hitrosti, podpora obstoječih priporočil (X.21, X.21 bis, X.25, serija V, 56K bps));
- I.500: vmesniki med centralami v omrežju;
- I.600: principi vzdrževanja (principi na uporabnika nanašajočega se testiranja in vzdrževanja).

Serija T se ukvarja s terminali za izvajanje telematskih storitev.

Omenimo še standardizacijo računalniških mrež (LAN). Najbolj odmevna s tega področja je serija standardov IEEE 802, ki se ukvarja predvsem z načinom dostopa do prenosnega medija:

- 802.1 tehnična rdeča nit: odnos med standardi in ISO OSI referenčnim modelom
- 802.2 logični nadzor linije:  
    LLC-1 - brezpovezavni  
    LLC-2 - povezavno usmerjeni
- 802.3 vodilo z dostopom CSMA/CD (Ethernet)
- 802.4 vodilo z žetonom
- 802.5 obroč z žetonom
- 802.6 mestna omrežja

V Evropi je (vsaj v univerzitetnih krogih) pravljicno priljubljena lokalna računalniška mreža Cambridge Ring. Standardizirana je v okviru ISO z dokumentom DP 8802.6 (slotted ring).

Pričakovana standardizacija v svetu in v Jugoslaviji: v svetu se standardi izredno hitro razvijajo (dopolnjevanje standardov za ISDN, standardi za širokopasovni ISDN, za pisarniško avtomatizacijo in še za mnogo drugih področij), pri čemer pa se na področju standardizacije podatkovnih omrežij ne dogaja skoraj nič. Eden od prvih korakov pri nas v tej smeri bo verjetno standardizacija postopkov, uporabljenih v Jupaku (X.25, itd.). Vsaj za upočasnitve zaostajanja na tem področju je treba delo takoj zelo intenzivirati.

## 9. Literatura

International Telecommunication Union, CCITT, Red Book, VIII th Plenary Assembly, 1984 (Genève 1985)

Serija standardov ANSI/IEEE 802.n (Standard for Local Area Networks), n = 1, 2, ..., 6

ISO standardi:

DP 8802.6 - Slotted Ring

DIS 7498 - Open Systems Interconnection

Datapro Reports on Data Communications, Datapro Research Corporation, Delran, NJ (monthly updated)

IEEE Spectrum, Special issue: Telecommunications, Volume 22, November 1985

M. J. Bevan: Image Processing May Cause Future Problems with Network Loading, Data Communications, March 1986

R. C. Hawk: The Integrated Voice/Data Option, Conference Transcript of "Voice/Data Integration Conference", Oyez Scientific and Technical Services, London, December 1983

P. Kahli: A Review of CCITT Standardization to Date, IEEE Journal on Selected Areas in Communications, May 1986, Vol. SAC-4, No.3

W. Karavatos: The Fourth Generation of PABXs, Conference Transcript of "3rd and 4th Generation PABXs Conference", Oyez Scientific and Technical Services, London, February 1985

W. B. Rauch-Hindini: Upper Level Network Protocols, Electronic Design, March 1983

A. S. Tanenbaum: Computer Networks, Prentice Hall, Englewood Cliffs, NJ, 1981

```
=====
= ADVANCED MICROPROCESSORS AND =
= HIGH-LEVEL LANGUAGE COMPUTER ARCHITECTURE =
=====
```

Knjiga z naslovom **ADVANCED MICROPROCESSORS AND HIGH-LEVEL LANGUAGE COMPUTER ARCHITECTURE** je zbirka najpomembnejših člankov, poročil in ekspertiz, ki jih je zbral in uredil avtor Veljko Milutinović za potrebe poučevanja predmeta z enakim naslovom na Purdue University v ZDA.

Knjiga je učbenik za študente ter hrati tudi dober pripomoček načrtovalcem novih računalniških sistemov in vodjem razvoja, ki potrebujetejo znanje o sodobnih trendih v računalniških arhitekturah. Knjiga sestoji iz 39 člankov, ki so razdeljeni v 7 delov in 14 poglavij ter ima skupno skoraj 600 strani.

Knjiga govori o arhitekturah, ki temeljijo na visokoprogramskih jezikih, to je o HLL (High Level Language) računalniških arhitekturah. Avtor deli HLL računalniške arhitekture na dve osnovni skupini:

- arhitekture z indirektnim izvajanjem ter
- arhitekture z direktnim izvajanjem.

Pri arhitekturah z indirektnim izvajanjem je za izvajanje programa potreben izvorni kod prevesti v izvajalni kod. Pri arhitekturah z direktnim izvajanjem pa računalnik lahko direktno izvaja izvorni kod.

Nadalje deli Milutinović arhitekture z indirektnim izvajanjem v dva podrazreda:

- reducirane arhitekture in
- kompleksne arhitekture.

Kompleksne arhitekture se nadalje delijo v

- jezikovno vodene arhitektura in
- jezikovno odvisne arhitekture.

Jezikovno vodene arhitekture lahko definiramo kot arhitekture, kjer se proti konstrukcije strojnega jezika na relativno visokem nivoju toda ne na nivoju HLL sintakse. Pri jezikovno odvisnih arhitekturah pa imamo direktna enotljivo odvisnost med HLL konstrukcijo in konstrukcijo strojnega jezika.

Na koncu so razdeljene jezikovno odvisne arhitekture še v:

- arhitekture s programskimi prevajalniki ter
- arhitekture s strojnimi prevajalniki.

Slika 1 kaže razdelitev HLL arhitektur.



Slika 1: Razdelitev HLL arhitektur.

Vtič o knjigi si najhitreje ustvarimo s pregledom kazala knjige, ki podaja poleg naslova vseh člankov tudi strukturo knjige in razdelitev vsebine v posamezne dele in poglavja.

#### Table of Contents

|                                                                                                                                                                                     |     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Preface.....                                                                                                                                                                        | iii |
| Acknowledgements.....                                                                                                                                                               | v   |
| <b>Part I -- Introduction</b>                                                                                                                                                       |     |
| Chapter 1:Essential Issues.....                                                                                                                                                     | 2   |
| Directions and Issues in Architecture and Languages.....                                                                                                                            | 3   |
| M.J.Flynn(Computer,October 1980,pages 5-22)                                                                                                                                         |     |
| Compilers and Computer Architecture.....                                                                                                                                            | 20  |
| W.A.Hulf(Computer,July 1981,pages 41-47)                                                                                                                                            |     |
| Requisites for Improved Architectures.....                                                                                                                                          | 27  |
| G.J.Myers(Advances in Computer Architecture, 1982,pages 58-100)                                                                                                                     |     |
| Retrospective on High-Level Language Computer Architecture.....                                                                                                                     | 63  |
| D.R.Ditzel and D.A.Patterson(Proceedings of the 7th International Conference on Computer Architecture,May 1980,pages 97-104)                                                        |     |
| Chapter 2:Impacts of the VLSI Technology.....                                                                                                                                       | 71  |
| VLSI Processor Architecture.....                                                                                                                                                    | 73  |
| J.L.Hennessy(IEEE Transactions on Computers, December 1984,pages 1221-1246)                                                                                                         |     |
| An Introduction to VLSI Microprocessor Architecture for GaAs.....                                                                                                                   | 97  |
| V.Milutinovic,D.Fura, and W.Helbig                                                                                                                                                  |     |
| Chapter 3:A Survey of Advanced Microprocessors and High-Level Language Architecture.....                                                                                            | 117 |
| A Survey of Advanced Microprocessors and High-Level Language Computer Architecture.....                                                                                             | 118 |
| A.Silbey,V.Milutinovic, and V.Mendoza-Grado                                                                                                                                         |     |
| <b>Part II -- Reduced Architectures</b>                                                                                                                                             |     |
| Chapter 4:The RISC Approach.....                                                                                                                                                    | 144 |
| A VLSI RISC.....                                                                                                                                                                    | 145 |
| D.A.Patterson and C.H.Sequin(Computer,September 1982,pages 8-21)                                                                                                                    |     |
| Architecture of a VLSI Instruction Cache for a RISC.....                                                                                                                            | 158 |
| D.A.Patterson,P.Garrison,M.Hill,D.Liboupolis, C.Nyberg,T.Sippel, and K.Van Dyke(Proceedings of the 10th Conference on Computer Architecture June 1983,pages 108-116)                |     |
| Strategies for Managing the Register File in RISC.....                                                                                                                              | 167 |
| Y.Tamir and C.H.Sequin(IEEE Transactions on Computers,November 1983,pages 977-989)                                                                                                  |     |
| Architecture of SOAR:Smalltalk on a RISC....                                                                                                                                        | 180 |
| D.Ungar,R.Blaau,P.Foley,D.Samples, and D.Patterson(Proceedings of the 11th International Conference on Computer Architecture,June 1984,pages 188-197)                               |     |
| Chapter 5:The MIPS Approach.....                                                                                                                                                    | 191 |
| Hardware/Software Tradeoffs for Increased Performance.....                                                                                                                          | 192 |
| J.Hennessy,N.Jouppi,F.Baskett,T.Gross, and J.Gill(Proceedings of the ACM Symposium on Architectural Support for Programming Languages and Operating Systems, March 1982,pages 2-11) |     |

|                                                                                                                                                   |     |                                                                                                                                                                   |
|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Organization and VLSI Implementation of MIPS...</b>                                                                                            | 202 | <b>Part IV -- HLL Architectures -- Type A</b>                                                                                                                     |
| S.A.Przybylski,T.R.Gross,J.L.Hennessey,N.P.Jouppi, and C.Rowen(Stanford University Technical Report No.84-259,April 1984).                        |     | <b>Chapter 9:Some Early Experiments.....</b> 460                                                                                                                  |
| <b>Floating-Point Arithmetic on a Reduced-Instruction-Set Processor.....</b> 241                                                                  |     | <b>Implementation of a High-Level Language Machine.....</b> 461                                                                                                   |
| T.Gross(Proceedings of the 7th Symposium on Computer Arithmetic,June 1985,pages 86-92)                                                            |     | A.Hassitt,J.W.Lageschulte, and L.E.Lyon(Communications of the ACM,April 1973,pages 199-212)                                                                       |
| <b>Postpass Code Optimization of Pipeline Constraints.....</b> 248                                                                                |     | <b>Design of an Aerospace Computer for Direct HOL Execution.....</b> 475                                                                                          |
| J.L.Hennessey and T.R.Gross(ACM Transactions on Programming Languages and Systems,July 1983 pages 422-448)                                        |     | W.C.Nielsen(Proceedings of the Symposium on High-Level Language Computer Architecture, June 1973,pages 34-42)                                                     |
| <br>                                                                                                                                              |     |                                                                                                                                                                   |
| <b>Chapter 6:Miscellaneous Reduced-Instruction-Set Processors.....</b> 275                                                                        |     | <b>Chapter 10:Some Current Research.....</b> 485                                                                                                                  |
| <b>The 801 Minicomputer.....</b> 276                                                                                                              |     | <b>Scheme-79 --Lisp on a Chip.....</b> 486                                                                                                                        |
| G.Radin(IBM Journal of Research and Development,May 1983,pages 273-246)                                                                           |     | G.J.Sussman,J.Holloway,G.L.Stein,Jr.,and A.Bell(Computer,July 1981,pages 10-21)                                                                                   |
| <b>Ridge 32 Architecture - A RISC Variation...<b>286</b></b>                                                                                      |     | <b>The Scheme-81 Architecture--System and Chip by the Designers.....</b> 497                                                                                      |
| E.Basart and D.Folger(Proceedings of ICCD'83, October 1983,pages 315-318)                                                                         |     | J.Batali,E.Goodhue,C.Hanson,H.Shrobe,R.M.Stallman, and G.J.Sussman(Proceedings of the 1982 MIT Conference on Advanced Research in VLSI, January 1981,pages 69-77) |
| <b>Reduced-Instruction-Set Multi-Microcomputer System.....</b> 290                                                                                |     | <br>                                                                                                                                                              |
| L.Foti,D.English,R.P.Hopkins,D.J.Kinniment, P.C.Traileaven, and H.L.Wang(Proceedings of the NCC,July 1984,pages 69-75)                            |     | <b>Part V -- HLL Architectures--Type B</b>                                                                                                                        |
| <b>Applying RISC Theory to a Large Computer...<b>297</b></b>                                                                                      |     | <b>Chapter 11:Two Interesting Experiments.....</b> 508                                                                                                            |
| R.Ragan-Kelley and R.Clark(Computer Design, November 1983)                                                                                        |     | <b>Reflections on the High-Level Language Symbol Computer System.....</b> 509                                                                                     |
| <br>                                                                                                                                              |     | D.R.Ditzel(Computer,July 1981,pages 55-66)                                                                                                                        |
| <b>Part III -- Language-Directed Architectures</b>                                                                                                |     | <b>High-Level Language Oriented Hardware and the Post-von Neumann Era.....</b> 521                                                                                |
| <br>                                                                                                                                              |     | H.J.Burkle,A.Frick, and C.Schlier(Proceedings of the 5th Annual Symposium on Computer Architecture,June 1978,pages 60-65)                                         |
| <b>Chapter 7:Stack Machines.....</b> 304                                                                                                          |     | <br>                                                                                                                                                              |
| <b>Stack Computers:An Introduction.....</b> 305                                                                                                   |     | <b>Chapter 12:The DEL Approach.....</b> 527                                                                                                                       |
| D.M.Bulman(Computer,May 1977,pages 18-28)                                                                                                         |     | <b>Ideal Directly Executed Languages:An Analytical Argument for Emulation.....</b> 528                                                                            |
| <b>Exploring a Stack Architecture.....</b> 315                                                                                                    |     | L.W.Hoewel(IEEE Transactions on Computers, August 1974,pages 759-767)                                                                                             |
| R.P.Blake(Computer,May 1977,pages 30-39)                                                                                                          |     | <b>Execution Architecture:The DELtran Experiment..</b> 537                                                                                                        |
| <b>Twenty Years of Burroughs High-Level Language Machines.....</b> 325                                                                            |     | M.J.Flynn and L.W.Hoewel(IEEE Transactions on Computers,February 1983,pages 156-174)                                                                              |
| E.D.Earnest(Proceedings of the International Workshop on High-Level Language Computer Architecture,June 1980,pages 64-71)                         |     | <br>                                                                                                                                                              |
| <b>Implications of Structured Programming for Machine Architecture.....</b> 333                                                                   |     | <b>Part VI -- Direct Execution Architectures</b>                                                                                                                  |
| A.S.Tanenbaum(Communications of the ACM,March 1978,pages 237-246)                                                                                 |     | <br>                                                                                                                                                              |
| <br>                                                                                                                                              |     | <b>Chapter 13:The University of Maryland Approach.</b> 558                                                                                                        |
| <b>Chapter 8:Advanced Complex-Instruction-Set Microprocessors.....</b> 343                                                                        |     | <br>                                                                                                                                                              |
| <b>An Architectural Comparison of 32-Bit Microprocessors.....</b> 344                                                                             |     | <b>Interactive High-Level Language Direct-Execution on Microprocessor System.....</b> 559                                                                         |
| A.Gupta and H.D.Toong(IEEE Micro,February 1983 pages 9-22)                                                                                        |     | Y.Chu and E.R.Cannon(IEEE Transactions on Software Engineering,June 1976,pages 126-134)                                                                           |
| <b>Introduction to the iAPX 432 Architecture...<b>358</b></b>                                                                                     |     | <b>Programming Languages and Direct-Execution Computer Architecture.....</b> 568                                                                                  |
| Intel Corporation(Intel Corporation Manual Order Number 171821-001,1981)                                                                          |     | Y.Chu and M.Abrams(Computer,July 1981,pages 22-32)                                                                                                                |
| <b>A 32-Bit VLSI CPU Chip.....</b> 422                                                                                                            |     | <br>                                                                                                                                                              |
| J.W.Beyers,L.J.Dohse,J.P.Fucetola,R.L.Kochis, C.G.Lob,G.L.Taylor, and E.R.Zeller(IEEE Journal of Solid-State Circuits,October 1981,pages 210-214) |     | <b>Part VII -- International efforts</b>                                                                                                                          |
| <b>The Motorola MC68020.....</b> 429                                                                                                              |     | <br>                                                                                                                                                              |
| D.MacGregor,D.Mothersole, and B.Moyer(IEEE MICRO, August 1984,pages 101-118)                                                                      |     | <b>Chapter 14:International Efforts.....</b> 580                                                                                                                  |
| <b>System Considerations in the NS32032 Design...<b>447</b></b>                                                                                   |     | <br>                                                                                                                                                              |
| R.Mateosian(Proceedings of the NCC,July 1984, pages 77-81)                                                                                        |     | <b>A Survey of High-Level Language Machines in Japan.....</b> 581                                                                                                 |
| <b>An Inside Look at the Z80,000 CPU:Zilog's New 32-Bit Microprocessor.....</b> 451                                                               |     | M.Yamamoto(Computer,July 1981,pages 68-77)                                                                                                                        |
| A.Patel(Proceedings of the NCC,July 1984,pages 83-91)                                                                                             |     | <b>Selected European Contributions in the Area of High-Level Language Computer Architecture...<b>590</b></b>                                                      |
|                                                                                                                                                   |     | A.Silbey and V.Milutinovic                                                                                                                                        |

V prvem poglavju knjige so 4 uvodni članki svetovno poznanih avtorjev (Flynn, Wulf, Myers,

Ditzel), ki obravnavajo odnos med programskim jezikom in arhitekturo računalnika. Hkrati predstavljajo izbrani članki pregled področja ter omogočajo bralcu, da na podlagi bibliografije razširi svoje znanje v posameznih specialnostih.

Drugo poglavje vsebuje 2 članka o vlogi VLSI tehnologije na računalniške arhitekture. Prvi članek (Hennessy) obravnava VLSI tehnologijo, ki temelji na klasični silicijevi tehnologiji, drugi članek (Milutinović) pa obravnava novo in hitro prodirajočo tehnologijo verzij na osnovi galijevega arzenida GaAs. Pristop pri načrtovanju računalniške arhitekture v mnogodem zavisi od izbrane tehnologije. Tako silicijeva kot tudi GaAs tehnologija imata vsaka svoje značilnosti, ki postavljajo specifične zahteve pri načrtovanju optimalne radikalniške arhitekture. Poglavlje obravnava reducirane arhitekture in sicer RISC računalnik iz Berkeley, MIPS iz Stanforda in ostale.

Prvi članek drugega poglavja, katerega avtor je Hennessy, primerja dva osnovna pristopa v arhitekturi, to je arhitekturo, ki zajema kompleksen nabor ukazov in arhitekturo z reduciranim naborom ukazov, kjer je obakrat procesor realiziran v VLSI tehnologiji na osnovi silicija. Članek analizira učinkovitost izvajanja predenega koda visokoprogramskega jezika.

Drugi članek je napisal Milutinovič in predstavlja GaAs kot možno osnovo za implementacijo VLSI procesorjev. Pri tem pa nam nova tehnologija narekuje novo arhitekturo vezij in režime, ki so bile razvite za silicijevlo okolje na splošno niso uporabne pri vezjih, ki temeljijo na GaAs. Kaze, da je pri vezjih, ki temeljijo na GaAs učinkovita samo arhitektura z reduciranim naborom ukazov.

Poglavja 3, 4 in 5 so posvečena kompleksnim arhitekturam, to je jezikovna odvisnim in jezikovno vodenim arhitekturam. V tretjem poglavju je narejen pregled različnih pristopov pri zasnovi in implementaciji novih mikroprocesorjev in HLL arhitektur ter analiza performans različnih sistemov.

Cetrtog poglavje je posveđeno RISC (Reduced Instruction Set Computer) arhitekturam. Ukvareja se z izborom reduciranega nabora ukazov in nekaterimi specifičnimi implementacijami, ki temeljijo na reduciranih naborih ukazov. Posebej je v prvem članku (Petterson) obdelan projekt University of California at Berkeley UCB-RISC, ki omogoča hitrejše izvajanje programa napisanega v visokoprogramskejem jeziku. Bitstvo rešitve problema je v metodi kako zasnovači arhitekturo, da bo čim bližje tistim konstrukcijam strojnega jezika, ki se pri visokoprogramskih jezikih najpogosteje uporabljajo. Nekrat naj bo arhitektura računalnika zasnovana tako, da bo zmanjšena potreba po komunikaciji z ostalimi vezji. Tako ima RISC I arhitekturi le 31 ukazov od katerih večina opravlja le preproste ALU in pomicne (shift) operacije na registrih.

Drugi članek v tem poglavju (Petterson) obravnava implementacijo VLSI verzja za cache ukaze za UCB-RISC računalnik. Ta VLSI verzija je neobčutljivo na napake (fault tolerant), vsebuje poseben programski stevec, izvaja komprimiranje kode in omogoča razširljivost. Kondni cilj skupine v Berkeleyu je združiti ukazni cache pomnilnik ter podatkovni cache pomnilnik s centralno procesorsko enoto v eno vezjo (chip).

Naslednji članek v četrtem poglavju (Tamic) se ukvarja z različnimi strategijami in metodami, ki so povezane z vodenjem večokenskih register-skih datotek v računalnikih kot je na primer UCB-RISC. Pri visokoprogramskih jezikih je

klicanje procedure časovno najbolj zamudna operacija. V splošnem imajo lahko RISC programi še ved klicev procedur kot običajni računalniki saj so kompleksni ukazi, ki jih najdemo v CISC arhitekturah realizirani kot podprogrami v RISC arhitekturi. Zato morajo biti klici procedur pri RISC računalnikih kar se da hitri. To je realizirano z registerskimi okni. Večokenska registerska datoteka je eden od tistih pristopov, ki bistveno pripomore k zmanjšanju potrebu po komunikaciji z drugimi vezji. Ideja je v tem, da v verzje vgradimo dolodeno število delno prekrivajočih se registerskih oken, pri čemer je ob vsakem trenutku dostopno prevajalniku ali programerju v zbirnem jeziku samo posamezno okno. Ostala okna vsebujejo spremenljivke za ostale procese. Eden od problemov pri tem pristopu je kako ravnati, če pride pri registerski datoteki do presekka (overflow). Avtorja članka ugotavljata, da je optimalno število registrrov, ki shranjujejo presek ūnako na.

Zadnji članek v četrtem poglavju (Ungar) opisuje zasnovno in implementacijo mikroprocesorja, ki je namenjen za jezik Smalltalk. Ta procesor temelji na reducirani naboru ukazov, a se bistveno razlikuje od UCB-RISC procesorjev. To nam potrjuje domnevo, da se vsaka reducirana arhitektura navezuje na dolodeno aplikacijo zato različno aplikativno okolje vodi do različnih konkretnih rešitev RISC procesorja.

Peto poglavje vsebuje štiri članke in je posvečeno MIPS pristopu. MIPS je okrajšava za Microprocessor without Interlocked Pipeline Storage. Ta koncept so razvili na Stanford University. MIPS pristop je primeren za verzijo, ki temelji na tehnologiji silicija, kot tudi za verzijo ki temelji na tehnologiji GaAs. Če primerjamo MIPS arhitekturo z arhitekturo UCB-RISC vidimo, da je za MIPS arhitekturo izabilna nizka kompleksnost VLSI vezij, zahteva pa kompleksnejši nadir programiranja in prevajanja. Eno osnovnih prednosti MIPS arhitekture je dejstvo, da je cevna sinhronizacija izvedena s programskim pristopom in ne ved v materialni računalniški opremi. To je ugodno predvsem zaradi lažje implementacije VLSI vezij in tudi hitrosti procesorja. Seveda pa mora prevajalnik sedaj generirati kod, ki je brez cevnih konfliktov. Generator koda zadosti tem zahtevam tako, da vstavi ukaze NO-OP povsed tam, kjer je to potrebno. Optimizator koda poskuša zamenjati čim ved ukaz NO-OP s kodo od kjer koli drugje pod pogojem, da na ta način ne vpliva na odvisnost podatkov. Tu vidimo potrebo po komplikiranih tehnologijah prevajalnikov.

### **Instruction 1**

| Fetch | Decode | Operand Decode | Stores or Executes | Operand Fetch |
|-------|--------|----------------|--------------------|---------------|
|       |        |                |                    |               |

| Instructions i + 1 | Fetch | Decode | Operand Decode | Store or Execute |
|--------------------|-------|--------|----------------|------------------|
|--------------------|-------|--------|----------------|------------------|

### (a) Plastic Structure

|                   |                    |                    |
|-------------------|--------------------|--------------------|
| <b>A := B + C</b> | <b>Load B, R1</b>  | <b>Load B, R1</b>  |
|                   | <b>Load C, R2</b>  | <b>Load C, R2</b>  |
|                   | <b>Add R1, R2</b>  | <b>NO-OP</b>       |
|                   | <b>Store R2, A</b> | <b>Add R1, R2</b>  |
|                   |                    | <b>Store R2, A</b> |

(b) HLL Statement    (c) Output of the Code Generator    (d) Output of the Code Register

Slika 2.1 Primer snemanja z MIPS arhitekturo, ki kaže izhod generatorja koda in reorganizatorja koda.

Naslednji članek (Przybylski) je tehnično poročilo Stanford University, ki opisuje VLSI implementacijo MIPS. Ta članek obravnava področje kot so nabor ukazov, cevna organizacija, ukrepanje pri izjemah, podpora za virtualni pomnilnik, podpora operacijskega sistema in visokoprogramskega jezika itd. Članek vsebuje tudi podatke o merjenju performans sistema.

Naslednji članek (Gross) se osredotoča na probleme, ki so povezani s programsko implementacijo aritmetike s plavajočo vejico za MIPS mikroprocesorje. Pri izbiri reduciranega nabora ukazov se pojavlja vprašanje, kako je tak reducirani nabor primeren za aritmetiko plavajoče vejice in za aritmetiko na sploš. Nabor ukazov za MIPS arhitekturo vsebuje ukaz, ki ustreza množenju po Booth algoritmu, kar je dalo relativno dobre performance.

Zadnji članek v petem poglavju (Hennessey) analizira številne činitelje, ki so povezani z optimizacijo koda v MIPS okolju. Članek definira tip cevnih konfliktov do katerih lahko pride v MIPS mikroprocesorju. Govori o razlikah pri optimizaciji koda, ki se izvaja po alokaciji registerov ali sočasno z alokacijo. MIPS optimizator koda uporablja prvi pristop. Podana je teorija MIPS kodnega optimizatorja in podatki o oceni performans.

6. poglavje je posvečeno arhitekturam za direktno izvajanje. Vsebuje štiri članke, ki obravnavajo najzanimivejše procesorce z reduciranim naborom ukazov. Trije taki procesorji izhajajo iz industrije, to so: IBM (IBM 801), Ridge (Ridge-32) in Pyramid (Pyramid 90X). Tretji procesor pa je bil razvit na University of Reading v Angliji. Angleški procesor je narejen v VLSI tehnologiji (RIMMS) ostali trije pa temeljijo na hitri SSI/MSI tehnologiji. Intenzivne raziskave in razvoj procesorjev z reduciranim naborom ukazov tečajo tako v industrijskem okolju (Fairchild, Hewlett-Packard, RCA, TRW, Inmos) kot tudi na univerzah (Caltech, Purdue, ULCA, Wisconsin in druge).

Nekateri tovrstni projekti so se pričeli že sredi sedemdesetih let. Tak je na primer projekt za miniračunalnik IBM 801. Članek, katerega avtor je Radin, govori o tem projektu in podaja nekatere značilnosti samega procesorja in tudi sistema kot celote. Opisuje na primer nabor ukazov, ki je realiziran popolnoma v materialni računalniški opremi, hierarhičnost pomnilnika, organizacijo V/I komunikacije, ki omogoča centralnemu procesorju izvajanje ukaza v skoraj vsakem ciklu in drugo. Projekt je bil poleg tega usmerjen k realizaciji sposobnejših prevajalnikov.



Slika 3.1: Zgradba Ridge-32 procesorja.

Basart in Folger v svojem članku predstavljata zasnovno in implementacijo superminiračunalnika Ridge-32, ki je verjetno prvi komercialno dobljiv RISC računalnik. Članek se ukvarja z osnovnimi cilji arhitekture, z izborom nabora ukazov, z implementacijo sistema in oceno performans. Ta računalnik je narejen za hitro izvajanje zahtevnih grafičnih aplikacij. Slika 3 kaže strukturo Ridge-32 procesorja, ki je implementiran s komercialno Schottky bipolarno logiko. Procesor ima ločeno dostavno (fetch) enoto in izvajano enoto. Dostavna enota je narejena za hitro izvajanje ukazov, ki se bo izvedel. Dostavna enota in izvajalna enota tvorita štiristopenjsko cevno arhitekturo, ki omogoča prekrivanje izvajanja ukazov. Ridge-32 vsebuje tudi zaleden pomnilnik (cache), kjer se hranijo vsi pred kratkim izvedeni ukazi.

Foti sodelavci v četrtem članku šestega poglavja opisuje projekt RIMMS mikračunalnika (Reduced-Instruction set Multi-Microprocessor System project). RIMMS sestoji iz linearnega polja 255 mikračunalnikov, ki komunicirajo preko skupnega vodila kot kaže slika 4.



Slika 4.1: Zgradba RIMMS mikračunalnika z 255 procesorji.

Vsek mikračunalnik ima preprost procesor in 256 zlogov lokalnega pomnilnika.

Ta mikroprocesor ima skrajno reducirani nabor ukazov in je namenjen uporabi v multimikroprocesorskem okolju. Zato so posebno pozornost posvetili strojni računalniški podpori za medprocesorsko komunikacijo. Vodilo sestoji iz 16 bitnega naslova, 16 bitnega podatka in dodatnih bitov za delo s pomnilnikom, kar omogoča izvajanje NO-OP posaga po pomnilniku. Slika 5 kaže organizacijo in kontrolo vodila ter pomnilnika za RIMMS mikračunalnik.



Slika 5.1: Nadzor vodila in pomnilnika za RIMMS mikračunalnik.

Med najzanimivejše lastnosti tega mikroprocesorja sodijo metode, ki jih uporabljajo za podporo programskih konstrukcij kot so FORK, JOIN, REMOTE LOAD in REMOTE STORE. Razvili so jezik za parallelno procesiranje imenovan BASAL, ki podpira osnovno idejo mikračunalnika z

reduciranim naborom ukazov za multimikroprocesorsko okolje.

Ragan-Kelley opisuje razvoj superminiračunalnika pri Pyramid Technology Corporation, ki prav tako temelji na reducirarem naboru ukazov. Cilj projekta je sposoben računalnik, ki podpira UNIX operacijski sistem in visokoprogramski jezike kot so C in Pascal. Računalnik je namenjen večuporabiškem okolju. Na razvoj tega projekta je verjetno vplival projekt RISC iz Berkeleyja, kljub temu pa vsebuje ta projekt številne nove zamisli.

Sedmo poglavje se ukvarja s skladovnimi (stack) računalniki. Sklad omogoča učinkovito organizacijo preklapljanja konteksta kot tudi aritmetiko. S skladovno arhitekturo se posebej ukvarjajo Burroughs, Hewlett-Packard, Microdata, Intel, Xerox in Zilog. Prvi članek v tem poglavju opisuje osnovno idejo skladovne arhitekture, še posebej povzročanje in kontrolo podprogramov ter evaluacijo izrazov. Podana je primerjava skladovnih računalnikov in tradicionalnih računalnikov, ki temeljijo na splošnih registrih.

Blake je avtor članka, ki je uvod v optimalno zasnovo skladovnega računalnika in podaja pristop firme Hewlett-Packard. Članek analizira potrebe in značilnosti programov pisanih v visokoprogramskih jezikih in njihov vpliv na sklad. Posebna pozornost je posvečena strojni opremi skladovnih računalnikov, naboru ukazov, naslovnem prostoru za procese, spremljjanju procesov itd.

Earnest v tretjem članku sedmoga poglavja obravnava ved skladovnih računalnikov, ki so jih razvili pri Burroughs v zadnjih 20 letih. Eden glavnih razlogov, da se nekateri proizvajalci osredotočajo na skladovne računalnike je dejstvo, da je relativno lahko pisati prevajalnike za skladovne računalnike in, da je ta koda ponavadi precej kompaktna.

Osmo poglavje se ukvarja s sodobnimi mikroprocesorji za kompleksen nabor ukazov, ki jih pogosto imenujemo CISC (Complex-Instruction-Sets Computers). Poglavje vsebuje 8 člankov, ki govorijo o 32 bitnih procesorjih, ki so namejeni delu z visokoprogramskimi jeziki. Imajo bogat nabor ukazov, od katerih nekateri zelo spominjajo na konstrukte, ki so značilni za moderne visokoprogramski jeziki. Raziskave in razvoj na tem področju hitro napredujejo in novi ter populnejši 32 bitni mikroprocesorji se stalno pojavljajo v ZDA, na Japonskem in v Evropi. Uveljavljeno je prepričanje, da so CISC računalniki bolj primerni za podporo programske zanesljivosti kot pa RISC računalniki. Prav tako imajo močnejše sposobnosti obdelave aritmetičnih izrazov. Sveda pa so CISC računalniki v primerjavi z RISC računalniki podcenjenji pri izvajanju prevedenega programa, ki jeписан v visokoprogramskem jeziku. Ker so CISC procesorji kompleksnejši, zahtevajo daljši čas za razvoj procesorja. Dajstvo pa je, da so novi CISC procesorji zelo sposobni, uporabljajo visoko stopnjo cevnega parallelizma in vsebujejo že na čipu cache pomnilnik ter mehanizme za delo s pomnilnikom. Konečna odločitev in tekma med RISC in CISC mikroprocesorji je še pred nami in ni jasno kdo bo zmagoval.

Gupta v svojem članku primerja 4 zgodnje 32 bitne mikroprocesorje. Tehnično porodilo firme Intel podaja bistvene značilnosti procesorja iAPX 432. Dobra lastnost procesorja iAPX 432 je razširjivost sistema. Vedno sposobnost sistema dosegamo brez spremnjenja programske opreme, tako, da povečamo število procesorjev v sistemu na največ 5 GPD (General Data Processors). Pet takih procesorjev si deli isto vodilo in imajo zato performance, ki so enake

vesoti treh nedvignih GPD. Razširitev iAPX v multiprocesorski sistem in performance iAPX 432 multiprocesorskoga sistema kaže slika 6.



(a) An IAPX 432 Multiprocessor System



(b) The Efficiency Function

Slika 6.: iAPX 432 multiprocesorski sistem in njegove performance kot funkcija števila procesorjev.

Beyers v svojem članku podaja notranje organizacijo procesorja HP-FOCUS. McGregor sodeloval obravnava bistvene značilnosti Motorolla nega procesorja MC68020. Mateosian opisuje glavne značilnosti procesorja NS32032 proizvajalca National Semiconductor. Na koncu poglavja pa je Patel podal pregled Zilogovega procesorja Z80,000. Vsi ti članki so zgolj pregledni članki.

Deveto poglavje podaja nekaj zgodnjih poskusov na področju HLL arhitektur s programskim prevajalnikom. To so arhitekture z naborom strojnih ukazov, ki je v enolični (eden proti enemu) zvezi z ukazi značilnega visokoprogramskega jezika. Prevajanje je izvršeno programsko. Pogoste te arhitekture imenujemo jezikovno skladne arhitekture s programskim prevajanjem. Zanimalje za te arhitekture se je zadealo že leta 1960, ko se je pojavila potreba po računalniku, za katerega bi bilo lažje pisati sistemski in uporabniški kod. Glavni problem tega pristopa pa je kompleksnost materialne računalniške opreme.

To poglavje vsebuje 2 članka. Prvi, katerega avtor je Hassit et al., opisuje enega prvih tovornih eksperimentov pri IBM. Rezultat tega eksperimenta je bil računalnik, ki je bil namenjen za jezik APL. To je bil pravzaprav računalnik IBM 8/360 M/25, ki je bil mikropro-

gramirani in je generiral APL kod. Osnovni razlog za ta razvoj je bila želja razviti učinkovito arhitekturno podporo za jezike kot so APL ali SNOBOL. Ti jeziki ponavadi potrebujejo interpreter in konvencionalen pristop ima lahko za posledico znatno zmanjšanje hitrosti izvajanja programa.

Nielsen predstavlja v drugem članku devetega poglavja glavne rezultate študije, katero cilj je bil načrt računalniške arhitekture in programskega jezika za vesoljske aplikacije.

Oba članka iz tega poglavja podajata rezultate eksperimenta. Računalnika, ki sta pri tem nastala sta danes zastarela, omenjena pa sta v tej knjigi zato, ker sta s svojimi idejami in eksperimentalnimi rezultati vplivala na sodobne tokove pri raznovi novih računalniških arhitektur.

Deseto poglavje opisuje nekatere sodobne raziskave na MIT. Vsebuje dva članka, ki se navezujejo na jezikovno skladne arhitekture. Te so zanimive tako z gledišča VLSI načrtovanja vezij, kot tudi z gledišča mikroprogramiranja. Večina računalnikov, ki temelji na tem pristopu vsebuje mikroprogram za podporo konstrukciji visokoprogramskega jezika. Trenutno stanje razvoja VLSI lahko udinkovito podpira velike ROM pomnilnike za mikroprogram na čipu. Vemo pa, da je VLSI tehnologija premalo močna za podporo kompleksnih visokoprogramskega jezikov na popolni enolični korrespondenci. Torej lahko z VLSI tehnologijo podpiramo bodisi samo izbrano podmnožico visokoprogramskega jezika ali pa uporabimo tehnologijo, ki ni VLSI in podpiramo celotni visokoprogramski jezik.

Prvi članek, katerega avtor je Sussman sodelavci, opisuje zasnova in implementacijo mikroračunalnika na enem vezju, ki direktno interpretira Scheme-79, to je dialect jezika Lisp. Skupina na MIT je razvila interpreter v obliki mikrokoda, ki so ga realizirali v strojni računalniški opremi. Pri tem so uporabili dodatne in nekonvencionalne hardverske pripomočke ter s tem povedali udinkovitost računalnika.

Drugi članek desetega poglavja, katerega avtor je Batali et al., opisuje vezje Scheme-81, ki je naslednik vezja Scheme-79. Scheme-81 je namenjen za okolja, kjer so računalniki specifikirani in kjer velike skupine računalnikov sodelujejo pri reševanju posamezne zahtevne naloge.

V 11. poglavju je govora o dveh zanimivih eksperimentih. Prvi izhaja iz šestdesetih let in opisuje Symbol računalniški sistem, to je računalnik, ki ima nekonvencionalno arhitekturo in o katerem je bilo v preteklosti veliko diskusij. Symbol je računalnik, ki ima splošen programski jezik in time-sharing operacijski sistem implementiran v materialni računalniški opremi. Vzpadbuda za tak eksperiment temelji na dejstvu, da so sčasoma postali prevajalniki zapleteni in jih je bilo težko napisati. Po drugi strani je cena materialne računalniške opreme padala, kompleksnost načrtovalnih orodij za razvoj vezij pa se je boljšala.

Drugi članek enajstega poglavja (Burkis) predstavlja laboratorijski eksperiment, ki je rezultiral v računalnik z imenom Abacus. Abacus je nastal pod vplivom računalnika Symbol, ima pa vrsto originalnih novih rešitev kot na primer kontrolo poslov (job control), učinkovito delo s podatkovnimi tipi in drugo.

Ovanajstvo poglavje vsebuje dva članka, ki obravnavata DEL (Directly Executed Language) pristop to je arhitekturo za direktno izvajanje jezika. To so, po razdelitvi iz slike 1, HLL arhitekture s strojnimi prevajalniki. Pri teh

arhitekturah uporabljam za programiranje običajen visokoprogramska jezik. S predprocesiranjem izvornega koda se prevade izvorni program v DEL obliko, kar je optimalni vmesnik med posameznim visokoprogramskega jezikom in izvajalnim računalnikom (Slika 7).



Slika 7: Primerjava med DEL arhitekturo in tradicionalno arhitekturo.

Prvi članek v tem poglavju, katerega avtor je Hoevel, podaja pregled različnih metod, ki se uporabljajo za generiranje DEL arhitekture.

Flynn je avtor drugega članka in opisuje DELtran eksperiment, ki se navezuje na okolje programskega jezika Fortran II. Izvajalni računalnik pri tem eksperimentu je mikroprogramabilni računalnik EMHY z univerze Stanford. Članek podaja primerjavo v performansah, ko se uporablja DELtran ali pa druge konvencionalne arhitekture kot na primer IBM 370. Prihranek pri velikosti programa in naslavljanju pomnilnika je pri uporabi DELtran-a znaten.

Flynn in Hoevel sta s svojim delom močno vplivala na razvoj celotnih HLL arhitektur, vključno z RISC arhitekturami.

Trinajsto poglavje opisuje v dveh člankih arhitekturo računalnika za direktno izvajanje, ki so jo zasnovali na University of Maryland. Bistvo pristopa univerze Maryland je dejstvo, da arhitektura omogoča direktno interpretiranje izvornega koda programov. Na ta način je semantični prepad med programskega jezikom in arhitekturo popolnoma premogčen.

Prvi članek v trinajstem poglavju (Chu) se ukvarja s sistemskimi vprašanji interaktivnega visokoprogramskega jezika in z arhitekturo za njegovo direktno izvajanje. Članek obravnava razliko med sistemom z interaktivnim prevajanjem in sistemom z interaktivnim interpretiranjem.

Drugi članek trinajstega poglavja (Chu) analizira interakcijo med procesorjem in visokoprogramskega jezikom pri arhitekturi za direktno izvajanje (Slika 8). Procesor za to arhitekturo sestoji iz treh glavnih delov, to je slovarskega dela procesorja, nadzornega dela procesorja in podatkovnega dela procesorja. V članku je prikazana interakcija teh treh delov procesorja na primerih, ko uporabljamo visokoprogramskega jezik.



Slika 8: Organizacija računalnika za direktno izvajanje.

Knjiga se konča s 14 poglavji, ki obravnava preglede članke o razvoju HLL arhitektur v različnih razvojnih centrih po svetu. Poglavlje vsebuje dva članka, ki predstavljata raziskovalne in razvojne dosežke na področju HLL računalniških arhitektur v Japonski in v Evropi. Yamamoto je v članku, ki daje pregled teh raziskav na Japonskem, prikazal strukturo PL/I procesorja, konfiguracijo Cobol računalnika, več različnih Lisp računalnikov, NEC-ov singgle-chip Pascal procesor in druge zanimivosti.

Drugi članek zadnjega poglavja (Sylbey) daje pregled raziskav s področja računalniških arhitektur v Evropi. Omenjeni so dosežki s področja reducirnih arhitektur z University of Kent, univerze v Bonnu in Gesellschaft für Mathematik und Datenverarbeitung. S podatkovno vodenimi arhitekturami se ukvarjajo na University of Manchester, Katholieke Universiteit Leuven in na univerzi v Dortmundu. Z reduciranimi arhitekturami se ukvarjajo na University of Reading. Jožikovno vodenje arhitekture razvijajo na Tehnični univerzi Berlin in na Univerzi Dortmund. HLL arhitekture razvijajo na univerzi Paul Sabatier v Toulouse ter na univerzah v Dortmundu, Frankfurtu ter Kaiserslautern. Arhitekture za direktno izvajanje razvijajo na gvedskem in v Franciji. Vsada je centrov, kjer raziskujejo in razvijajo HLL računalniške arhitekture v Evropi več mnogo ved. V tem članku je izbranih samo nekaj najbolj zanimivih. Na koncu je priložen še spisek evropskih revij in simpozijev s področja HLL računalniških arhitektur.

Pripravil: Saša Prešern

\*\*\*\*\*  
\* Pisma bračev \*  
\*\*\*\*\*

Poštovani dr. Žaleznikar

U broju 3/86 Vašeg časopisa "Informatica", kojeg inače sa zadovoljstvom pratim i neobično cenim, objavili ste članak autora Vilfana, Mahniča i Mohoriča: "Ocena programskih orodij IDA". Iako znam da nije praksa Vašeg časopisa da prenosi polemike u vezi sa informatičkim temama ipak osjećam potrebu da na ovaj članak na neki način reagiram.

Mi u Jadroagentu u Rijeci koristimo IDA alate a posebno IDA-Bazu od samih njihovih početaka tako da smo dosta detaljno upoznati sa njima pa nas je posebno zanimalo jedno, stručno mišljenje pogotovo kada ono dolazi sa Fakulteta za elektrotehniku iz Ljubljane i to iz Laboratorija za programsku opremu kako su se autori potpisali.

Ideja da se uzme u stručno razmatranje jedan programski proizvod je izuzetno zanimljiva pogotovo kada se radi o IDA-Bazi proizvodom Iskra-Delta iz Ljubljane za koju možemo slobodno reći da je prvi jugoslavenski sistem za upravljanje bazom podataka koji je načao svoj put do tržista. Još će više zaintrigirati čitaoca napava da će proizvod biti usporen sa ULTROM poznatim programskim proizvodom svjetski renomirane firme CINCOM iz Cincinnatija u SAD.

U članku je uvodno dosta dobro dan pregled proizvoda IDA sa njegovim osnovnim karakteristikama ali se odmah oučava da autori zaobilaze onaj dio koji će sve sadašnje i buduće korisnike IDA-alata zanimati a to su praktičan rad sa IDA-alatima (i usporedba sa ULTROM) kao i rezultati mjerjenja performansi.

Da bi se dala ocjena jednog programskog proizvoda pogotovo tako složenog kao što je IDA nije dovoljno proučiti samo njegov priručnik već je potrebno određeno vrijeme raditi sa tim produkтом a pri ruci imati razna mjerila kako bi se ocjene mogle kvantificirati.

Ako se želi dati paralelna ocjena u usporedbi sa drugim proizvodom tada treba razraditi (i objasniti) metodologiju usporednog testa i dati paralelne podatke kako bi budući i sadašnji korisnici tih produkata (jer smatramo da je za njih članak i napisan) mogli dobiti realnu sliku o kvalitetama i performansama tih produkata.

Zato se obraćam Vama druže uredniče sa molbom i željom da i ubuduće u Vaš časopis uvrstite članke koji daju ocjene softverskih proizvoda ali opremljene sa svim potrebnim podacima o performansama kako bi čitaoci mogli dobiti realnu sliku o njima.

Uz želje za uspješan napredak Vašeg časopisa drugarski posdravljamo,

Ranko Smokvina, dipl. ek.  
ruk. informatičke službe  
Rijeka, 12. 07. 1986 Jadroagent Rijeka

-----  
Odgovor urednika:  
-----

Spoštovani kolega R. Smokvina,

Hvala za vaše pismo, ki me je vzpodbudilo k nekoliko bolj izčrpnejšem odgovoru, saj vaša vprašanja dregajo v splošnejši koncept in praksu strokovne kritike in polemike v okviru računalništva in informatike.

Praksa časopisa Informatica so lehko samo tisti predmeti, za katere se uredništvo in predvsem avtorji opredeljujejo, da so relevantni in na določeni razvojni, kulturni stopnji tudi potrebni in zaseljeni. Polemični in kritični prispevki so danes že kako potrebeni, čeprav je pismenost na tem področju in sploh pri strokovnem delu šibka oziroma se ne privzgojuje in tako tudi ne prakticira. Seveda pa polemičnost in kritičnost vobča nista zaseljeni, ker vzbuzirata naša tradicionalno mirna delovna okolja. To sem celo ob izraziti nepolemičnosti časopisa Informatica iškal tudi na svoji koži.

Ocenjevanja sistemskih in aplikativnih programskih paketov oziroma izdelkov je v razvitem strokovnem tisku domala standarizirano. Ocena ali benchmark je dovolj raznoljena kvantitativna in kvalitativna primerjava smogljivosti programskega izdelka, ki ob cenovni primerjavlji daje napotek potencialnemu kupcu, da se lažje odloča za izbiro glede na svoj specifičen primer. Ob benchmarku je seveda zaselencem že polemična obravnava, ki razjašnjuje tista mesta, določene semantične atribute, ki jih z standardnim ocenjevanjem ni mogoče zajeti. Časopis Informatica je široko odprt za vsako argumentirano polemiko in kritiko programskih izdelkov in seveda tudi za druga področja strokovne problematike.

S kolegom R. Smokvino se strinjam, da zadevni članek, ki ocenjuje programska orodja IDA, ne dosega ocenjevalnih standardov in da kakovost ocene ni nujno odvisna od naslova institucije, ki ji avtorji pripadajo. Zato sprejemam tiki in skrajno obzirni poziv R. Smokvine, da je določena pozornost, kakovost, strokovna doslednost pri ocenjevanju potrebna, če naj ocena prima ka korist tudi potencialnim interesentom. Strinjam se tudi, da ocene določenega produkta ni mogoče dati z prebiranjem priročnikov in da je lahko ozadje neke ocene le strokovno utemeljeno delo s produkтом.

S pozdravom

Ljubljana, 13. 8. 1986

A. P. Žaleznikar

# SRC

SVEUČILIŠNI RAČUNSKI CENTAR  
UNIVERSITY COMPUTING CENTRE

**POZIV NA SUDJELOVANJE**

9. MEĐUNARODNI SIMPOZIJU "KOMPЈUTER NA SVEUČILIŠTU"  
18 — 22. SVIBNJA 1987.

*Mjesto:*  
DUBROVNIK/ČAVTAT, HOTEL CROATIA

*Organizator:*  
SVEUČILIŠNI RAČUNSKI CENTAR, ZAGREB

*Teme:*

- INFORMATIKA I OBRAZOVANJE
- RAČUNARSKI SISTEMI I MREZE, OSOBNA RAČUNALA
- SOFTWARE-SKO INŽINJERSTVO
- INFORMACIJSKI SISTEMI I BAZE PODATAKA
- ANALIZA PODATAKA, STATISTIKA I STATISTICKI SOFTWARE
- MODELIRANJE, SIMULACIJA I OPTIMIZACIJA
- DIZAJN I PROIZVODNJA POMOĆU RAČUNALA (CAD/CAM)
- UMJETNA INTELIGENCIJA I EKSPERTNI SISTEMI
- PRIMJENA INFORMATICKIH SREDSTAVA I METODA U PRIRĐNIM I DRUŠTVENIM ZNANOSTIMA
- DRUŠTVENI I PRAVNI ASPEKTI INFORMATIKE

*Rok za sažetke (1-2 stranice):*

15. STUDENI 1986.

*Obevijest o prihvaćanju:*  
15. PROSINAC 1986.

*Rok za radove:*  
15. VELJAČE 1987.

*Struktura simpozija:*

PREDAVANJA, POSTER SEKCije, PREZENTACIJE HARDWARE-A I SOFTWARE-A,  
PANEL DISKUSIJE, IZLOŽBE

*Informacije:*

*Sekretarica simpozija:*

SVEUČILIŠNI RAČUNSKI CENTAR, 41000 Zagreb, Engelsova, b.b., Jugoslavija  
Tel.: 041/510-099, TM: 21871

**CALL FOR PAPERS**

IFIP WG 6.5 International Working Conference on Message Handling Systems  
April 27-29, 1987, Munich, FRG



IFIP WG 6.5 International Working Conference  
on Message Handling Systems

State-of-the-art, new Future Options

27 to 29 April 1987, Munich

Munich, FRG (West Germany)

Fed. Rep. of Germany

Sponsored by IFIP WG 6.5, and the Gesellschaft für Informatik

To: Message Systems '87

Mrs. Stenzel

Siemens AG

D-8000

Ode-Hahn-Ring 8

D-8000 München 83

Fed. Rep. of Germany

**TRIGLAV**

**TRETJI VRH RAZVOJA ISKRE DELTE**



Računalniški sistem TRIGLAV lahko deluje na treh procesnih enotah. Z enostavno menjavo procesorskih modulov in operacijskih sistemov je družina TRIGLAV kompatibilna z družinama mikro in miniračunalnikov vodilnih svetovnih proizvajalcev in seveda z računalniki in s programsko opremo ISKRE DELTE.

Sistem TRIGLAV je zasnovan za uporabo v:

- vodenju proizvodnje
- avtomatizaciji procesov
- robotizaciji
- kot grafično delovno mesto za projektiranje
- kot večuporabniški poslovni sistem
- kot komunikacijska enota

