Програмистката, която прати хора на Луната

ян. 7, 2022 | Истории

Програмистката, която прати хора на Луната

7 януари 2022 | Истории

Иконична е тази снимка и според мен трябва да бъде задължителна част от обучението по софтуерно инженерство. Също така да се показва на всеки програмист, който се оплаква, че работата му е трудна. На кадъра е д-р Маргарет Хамилтън, шефката на екипа, създал софтуера, с който „Аполо 11“ се отправя към нощното ни светило. Мисията ще отведе първите хора на Луната през 1969 г.

А каква е тази огромна купчина хартия? Именно това е компютърният код, написан от Маргарет и екипа ѝ. Те успяват с примитивните тогавашни технологии да познаят какъв проблем би могъл да спре „голямата стъпка на човечеството“ и го предотвратяват.

Нещо повече. Приема се, че момичето на снимката е и създател на термина „софтуерно инженерство“.

Какво ли е да отговаряш за софтуера на архаични компютри, от който обаче зависи оцеляването на първите хора, които ще стъпят на земния спътник?

 

Маргарет Хамилтън

 

Цвете от Луната

Днес животът на редовия програмист е светлинни години по-лесен, имаме наготово огромни платформи, а след тях и библиотеки, на гърба на които да се катерим.

При младата мисис Хамилтън нещата изгледат доста различно. Родена през 1936 г., тя от малка си пада по математиката и се дипломира в Мичиганския университет през 1958 г. Баща ѝ е философ и поет, дядо ѝ – писател, учител и висш протестантски проповедник, тях двамата тя посочва като свои вдъхновители.

За кратко преподава математика и френски в гимназия, докато чака съпругът ѝ да завърши, срещнала го е в гимназията. Скоро той също има висше, а двамата заедно – малка дъщеря на име Лорън.

Местят се в Бостън, където той си намира работа. Маргарет е заминала с идеята да продължи с докторантура, но… ѝ се налага да почака. Трябва да започне работа, за да помогне на семейния бюджет, нещо доста нетипично за млада майка по онези времена.

Работи за кратко в метеорологична програма към MIT, после се насочва към проект на военновъздушните сили, чиято цел е да идентифицира вражески изтребители.

 

Луната спи

„Трябваше да си намеря работа и така попаднах в лабораторията, която се водеше от проф. Едуард Лоренц, създателя на Теорията на хаоса. Работех върху система за прогнозиране на времето. Той търсеше математици, които да се учат на софтуерна разработка. Тук научих какво е компютърът и как се създава софтуер“, спомня си тя.

Тъкмо тогава, през 1963 г., когато тя планира отново да се върне към докторантурата си, вижда обявата, че се търсят компютърни специалисти в лаборатория отново към MIT, която обаче ще работи по проекта за изпращане на първите хора на Луната. Ще създава софтуера за следващите мисии „Аполо“.

Маргарет решава, че няма как да пропусне такъв шанс.

Веднага се обажда на телефона, посочен в обявата, само за няколко часа си уговаря срещи с двама от мениджърите, които познава от предишната си работа. Предлагат ѝ позицията в един и същи ден. Тя не иска да откаже на някой от двамата, предлага им да хвърлят монета, за да видят къде ще отиде тя. Печели този, който отговаря за софтуерната част и тя още на следващия ден започва работа.

 

Маргарет Хамилтън

 

Лунната соната

Маргарет е първият програмист в екипа и първата жена там. По това време в проекта вече работят голям брой компютърни специалисти и математици, но всички те отговарят за хардуера. Скоро в екипа на Маргарет вече има около 100 софтуерни инженери (които дори още не знаят, че така се нарича професията им). А тя официално застава начело през 1965 г.

„По това време софтуерът беше пълна мистерия, черна кутия за мениджърите. Затова ни дадоха пълната си вяра и доверие, имахме невероятния късмет да сме на правилното място в правилното време“, спомня си тя.

„Нямахме откъде да учим. Работехме в поле, което едва се появява. Нямахме друг шанс, освен да бъдем пионери. Но колкото по-голямо беше предизвикателството, толкова по-забавно ни беше, както е нормално за хлапета на по 20 и няколко години“.

„Нашият софтуер трябваше да е свръхнадежден, да е способен да улавя грешките и да се възстановява от тях във всеки един момент на мисията“, спомня си тя.

Едно от най-важните неща, които трябва да се планират, е в критичните моменти преди кацането компютърът да не бъде претоварен. Днес браузърът ни „яде“ оперативна памет като гладен змей, при това тя се измерва с десетки гигабайти, а тогавашният космически компютър има на разположение… 72 килобайта в своеобразния си „харддиск“ и едва 10-ина килобайта оперативна памет.

 

Маргарет Хамилтън

 

Лунатици

20 юли 1969 г. Модулът за прилуняване „Игъл“ се отделя от командния – „Колумбия“, и се отправя на единствената си мисия.

Точно преди да започне ключовият етап на кацането, към компютъра, контролиращ модула, политат десетки различни команди. Ситуацията е критична. Ако софтуерът не е подготвен да ги приоритизира, машината може да спре да изпълнява указанията и кацането да стане невъзможно.

Нашата героиня и екипът ѝ обаче са предвидили този риск.

Софтуерът е подготвен да разпознае кога го карат да изпълни повече операции, отколкото би могъл. В такава ситуация той изпраща знак на астронавтите, че нещо не е наред и е претоварен.

И не само. Екипът софтуерни инженери, които още не знаят, че са такива, са създали самовъзстановяваща се програма. В такъв режим компютърът спира маловажните задачи и продължава да изпълнява само ключовите. Именно това се случва малко преди кацането на модула „Игъл“. Наземният контрол и астронавтите се доверяват на преценката му.

„Софтуерът беше направен така, че не просто да съобщава, че има проблем, свързан с хардуера, но и да се опита да го преодолее“, казва Маргарет. „За щастие, му се довериха и само след 30 секунди се чу Нийл Армстронг да казва: „Игъл“ кацна“.

 

Маргарет Хамилтън

 

Подлуняване

По това време Маргарет е начело на екипа, занимава се с професия, която още не съществува. И е само на 32.

След „Аполо“ част от кода е използвана за изпращането на „Скайлаб“ – първата орбитална станция, а после и в совалките.

А как ли изглежда софтуерът в онези времена?

Писането на код започва на големи листове хартия. Човек, наричан перфоратор, на базата на написаното създава перфокарти – картонени листове с дупки на определени места.

След като е проверено, че всичко е наред, кодът се изпраща във фабрика, където вече е трансформиран във вида, в който го ползват пракомпютрите. Медните проводници и магнитите се нанизват на дълга тел, която „помни“ нулите и единиците по доста примитивен начин: минавайки през силен магнит, те се разделят според поляризацията си.

 

Кодът на „Аполо“

Част от компютърния код, създаден от Маргарет и екипа ѝ.

 

Месечина, йо и йо

Едно от най-сериозните предизвикателства е софтуерът да бъде подготвен за всякакви възможни проблеми. Много време ще измине, преди на сцената на софтуерния бранш да се появят специалистите в тестването, но в тази роля влиза дъщерята на Маргарет.

Тя често взема със себе си Лорън, когато ѝ се налага да работи вечерите и уикендите.

„Един ден отново беше с мен, тъкмо бях пуснала симулацията на полета до Луната. Тя много обичаше да ме имитира, като си играе на астронавт. Започна да натиска случайни копчета и симулаторът се включи. После натисна още няколко и всичко заби. Беше стартирала програмата, която трябва да се пусне преди излитането, а уж ракетата вече беше по пътя си към Луната. Цялата памет на компютъра беше заета с настоящата задача и той блокира.

Помислих си: „Боже, ами ако това се случи по време на истинска мисия!“. Веднага предложих на екипа да направим така, че програмите да могат да се пускат само в точния етап, за който са предвидени“.

Шефовете ѝ отвръщат, че това е пълна глупост, защото селектираните, прецизно тренирани астронавти никога не биха могли да направят подобна грешка. Междувременно още на следващата мисия – „Аполо 8“, се случва точно същото. „Това доведе до големи поразии, трябваше да променяме много неща в движение, но едва тогава ми позволиха да направя промяната“.

 

Компютърът на „Аполо“

Така изглежда единият от компютрите в мисията „Аполо“.

 

Ясен месец веч изгрява

„Първите езици, на които програмирах, бяха 16-ични и двоични“, разказва Маргарет. „Пишеш код от нули и единици. Попаднах на добри учители и се научих как по този начин да давам оптимални команди, така че тогавашният хардуер да успее да се справя колкото може по-добре. С помощта на учителите си създадох нещо, което може днес да се нарече „мини операционна система“.

„Размерът на компютрите, с които аз и колегите ми работехме преди „Аполо“, варираше от огромен – с размера на стая, до такъв като цял склад“, разказва Маргарет. Когато се включва в лунната мисия обаче, трябва да подготвя програмата на два значително по-малки, почти идентични компютъра. Направо лаптопи, тежащи само по около 30 килограма

„Аполо 11“ има два компютъра на борда си, почти идентични. Единият се намира в „Колумбия“, а другият – в „Игъл“.

 

Между две луни

„Докато работех по програмата за търсене на вражески самолети, за първи път ми стана интересна темата за надеждността на софтуера. Когато компютърът просто спре по средата на изпълнението на твоя код, това няма как да бъде скрито. Светлините мигат, алармите пищят отвсякъде. Това ме караше да опитвам да предвидя къде може да изникне проблем“, разказва Маргарет.

Дебъгването е същинско приключение. „Единствената информация, която компютърът даваше на програмиста, беше регистърът, който да ти посочи частта от паметта, където програмата се е забавила.“

„Другият вариант беше просто да слушаш. Когато програмата вървеше нормално, компютърът звучеше като прибоя на красив плаж. Така го и наричахме, „звука на прибоя“. Случваше ми се да се обади посреднощ някой от операторите и да ми каже, че нещо не е както трябва, защото „вече не чувам прибоя“. Така се появи още един начин на дебъгване“.

 

Маргарет Хамилтън

 

Обратната страна на Луната

Каква е истината за прословутата снимка с „огромните папки софтуер“. Е, донякъде днес бихме ги нарекли пиар. Да, разбира се, това не е точно кодът, който е използван в „Аполо 11“.

За снимката фотографът на MIT идва в лабораторията на Маргарет и я кара да събере всички работни папки, които намира. После кадърът е разпратен до медиите, веднага след успешното кацане на Луната, със съответния текст. Реалният код, използват от двата компютъра на „Аполо“, е с „височина“ около 1/10 от този на снимката.

Всяка от отделните папки на снимката съдържа код, подготвен за машините на борда на някоя от мисиите „Аполо“. Една подобна папка „захранва“ с команди компютъра в лунния модул, а друга – този в командния.

 

Маргарет Хамилтън

Маргарет през 1995 г.

 

 

Лунички

Дали наистина Маргарет Хамилтън е автор на термина „софтуерно инженерство“? Трудно е да се каже, но със сигурност е помогнала много за това той да се превърне в истина.

По онова време инженерството се смята за сериозна наука, а софтуерът все още е по-скоро измислица, нещо шеговито за „сериозните инженери“.

Когато тя започва да се занимава със софтуер, все още няма термин, който да описва тази професия, нито пък тя се учи някъде. Много скоро, през 70-те години това рязко ще се промени.

В първите дни на проекта софтуерът наистина не се взема особено насериозно на фона на другите инженерни дисциплини. „Работехме с много комплексни системи, но никой не смяташе, че това, което правим, е сериозна наука и ключова задача. От отчаяние един ден отидох при другите водещи хардуерни специалисти им казах: „Хей, и ние сме инженери!“.

Дълго време след това те ми го повтаряха като шега. Докато един ден, по време на среща на целия екип, един от най-големите хардуерни гурута в екипа обясни пред всички, че всъщност е напълно съгласен с мен. Процесът по изграждане на софтуер също трябва да бъде приет за инженерна дисциплина, точно както хардуера. Беше наистина паметен момент!“, спомня си Маргарет.

Така се оказва, че очевидно твърдението не е преувеличено и тя е човекът, въвел термина, с който днес се кичат програмистите.

 

Маргарет Хамилтън

Маргарет Хамилтън получава президентската награда от Барак Обама през 2016 г.

 

Луноход, ход

Какъв ли най-важен съвет дава д-р Хамилтън днес на младите програмисти? Да не се ограничават само с „ученето“ на код. „Вярвам, че е също толкова важно да се учат и да имат досег с неща като музиката, изкуството, философията, лингвистиката. И, разбира се, математиката и логиката. Смятам, че всяка от тези области може да помогне в изграждането на един отличен програмист и на човек, умел в решаването на различни проблеми.“

Много изследователи забелязват, че дълги години софтуерният екип и Маргарет почти не са споменавани в спомените и историческите документи на мисията. През годините тя се занимава с различни софтуерни проекти, основава и своя компания, „Хамилтън Текнолъджис“ работи по проекти в областта на системно инженерство. Най-накрая стига и до докторантурата. Публикува над 130 научни статии, участва в проекти и конференции. Така или иначе, тя не постига някакви зашеметяващи успехи в тази област, които да привлекат вниманието на медиите и обществото.

Момичето до планината от код влезе с трясък и с пълна сила във фокуса на прожекторите през 2016 г., когато Барак Обама я награди с президентския медал на свободата, който оттогава не е връчван на никого. Тя стана толкова популярна, че година по-късно „Лего“ ѝ посвети сцена в специалната си колекция за жени изследователки, а „Гугъл“ я почете, като с помощта на 100 000 огледала от слънчевата обсерватория в пустинята Мохаве изрисува образа ѝ.

А гледката наистина е впечатляваща:

Луна президент

Да, немалко специалисти са на мнение, че приносът ѝ е преувеличен през последните години. Изведен е на преден план и се използва точно тогава, когато на мода идват идеите за половото равенство. А заради знаменитата си снимка тя е подходящ медиен продукт, който да привлича внимание.

И все пак, където и да е истината… планината от код, която си е свършила работата в точния момент, не може да бъде подложена на съмнение. А, особено ако и вие професионално се занимавате със софтуер, със сигурност си струва да си я припомните следващия път, когато „забиете“ в решаването на някоя задача и ви се иска физически да се саморазправите с компютъра…

Маргарет Хамилтън

В чест на Маргарет е създадена и лего колекция

 

Дигитални истории

Дигитални истории е и ще си остане изцяло некомерсиално начинание, на което посвещавам доста време и усилия. За създаването на сайта обаче са нужни определени разходи. Ако имате възможност и желание да подпомогнете сайта, вече можете да го направите. Разбира се, все така важна подкрепа си остава всяка добра дума, всяко споделяне на темите.

<a href="https://karamanev.me/author/georgik" target="_self">Георги Караманев</a>

Георги Караманев

Програмист, журналист и писател. Още за мен – тук.
Дигитални истории

Най-нови публикации:

Дете или ИИ? Успяха ли 4000 души да различат автора?

Дете или ИИ? Успяха ли 4000 души да различат автора?

Детска рисунка или ИИ? Експериментът привлече огромен интерес. В теста дали ще различим 15 рисунки на деца под 11 г. от 15 изображения, създадени от изкуствения интелект, се включиха почти 4000...

повече информация
Грешки (не)човешки

Грешки (не)човешки

Статията се препубликува от Тоест. Тя е част от рубриката Порция език и е подготвена съвместно с Павлина Върбанова.   Има ли грешка, има и прощка. Ако сте открили нещо нередно тук, значи и вие...

повече информация
Тест: Ще различите ли ИИ глас от човешки?

Тест: Ще различите ли ИИ глас от човешки?

Можете ли да си представите глас, неразличим от човешкия, който да чете новините? Или да ви се обади по телефона, без да има никакъв шанс да го различите? Не говорим за популярното решение гласът да...

повече информация

Още публикации по темата:

От рубриката:

Питър Тийл. Консервативният визионер

Питър Тийл. Консервативният визионер

Facebook, SpaceX, Airbnb, LinkedIn, PayPal, Ethereum. Революцията на OpenAI и ChatGPT, възходът на Доналд Тръмп и вездесъщия му (доскорошен) съюзник Илон Мъск.
Наистина ли има една личност, която събира всички тези явления? Нещо повече – не е преувеличено да се каже, че ако не беше днешният ни герой, надали някое от тях щеше да се претвори в реалност…
Питър Тийл си е спечелил името на пророк, на гуру. На големия визионер на технологичните времена. Докато в същото време има толкова противоречиви възгледи, които някак си остават встрани от големия медиен шум. Но това е типично за родения в Германия предприемач. Някои го приемат за сивия кардинал на Силициевата долина, други – за мъдрец, който може да покаже на всеки пътя към големия успех в технологичната епоха.
Мултимилиардер, той казва, че конкуренцията е измамно благо, а монополите са решението на бъдещето. Създава мащабна програма, за да помага на хора, избрали да изоставят образованието си, за да създадат собствен бизнес, което пък проправя пътя на следващото поколение технологични лидери.
Всичко това и още много е г-н Тийл. Време е да застане под светлината на прожекторите, защото със сигурност е един от хората, които вече са променили живота на всеки от нас. Нещо повече – от него се очаква да зависи все повече в турболентните технологични времена, в които живеем.

повече информация
Какъв ще станеш, когато пораснеш?

Какъв ще станеш, когато пораснеш?

Какви искат да бъдат, когато пораснат, днешните хлапета? Навръх техния празник, време е за резултатите от една любопитна анкета.
Поредицата на Дигитални истории за срещата на децата с технологиите събра важни гледни точки по много теми. От 350 души, включили се в анкетата на сайта, 289 избраха да отговорят:
Какви искат да станат децата, когато пораснат?
„Инфлуенсър“ или „лекар“ – кой според вас ще се окаже най-срещаният отговор?
Как се променят мечтите на хлапетата?
Какво говори това за нас, възрастните, за технологиите, за духа на времето?

повече информация
Тест: Кой го нарисува – дете или ИИ?

Тест: Кой го нарисува – дете или ИИ?

Време е за неочакван, но важен тест. За експеримент, който поставя важни въпроси за бъдещето на творчеството, на човешкото, на образованието.
Предизвикайте себе си и своята интуиция! 15 картини, нарисувани от деца между 3 и 10 г., и 15 – генерирани от изкуствения интелект. Ако успеете да ги различите, очакват ви награди!
Отговорите се събират до 1 юли, анкетата не би ви отнела повече от 10 минути. За всяко от 30-те изображения е достатъчно да предположите дали е нарисувано от дете, или генерирано от ИИ, а също и да оцените техниката и въображението, вложени в първите 10. Можете да отговорите и само на част от въпросите. Анкетата е отворена и за деца!

повече информация

Най-новите:

Дете или ИИ? Успяха ли 4000 души да различат автора?

Дете или ИИ? Успяха ли 4000 души да различат автора?

Експериментът „Детска рисунка или ИИ?“ привлече огромен интерес! За месец и половина въпросникът, в който се опитваме да различим 15 истински рисунки на деца под 11 г. от изображения, създадени от изкуствения интелект, беше попълнен от почти 4000 души! Време е да обобщим резултатите. Успяхме ли да се справим с предизвикателството? Истинските или генерираните рисунки се оказаха по-лесни за разпознаване? Трудна ли се оказа задачата, или почти всеки успя да познае и 30-те възможности? Дали самите деца се оказаха по-точни в преценката си? Защо изводите са важни? Време е за прелюбопитните изводи.

повече информация
Грешки (не)човешки

Грешки (не)човешки

Във времената, когато все по-малко медии и дори издателства се доверяват на специалисти, които да следят за правописа, дали пък изкуственият интелект (ИИ) няма да се окаже полезен помощник? Време е за един показателен правописен експеримент с участието на някои от най-мощните съвременни модели.
Всички (надяваме се) вярваме, че по правописа, а не по дрехите днес посрещат онлайн. В технологичната епоха общуваме все по-често чрез писмени текстове и начинът, по който го правим, определено издава толкова много на събеседника. Може ли ИИ да ни помогне да пишем грамотно?

повече информация
Тест: Ще различите ли ИИ глас от човешки?

Тест: Ще различите ли ИИ глас от човешки?

6 аудиозаписа, в които е произнeсена кратка фраза. Някои от тях са генерирани от ИИ, другите са истински човешки гласове. Ще ги различите ли?
Включете се до 1 август 2025 г. и при 6 правилни отговора участвате в жребия за скромен подарък.
Ще познаете ли кой глас е на човек и кой – на машина? Ръкавицата е хвърлена!

повече информация
Кой говори – човек или алгоритъм?

Кой говори – човек или алгоритъм?

Не е новина, че ИИ генерира изображения и текстове, които (проверено!) не могат да бъдат различени от създадените от човека. Видеото като че ли все още изостава, но… Можете ли да си представите глас, неразличим от човешкия, който да чете новините? Или да ви се обади по телефона, без да има никакъв шанс да го различите? Не говорим за популярното решение гласът да бъде клониран, а за напълно изкуствено създаден, който обаче е толкова убедителен. При това на чист български, който е почти невъзможен за човек, чийто роден език не е!
Време е за една звучна Дигитална история. А какво предизвикателство ви очаква след това…

повече информация
Колко изкара ИИ на матура?

Колко изкара ИИ на матура?

Какво ще стане, ако изпитаме на матурата по български език и литература три от най-мощните модели изкуствен интелект? Усилията им ще оценят двама опитни проверители на истинските зрелостни изпити. За да е състезанието още по-оспорвано и показателно, включваме двама реални зрелостници и мен, автора на тези редове.
Ще изкарат ли пълни шестици ChatGPT, Claude и Gemini, или ще се провалят с гръм и трясък?
Ще разпознаят ли учителите коя от работите е на изкуствен интелект и коя – на човек?
Кой ще получи най-високата и кой – най-ниската оценка?
Какво ще ни кажат резултатите и за най-показателния изпит в българското образование, и за напредъка на алгоритмите, и за големите въпроси, с които идват новите технологии?

повече информация
„Хайде да спрем да се подценяваме!“

„Хайде да спрем да се подценяваме!“

Как да сме по-щастливи като общество? Как да изведем на следващо ниво ИТ сектора в България?
Седнали двама програмисти да си говорят за счупения обществен разговор, за разделението, за пътя на успеха. Звучи като начало на виц, а се получи сериозно и замислящо интервю в подкаста на DEV.BG. Думите, които разменихме, ми се сториха толкова важни, че ще ви ги представя и тук.
Веско Колев е начело на Icanpreneur – стартъп, който помага на повече ИТ компании да създадат работещ продукт. Има богат опит в софтуерния свят и особено интересни наблюдения, с които ще се срещнем днес.
Защо и как е време отново да започнем не само да се слушаме, но и да си говорим, дори когато ни разделя актуалният спор на деня? Защо е изграждащо и осмислящо честото „настъпване на мотиката“ и си струва да се радваме, когато детето ни получи слаба оценка? Какво ни е нужно като общество, за да вървим заедно напред, и то в епохата на напредналия изкуствен интелект?

повече информация
Share This