Kesederhanaan dalam desain Belanda

May 08 2023
Setelah beberapa cerita tentang pekerjaan, izinkan saya menceritakan sebuah cerita menarik dari enam puluh lima tahun yang lalu tentang dua desainer Belanda dan karya mereka. Artikel ini adalah hasil dari salah satu daya tarik saya dengan mata pelajaran teknis acak.

Setelah beberapa cerita tentang pekerjaan, izinkan saya menceritakan sebuah cerita menarik dari enam puluh lima tahun yang lalu tentang dua desainer Belanda dan karya mereka. Artikel ini adalah hasil dari salah satu daya tarik saya dengan mata pelajaran teknis acak. Setelah cerita umum, kami akan membahas beberapa detail teknis.

Perancang pertama adalah Dick Bruna, pencipta Miffy (atau “Nijntje” dalam bahasa Belanda asli):

Nijntje (Miffy) di kebun binatang

Dick Bruna menggunakan metode menggambar seperti Matisse yang sangat khusus . Dia menghabiskan waktu berjam-jam untuk satu gambar untuk memastikan ada makna sebanyak mungkin, menggunakan elemen sesedikit mungkin. Saya tumbuh bersama Nijntje, dan sepertinya Anda juga demikian, karena buku-buku tersebut dijual di sebagian besar negara di dunia.

Ketika saya mengunjungi pameran Vermeer beberapa hari yang lalu (saya beruntung tinggal cukup dekat dengan Rijksmuseum), saya menemukan bahkan ada Nijntje khusus  untuk acara tersebut.

Kira-kira pada waktu yang sama Dick Bruna menciptakan Nijntje, ada perancang Belanda lainnya, yang kurang terkenal, menggunakan pendekatan yang sama untuk merancang sesuatu yang sangat berbeda: salah satu komputer pertama.

Saat itu tahun 1958. Hanya dua buku Nijntje yang tersedia, dan hanya dalam bahasa Belanda. Orang tua saya bertemu untuk pertama kalinya (akhirnya saya lahir pada tahun 1964). Rusia meluncurkan satelit Sputnik setahun sebelumnya, memulai perlombaan luar angkasa.

Komputer terbesar di dunia saat itu adalah sistem militer AN/FSQ-7 , yang dibuat oleh IBM, terdiri dari 24 mesin. Setiap mesin berbobot 250 ton, menggunakan daya 3 megawatt, dan melakukan 75.000 operasi per detik. (Sebagai perbandingan, ponsel Anda sekitar satu juta kali lebih cepat, dengan daya baterai.)

Bahkan komputer sipil adalah monster yang beratnya berton-ton dan menghabiskan banyak uang. Di seluruh dunia, ada sekitar seribu dari mereka. Jika Anda memiliki komputer, Anda harus menyewa beberapa spesialis teknis agar tetap berjalan.

Di Belanda, hanya ada segelintir komputer yang dimiliki oleh lembaga penelitian dan perusahaan teknologi tinggi seperti Philips dan Fokker.

Willem van der Poel telah menyelesaikan tesis Ph.D. “The Logical Principles of Some Simple Computers” dua tahun sebelumnya. Tesisnya menjelaskan bagaimana Anda dapat membuat komputer dengan sumber daya sesedikit mungkin.

Willem bekerja di perusahaan telepon Belanda (PTT) merancang komputer yang dapat digunakan yang jauh lebih murah daripada komputer di pasaran, namun tetap relatif cepat. Karena semua komponen komputer mahal, pendekatan minimalisnya adalah yang dibutuhkan.

Komputer Willem disebut ZEBRA. Mesin itu hanya terdiri dari tiga lemari, relatif kecil pada masanya. Majikannya memutuskan bahwa terlalu rumit untuk membuat dan memasarkan mesin ini, sehingga pembuatannya dilakukan oleh perusahaan Inggris Stantec.

Komputer ZEBRA beraksi. Komputer sebenarnya ada di tiga lemari di latar belakang

Komputer ini cukup sukses: sekitar 55 di antaranya dibuat dan dijual; sekitar sepertiga digunakan di Belanda, dan sisanya digunakan di luar negeri. Ada komunitas pengguna yang bersemangat di mana orang-orang bertukar ide pemrograman.

Kenangan saya tentang Willem van der Poel

Pertama kali saya mendengar nama Willem van der Poel adalah ketika seseorang memberi saya “ puzzle Van der Poel ”. Teka-teki kayu 18 bagian yang tampaknya sederhana ini bahkan sulit untuk dibongkar ; perakitan hampir mustahil. Itu masih teka-teki kayu tersulit yang pernah saya lihat. Kemudian saya mendapat buku puzzle kayu untuk ulang tahun saya yang berisi penjelasan tentang cara membuatnya sendiri, tetapi sayangnya keterampilan pertukangan saya tidak cukup untuk tugas itu. Nama “Van der Poel” melekat di otak saya.

Teka-teki Van der Poel, di mana semuanya dimulai

Di lain waktu, ayah saya berbicara tentang akronim yang disukainya dan dia berkata bahwa ada komputer bernama “ZEBRA” yang berarti “Zeer Eenvoudige Binaire Reken Automaat” (“Mesin Perhitungan Biner Sangat Sederhana”). penemuan, tapi nama ZEBRA macet.

Bertahun-tahun kemudian, saat makan malam penelitian, saya kebetulan duduk di depan Willem van der Poel sendiri. Kami berbicara tentang ZEBRA, dan Willem menjelaskan kepada saya bahwa trik desainnya adalah membuat set instruksi umum yang memungkinkan untuk melakukan semua langkah dari loop perkalian dalam satu instruksi berulang. Sejak saat itu, saya terpikat, dan saya harus mencari tahu cara kerjanya. Saat itu sulit mencari informasi tentang ZEBRA karena internet belum cukup matang.

Beberapa tahun yang lalu saya mendapat buku tentang komputer lama yang memperlihatkan beberapa gambar ZEBRA, termasuk gambar yang merupakan bagian dari dokumentasi ZEBRA. Saya mulai mencari-cari di Google, dan menemukan semakin banyak tentang seberapa pintar sebenarnya desain itu. Tidak ada jalan kembali: Saya harus membuat emulator.

Bekerja dari komputer ZEBRA

Untuk memahami cara kerja komputer ZEBRA yang aneh dan membingungkan, bersiaplah untuk melupakan banyak hal yang Anda anggap remeh tentang cara kerja komputer. ZEBRA tidak memiliki keyboard, ROM, byte, pointer, stack, atau bahkan penghitung program.

Jika Anda tidak tertarik dengan detail teknis, Anda dapat melewatkan beberapa halaman ke jenius pemrograman. Sebelum kita membahasnya, mari kita mulai dari awal. Deskripsi ini adalah terjemahan dalam bahasa komputer modern dari dokumen garis besar fungsional dari September 1958.

Perangkat keras

ZEBRA adalah mesin serial: artinya penambahan dilakukan dengan menambahkan bit satu per satu. Semua operasi adalah 33 bit. Ya, 33: itu bukan kesalahan! Rangkaian elektronik untuk penjumlahan bit demi bit adalah “ serial binary adder ”, sebuah rangkaian digital yang sangat dasar. Tapi karena diimplementasikan menggunakan tabung vakum, ini sudah menghabiskan beberapa kilo barang elektronik. ZEBRA berisi total lima penambah seri, ditambah "incrementor", versi sederhana dari sirkuit ini yang menambahkan satu ke angka.

Instruksi dan data keduanya memiliki ukuran yang sama; sebenarnya, sebenarnya tidak ada perbedaan antara keduanya, karena terkadang Anda perlu melakukan perhitungan dengan instruksi.

Penyimpanan

ZEBRA memiliki 8192 kata dari 33 bit memori, disusun sebagai 256 trek pada drum magnetik. Setiap track memiliki 32 kata, jadi itu berarti alamat drum terdiri dari delapan bit yang menentukan track dan lima bit yang menentukan posisi pada track.

Willem van der Poel. Di latar belakang drum memori ZEBRA

Drum diputar dengan 100 putaran per detik. Tidak ada penundaan dalam mengganti trek pada drum; yang harus Anda lakukan hanyalah menunggu nilai yang tepat untuk ditampilkan, yang memerlukan waktu hingga 10 milidetik. Program pintar ditulis sehingga alamatnya ada di drum berikutnya (di trek mana pun). Dengan cara ini Anda tidak perlu menunggu drum.

Singkatnya, ZEBRA memiliki tiga jenis siklus: waktu bit 7,8 μs, di mana satu bit diproses oleh penambah; waktu instruksi 312 μs, di mana instruksi dieksekusi; dan waktu putaran drum 10 ms.

Register

Ada dua belas register tujuan umum (4 sampai 15), dan empat register khusus (A, B, C, D). Masing-masing juga disimpan di drum, dengan hanya menggunakan sebagian trek. Kepala baca dan tulis ditempatkan pada jarak yang tepat, sehingga data setiap register dapat diakses di setiap instruksi.

Ada juga beberapa register semu yang merupakan perangkat keras khusus yang ditujukan seperti register:

  • 0 berisi nilai 0
  • 1 berisi nilai 1
  • 2 berisi nilai A (kecuali bit ke-34)
  • 3 berisi nilai B
  • 23 berisi nilai “setengah”, atau 1 << 32 seperti yang kita tulis hari ini
  • 24 berisi AND logis dari A dan B, atau A & B seperti yang kita tulis hari ini
  • register lain memberi nilai dari lima lubang pukulan pembaca kaset, untuk membaca dan menulis
  • register yang mengirim bit ke printer.

Register A, B, C, D

Register A dan B, juga disebut akumulator, adalah dua register (hampir) identik. Mereka adalah pekerja komputer. Setiap instruksi akan menggunakan salah satu dari dua akumulator, atau keduanya sebagai nilai presisi ganda. Daftar A memiliki bit 34 ekstra, yang hanya dapat dibaca menggunakan operasi shift. Nilai yang sesuai untuk B disimpan di "carry trap".

Akumulator terhubung ke penambah serial, memungkinkan untuk melakukan perhitungan yang relevan. Dua "penambah awal" tambahan yang digunakan dalam beberapa instruksi memungkinkan untuk menambahkan jumlah dari dua nilai ke akumulator.

Register C sebenarnya disimpan dalam bentuk elektronik. Pada akhir setiap instruksi, nilainya disalin ke register instruksi. Register instruksi, seperti prosesor modern lainnya, menentukan apa yang akan dilakukan mesin pada siklus tertentu. Anehnya, register C juga diumpankan dari keluaran penambah, sehingga Anda dapat menghitung instruksi selanjutnya dari penjumlahan dua nilai. Ini memungkinkan untuk melakukan lebih banyak operasi lanjutan seperti pengindeksan array.

Register D dihubungkan dari output register C melalui sebuah incrementor, sehingga berisi nilai register C sebelumnya ditambah dua. (Menambahkan dengan dua dalam bentuk serial sama seperti menambahkan satu, tetapi memulai siklus nanti.) Penggunaan register ini, dan mengapa ini dinaikkan dengan dua, bukan satu, akan dijelaskan nanti.

Itu semua register yang ada.

Ringkasnya, perangkat keras komputer ZEBRA terdiri dari:

  • Drum yang berisi program, data dan register.
  • Daftar C, diimplementasikan dalam perangkat keras, yang disalin ke register instruksi pada awal instruksi.
  • Lima penambah, mengumpan ke register A, B, C
  • Banyak sakelar elektronik yang akan merutekan data serial ke berbagai penambah dan register.
  • Pemilih data untuk trek dan posisi drum.
  • Semua perangkat keras lainnya digunakan untuk sistem I/O (tape reader, punch dan printer).

arsitektur umum

Berikut adalah gambar blok bangunan dasar, langsung dari manualnya:

Empat blok dasar ZEBRA

Unit aritmatika berisi A dan B; unit kontrol berisi C dan D dan register instruksi. Register dan penyimpanan utama masing-masing dapat membaca atau menulis satu kata setiap siklus. Koneksi antar unit tergantung pada instruksi.

Petunjuk

Ya, tunggal! Alih-alih memiliki satu set instruksi, komputer ini hanya memiliki satu instruksi, dengan banyak opsi berbeda. Sebagian besar opsi adalah bit yang akan mengubah sebagian operasi dengan cara yang sangat cerdas, sehingga sejumlah besar tindakan dapat dilakukan dalam satu siklus. Ini berarti bahwa tidak diperlukan instruksi decoding hardware. Nerd perangkat keras akan melihat bahwa tindakan semua opsi dapat diimplementasikan dengan gerbang sederhana, seperti multiplexer.

33 bit instruksi dibentuk sebagai berikut:

format instruksi ZEBRA; gambar asli

Dari kiri untuk menulis Anda memiliki 15 "digit fungsi" yang merupakan bit kontrol yang secara independen menentukan apa yang dilakukan instruksi, alamat register lima bit, dan alamat memori 13 bit. Semua pengguna ZEBRA menghafal string AKQLRIBCDEV421W dan menyebutnya “alfabet Belanda”.

"Instruksi dasar"

Anda bisa melihat bit fungsi sebagai pengubah instruksi dasar, yang akan:

  • Tambahkan nilai register yang diberikan ke A.
  • Muat alamat memori yang diberikan di register C (secara efektif melompat ke alamat itu).
  • Tambahkan 2 ke nilai register C dan salin ke D: ini biasanya tidak penting, tetapi penting untuk instruksi A (lihat di bawah).

Notasi assembler: "kode normal"

"Bahasa perakitan" adalah bahasa khusus dengan hanya 32 karakter (digit, +, -, titik, dan sebagian besar huruf kapital). Program dikodekan pada pita kertas selebar 5 lubang.

Instruksi, seperti yang ditulis dalam bahasa rakitan, terdiri dari:

  • A atau X untuk menunjukkan apakah bit pertama hidup atau mati. Assembler menggunakan ini untuk melihat bahwa instruksi sebelumnya telah berakhir (karena tidak ada "end of line" atau bahkan ruang kosong pada kaset).
  • Huruf apa pun yang bit yang sesuai (disebut "digit fungsional") perlu disetel (lihat di bawah untuk arti huruf).
  • Sebuah alamat memori. Harus setidaknya tiga digit; tambahkan 0 jika diperlukan. Anda dapat menghilangkannya jika nol.
  • Nomor pendaftaran. Menghilangkan berarti nol.
  • Untuk memisahkan alamat memori dan nomor register, Anda dapat menggunakan titik, atau salah satu huruf fungsional.
  • Ada pengkodean khusus untuk fungsi huruf W, yang tidak tersedia: jika Anda menyebutkan nomor kedua setelah nomor register, ini berarti indikator pengulangan , dikodekan pada area alamat memori setelah dikalikan dengan -2. Bit W kemudian diatur. Untuk contoh artinya, lihat di bawah.

Operasi dasar "tambah dan lompat" dapat dimodifikasi dengan berbagai cara untuk menciptakan jumlah operasi yang luar biasa. Ini dijelaskan dalam bentuk "diagram fungsional" yang menunjukkan efek huruf secara visual yang indah. Gulir ke halaman terakhir “ garis besar desain fungsional komputer ZEBRA ” (archive.org) untuk melihat semua detailnya.

Mari kita mulai dengan dua bit fungsi pertama A dan K, yang menentukan instruksi selanjutnya :

  • A mengubah rute output drum ke ALU, bukan ke register C. Ini memungkinkan untuk membaca nilai data dari drum (yang ditambahkan ke nilai register dengan pre-adder). Register C kemudian diumpankan dari register D sebagai gantinya. Register D dibaca dari register 4.
    Ingatlah bahwa dalam instruksi non-A, C+2 ditulis ke D: jadi, setelah instruksi A, instruksi berikutnya dieksekusi dua kali lebih banyak dari instruksi sebelumnya, yang berarti ia dengan mudah melompat ke instruksi selanjutnya pada drum, jadi tidak ada penundaan. Yang membingungkan, ini menyiratkan bahwa instruksi sebelumnya dilakukan lagi. Van der Poel menyebut instruksi implisit ini "setelah instruksi". Seringkali instruksi boneka ditempatkan sebelum instruksi A untuk memastikan tidak ada kejutan.
    Butuh beberapa saat bagi saya untuk mengetahui cara menggunakan instruksi A.
  • K mengumpan register C dari nilai register (ditambahkan ke nilai memori atau register D, tergantung pada bit A). Ini berarti bahwa instruksi berikutnya dapat berupa jumlah dari dua nilai!
Efek bit A dan K

"Instruksi dasar" yang saya tunjukkan di atas adalah tipe X: register terhubung ke unit aritmatika, melakukan penjumlahan, dan drum terhubung ke unit kontrol, mendapatkan instruksi selanjutnya. Kombinasi lain memungkinkan untuk melakukan segala macam hal yang memerlukan instruksi terpisah pada prosesor "standar": memuat nilai dari memori, tabel lompat, ulangi instruksi, dan sebagainya.

Dalam bahasa modern Anda dapat mengatakan kira-kira: X berarti "tambah dan lompat", A berarti "muat dan tambahkan", K berarti "jalankan register", dan KA berarti "offset instruksi berikutnya dengan register".

(Apakah kamu masih bersamaku? Ini menjadi sedikit lebih mudah mulai sekarang, aku janji.)

Mari lanjutkan dengan bit fungsi yang tersisa, yang sedikit lebih mudah diikuti.

  • Q menambahkan satu ke register B, bahkan jika nilai lain ditambahkan ke B.
  • L menggeser isi A dan B ke kiri. Pergeseran dilakukan sebelum penambahan: nilai yang digeser ditambahkan ke register yang dipilih. Bit tinggi B digeser menjadi A, sehingga AB secara efektif diperlakukan sebagai register ganda 67 bit.
  • R menggeser isi A dan B ke kanan. Bit rendah A digeser ke B, jadi AB adalah register ganda lagi. Bit tinggi A berasal dari bit ke-34 tambahan A. Ini adalah satu-satunya cara untuk memiliki akses ke bit ini, yang secara efektif merupakan bendera "meluap" untuk A.
  • Saya membalikkan penjumlahan menjadi pengurangan: nilai dikurangi dari, bukannya ditambahkan ke, register. Ini juga mengubah Q menjadi pengurangan 1 dari B.
  • B menggunakan akumulator B bukan akumulator A. Carry akan disimpan di “carry trap”.
  • C menghapus akumulator yang digunakan (A atau B): artinya nilai yang dibaca dari register diganti dengan 0 dalam perhitungan. Dalam kombinasi dengan pergeseran, hanya akumulator lain yang digeser dan tidak ada pengangkutan bit di antara keduanya.
  • D menulis nilai dari A atau B ke drum di lokasi yang diberikan alih-alih membaca. Menulis nilai akumulator menulis nilai asli register.
  • E menulis nilai akumulator yang dipilih ke dalam register yang diberikan. Dalam kombinasi dengan K, nilai register D ditulis sebagai gantinya.
  • V menambahkan nilai carry trap ke register A. Dalam kombinasi dengan flag V lainnya, instruksi menjadi bersyarat.
  • V4, V2, V1 bergabung untuk membuat s digit 1–7 untuk instruksi bersyarat. Di assembler, Anda menulis V dengan atau tanpa digit setelahnya. Jika flag V jelas (ditulis sebagai U), instruksi dijalankan tergantung pada sakelar yang sesuai di panel depan (dan jika nilainya nol, jebakan pembawa digunakan, seperti yang disebutkan). Jika V diatur dan nilainya 1 sampai 4, instruksi dieksekusi pada salah satu dari empat kondisi berikut: A negatif, B negatif, A nol, atau B ganjil. Jika kondisi tidak benar, instruksi diganti dengan A0W.
  • W menonaktifkan drum, sehingga instruksi berikutnya segera dijalankan. Nilai yang Anda baca menjadi 0. Biasanya Anda menggabungkan ini dengan A atau K karena Anda akan mendapatkan nol sebagai instruksi sebaliknya. Ini digunakan dalam kombinasi dengan huruf lain untuk membuat instruksi berulang, seperti perkalian cepat (lihat di bawah), pembagian, dan membersihkan drum.

Kombinasi huruf tertentu memberikan fungsionalitas tambahan.

  • N adalah akronim assembler untuk kasus umum instruksi X yang melompat ke alamat drum berikutnya: jalankan instruksi berikutnya.
  • LR bergeser ke kanan, tetapi juga menambahkan R15 ke A (independen dari bit B) jika B ganjil. Ini digunakan untuk perkalian.
  • XD menambahkan R15 ke A atau B (bergantung pada bit B), digunakan untuk pembagian.
  • NKK digunakan untuk instruksi A yang menggunakan alamat berikutnya. (Efeknya ini adalah efek samping dari cara kerja assembler.)
  • KE menulis D ke register (yang merupakan instruksi sebelumnya +2). Anda dapat menggunakan ini untuk membuat instruksi bergantung pada alamat saat ini, misalnya untuk membuat subrutin kembali ke pemanggil: Anda dapat menghitung instruksi kembali yang melompat kembali ke pemanggil.
  • AK menggunakan drum untuk kalkulasi, sambil menjalankan instruksi dari register. Ini digunakan misalnya untuk membaca dua nilai dari drum dalam satu putaran.

Beberapa contoh untuk melihat bagaimana digit fungsional digabungkan satu sama lain. Sebagian besar contoh diambil dari dokumentasi asli, tetapi penjelasan di sini diterjemahkan ke dalam bahasa modern.

  • N : tidak ada operasi. Tepatnya: tambahkan 0 ke A saat membaca instruksi selanjutnya ke C.
  • NLBQ3: kalikan B dengan tiga dan tambahkan satu; kalikan A dengan 2.
  • X100BC5: salin register 5 ke B (hapus dan tambahkan), instruksi selanjutnya adalah 100.
  • X569LQK7: AB bergeser ke kiri, bergeser ke 1. Instruksi berikutnya adalah penjumlahan lokasi memori 569 dan register 7.
  • A2991.9: tambahkan lokasi memori 2119 + register 9 ke A. (Ini adalah contoh penggunaan pre-adder.) Instruksi berikutnya adalah instruksi sesudahnya.
  • X1956LBC3V4: Jika B ganjil, geser akumulator A ke kiri dan lanjutkan eksekusi di lokasi memori 1956. Jika tidak, ulangi instruksi sebelumnya (karena kondisi salah ganti register instruksi dengan A0W, yang melakukan itu). Bagaimanapun, B tetap sama, karena dibersihkan dan diisi dengan nilai lamanya.

ZEBRA memiliki layar, tetapi bukan untuk keluaran: digunakan untuk debugging. Itu menunjukkan empat rangkaian tanda hubung yang menunjukkan nilai register A, B, C dan register lain yang dapat dipilih dari beberapa register penting. Tidak ada keyboard, tetapi tombol telepon yang Anda putar untuk memasukkan angka. Subrutin khusus yang diizinkan untuk menggunakan nilai-nilai ini dalam suatu program.

Selebihnya ia dapat membaca dan menulis pita berlubang dan mencetak (jauh lebih lambat daripada pita dengan 7 karakter per detik; pita bacaan adalah 100 karakter per detik).

Kaset itu hanya memiliki 5 lubang per baris, yang berarti hanya ada 32 simbol yang tersedia untuk program. Assembler menggunakan rangkaian karakter yang diperkecil sehingga angka dan huruf yang diperlukan tersedia; surat-surat lain tidak ada di sana. Bahkan huruf W pun hilang: itulah salah satu alasan instruksi W dikodekan dengan cara khusus.

Untuk input dan output umum, kode Baudot (telex) digunakan, memungkinkan lebih banyak karakter (tetapi masih tanpa huruf besar dan kecil).

Terakhir, ada "pengukur efisiensi" di konsol yang menunjukkan persentase instruksi mana yang dijalankan tanpa penundaan. Tentu saja, cukup sulit untuk menulis sebuah program yang akan menjaga persentase tetap tinggi. Ingatlah bahwa untuk mendapatkan 100%, Anda harus memastikan bahwa setiap instruksi diikuti oleh instruksi selanjutnya pada drum, atau instruksi W, yang tentu saja hampir tidak mungkin.

Contoh pemrograman: perkalian

Untuk memberi Anda gambaran tentang semangat memprogram ZEBRA, berikut adalah program enam instruksi kecil untuk melakukan perkalian bertanda tangan dari register A dan B. Untuk tujuan penjelasan, mari kita asumsikan program ditempatkan di alamat 100.

  • 100 NE5 (dirakit sebagai X101E5): salin A ke register 5, lanjutkan ke 101.
  • 101 NKKCE15 (dirakit sebagai A102CE15): memuat A ke dalam register 15, memuat nilai pada 102 ke dalam A
  • 102 ALR (dirakit sebagai A0000LRW): instruksi untuk disimpan di R5.
  • 103 NKE6LRC (dirakit sebagai X104LRC6): langkah perkalian pertama.
  • 104 X5K15LR (dirakit sebagai X8162KLR5W): instruksi berulang.
  • 105 NLRI (dirakit sebagai X106LRI): pastikan rambu ditangani dengan benar.
  • NE5 : Instruksi ini, yang menyimpan nilai A ke dalam register 5, sebenarnya belum penting. Yang penting, pada instruksi berikutnya register D diisi dengan dua instruksi lebih dari ini, yaitu X103E5.
  • NKKCE15 : Pindahkan operan pertama dari register A ke register 15. Pada saat yang sama, muat instruksi berikutnya “ALR” ke dalam register A.
  • Setelah instruksi ini, register D dijalankan karena merupakan instruksi A. Ini menyimpan instruksi "ALR" ke dalam register 5, menghapus A, dan melanjutkan eksekusi pada instruksi di 103.
    (Singkatnya, tiga instruksi pertama menunjukkan cara memasukkan konstanta ke dalam register.)
  • ALR : instruksi ini tidak dieksekusi tetapi dimuat ke dalam register 5 untuk digunakan selama perkalian.
  • NKE6LRC : Lakukan tindakan LR khusus “geser AB ke kanan, dan tambahkan R15 ke A jika B ganjil”, yang merupakan langkah pertama perkalian. Salin nilai register D (yang sekarang bertambah menjadi X105E5) ke dalam register 6.
  • X5K15LR: melakukan langkah kedua dari instruksi. Instruksi selanjutnya ada di register 5. Perhatikan instruksi ini harus dibaca sebagai X8162KLRW5.
  • Instruksi selanjutnya ada di register 5: ALR. Lakukan langkah ketiga perkalian. Karena ini adalah instruksi A, yang berikutnya dua lebih banyak dari yang sebelumnya: X5K14LR (atau untuk menunjukkannya dua lebih banyak dari yang sebelumnya: X8164LRW5).
  • X5K14LR: lakukan langkah keempat perkalian
  • X5K1LR: lakukan langkah ke-30.
  • ALR: langkah perkalian ke-31. Alamat instruksi 8190 dilimpahkan ke nomor register, sehingga instruksi menjadi X000KLR6, atau dengan kata lain X6KLR.
  • X6KLR: langkah perkalian ke-32 dan terakhir. Instruksi selanjutnya adalah R6, yang berisi X105E5.
  • X105E5: menyimpan A ke dalam R5 (tidak digunakan untuk komputasi). Lanjutkan di 105.
  • NLRI: kurangi R15 dari A jika bit tanda B ditetapkan untuk mendapatkan hasil negatif; ini menangani perkalian bilangan negatif dengan konvensi komplemen dua.

Perhatikan bahwa langkah kedua hingga terakhir dari rutinitas perkalian adalah instruksi W, yaitu untuk tidak menunggu drum. Artinya, mereka dieksekusi saat drum berputar 31 posisi. Jadi drum melakukan putaran penuh, mulai dari 104, dan instruksi di R6 menyebabkan komputer mengeksekusi di posisi 106, yang menyebabkannya hanya menunggu dua instruksi untuk mengambil instruksi berikutnya. Oleh karena itu program membutuhkan 6 + 32 = 38 siklus untuk dijalankan.

Kode sederhana

Untuk mempermudah hidup orang, ada juga “kode sederhana” yang sedikit lebih mudah digunakan. Di sini perintahnya adalah huruf tunggal, (A untuk tambah, D untuk bagi, X untuk lompat, dll). Itu lebih mirip perakitan komputer saat ini. Itu memiliki angka floating point, variabel dan struktur loop sederhana, serta banyak fungsi matematika tingkat lanjut, seperti fungsi goniometrik dan eksponensial. Itu berjalan pada satu atau dua siklus drum per instruksi.

Sistem operasi

Dibutuhkan seorang jenius sejati untuk menulis perangkat lunak untuk mesin ini. Untuk menjalankan program, Anda dapat menggunakan tiga cara berbeda untuk menyediakan program:

  • Assembler yang mengumpulkan instruksi. Itu termasuk fungsi untuk menghitung alamat sehingga Anda dapat menulis kode yang dapat dipindahkan. Tidak ada label, tetapi Anda dapat mengidentifikasi alamat dengan angka kecil yang akan dihitung dan diisi pada waktu perakitan. Itu juga memungkinkan untuk menghitung jumlah dan perbedaan nilai (dan instruksi) pada waktu perakitan, yang sangat dibutuhkan karena instruksi ZEBRA sering dihitung sebagai jumlah nilai.
  • Kemungkinan untuk segera mengeksekusi instruksi rakitan. Opsi aneh ini memungkinkan untuk memulai program, atau menyesuaikan alamat ke mana rutinitas akan pergi. Anda juga dapat menghentikan rekaman untuk memasukkan nomor, misalnya, atau "menghubungkan" rutinitas bersama dengan membuat tabel lompatan. Sekali lagi, cara yang sangat sederhana untuk melakukan banyak tugas berbeda.
  • Penerjemah untuk "kode sederhana". Kode itu "dikompilasi" menjadi dua kata per instruksi kode sederhana. Penerjemah membaca kedua kata itu dan mengeksekusi potongan kode yang sesuai.
  • Rutin untuk membaca program biner. Dimungkinkan untuk membuat program biner yang dapat dimuat di berbagai tempat di memori, menggantikan beberapa fungsi penghubung kode objek saat ini.
  • Satu set rutin I/O untuk membaca dan menulis pita. Pita berlubang dapat berisi keluaran yang diformat untuk pencetakan luring. Mencetak jauh lebih lambat daripada meninju, jadi lebih efisien untuk meninju keluaran Anda dan mencetaknya secara offline.
  • Rutin matematika, seperti fungsi goniometrik dan eksponensial.
  • Rutinitas pengguna dapat ditambahkan dan disertakan dalam suatu program.

Karena tidak ada stack, subrutin menggunakan register untuk mengingat lokasi pemanggilan, menggunakan instruksi KE seperti yang dijelaskan di atas.

Sayangnya, saya tidak mengetahui semua detail sistem operasinya; yang saya tahu adalah dari reverse engineering, yang cukup sulit mengingat prosesor yang aneh.

Jenius pemrograman

Menulis semua ini dengan cara yang efisien membutuhkan kejeniusan sejati. Untuk membuat ceritanya semakin luar biasa, jenius ini berwujud ahli matematika tunarungu Gerrit van der Mey . Dia berhasil mengeluarkan fungsionalitas terakhir dari mesin ini, terlepas dari keunikannya. Sulit membayangkan bahwa dia dapat menulis kode itu, jika satu-satunya cara Anda dapat mengajukan pertanyaan kepadanya adalah perangkat kecil untuk menghasilkan simbol Braille untuk disentuhnya.

Gerrit van der Mey dengan anjing penglihatannya

Kode sumber sistem operasi tersedia, tetapi hampir tidak ada komentar; Saya mengetahui cara kerja assembler dan beberapa rutinitas I/O, tetapi kemudian saya harus menyerah karena menjadi terlalu rumit. Sangat menarik untuk melihat trik apa yang digunakan untuk mendapatkan semuanya seefisien mungkin. Saya bertanya-tanya apa yang terjadi di otak Gerrit ketika dia menulis ini.

Keramahan pengguna

Akibat keterbatasan teknologi, pemrograman menjadi cukup sulit. Jika Anda membuat kesalahan dalam program Anda, komputer akan macet. Tidak ada pemeriksaan sintaks, tidak ada debugger yang ramah pengguna, atau apa pun. Saat ini "meretas" beberapa kode dianggap sebagai praktik yang buruk; saat memprogram ZEBRA Anda tidak punya pilihan: bahkan program yang paling sederhana pun membutuhkan semua jenis konstruksi aneh untuk melakukan tugas yang paling sederhana.

Tapi tetap saja, bahasa pemrograman LISP dan ALGOL berjalan di atasnya. Saya tidak berpikir mereka akan cepat, meskipun.

Panggilan untuk sumber daya

Seluruh petualangan ini telah membawa saya ke banyak dokumen menarik, tetapi ada dua yang tidak dapat saya dapatkan. Jika Anda memiliki (versi PDF) salah satunya, beri tahu saya!

  • Manual Program Stantec Zebra, oleh Standard Telephones and Cables (London, Inggris).
  • Kode sederhana ZEBRA dan interpretasinya, oleh RJ Ord-Smith Ph.D.

Museum sejarah komputer

masyarakat konservasi komputer

Koleksi saya di archive.org

Halaman Bitbucket saya, yang perlu diperbarui . Ini berisi emulator ZEBRA yang berfungsi, tetapi GUI tidak berfungsi karena pustaka tkinter standar Python telah dimodifikasi. Agak membuat frustrasi betapa sulitnya menjaga agar bahan bersejarah tetap dapat digunakan!

Terima kasih telah membaca ini sampai akhir tentang desain yang menarik ini. Saya harap Anda sama terkejutnya dengan saya.