Beendet Deep Learning die Bildverarbeitung / das Computer-Sehen?

52

Ich freue mich darauf, einen MSc in Signal- und Bildverarbeitung zu machen, oder vielleicht Computer Vision (ich habe mich noch nicht entschieden), und diese Frage tauchte auf.

Mein Anliegen ist, dass Deep Learning keine Feature-Extraktion und fast keine Vorverarbeitung von Eingaben erfordert. Beendet es die Bildverarbeitung (oder die Signalverarbeitung im Allgemeinen)?

Ich bin kein Experte für vertieftes Lernen, aber es scheint sehr gut bei Erkennungs- und Klassifizierungsaufgaben zu funktionieren, bei denen Bilder direkt anstelle eines Merkmalsvektors wie bei anderen Techniken aufgenommen werden.

Gibt es einen Fall, in dem ein traditioneller Ansatz zur Merkmalsextraktion und -klassifizierung unter Verwendung von Bildverarbeitungstechniken besser wäre, oder liegt dies am tiefen Lernen?

Tony
quelle
3
Wiedereröffnung, weil es eine hohe Anzahl von positiven Stimmen hat und die Antwort mit den meisten Stimmen eine sehr hohe Anzahl von positiven Stimmen hat.
Peter K.
1
@LaurentDuval Ich denke, jede Antwort war hilfreich und sehr interessant, aber vor allem Ihre und Kathreadler (zusammen mit der Diskussion, die auftauchte) haben das Thema wirklich klargestellt.
Tony
2
Ich möchte in der laufenden Diskussion einen Scheideweg nehmen. Wer hat gesagt, dass Deep Learning keine Feature-Extraktion erfordert? Nach meiner eigenen praktischen Erfahrung sollten wir DNN nicht für Rohdaten trainieren. Wir müssen einige Features extrahieren und müssen auch ein grundlegendes Verständnis des Bildes besitzen. Deep Learning sollte mit Vorsicht angewendet werden, es ist jedoch auch eine gute Idee.
Arun Raj

Antworten:

45

Dieser Beitrag wurde viel aktualisiert. Oben sehen Sie Link-Updates. Nachfolgend Variationen der ersten Antwort. Für die Kurzfassung: Erfolge von Faltungsnetzwerken und Deep Learning sehen wie eine Art galiläische Revolution aus. Aus praktischer Sicht sind klassische Signalverarbeitung oder Computer Vision tot ... vorausgesetzt, Sie haben genügend beschriftete Daten, kümmern sich nicht um offensichtliche Klassifizierungsfehler ( tiefe Fehler ), haben unendlich viel Energie, um Tests durchzuführen, ohne über den CO2-Fußabdruck nachzudenken . und kümmere dich nicht um rationale Erklärungen. Bei den anderen haben wir über alles nachgedacht, was wir zuvor getan haben: Merkmalsextraktion, Optimierung (vgl. Meine Kollegin J.-C. Pesquet, Arbeiten zur Lösung variationaler Ungleichungen durch tiefe neuronale Netzwerkstrukturen)), Invarianz, Quantifizierung usw. Und daraus ergibt sich eine wirklich interessante Forschung, die hoffentlich fest verankerte Prinzipien und ähnliche Leistungen aufholt.

Aktualisierte Links:

Wir stellen Beispiele für natürliche Kontroversen vor - reale, nicht modifizierte und natürlich vorkommende Beispiele, bei denen sich die Genauigkeit des Klassifikators erheblich verschlechtert. Wir kuratieren 7.500 Beispiele von natürlichen Gegnern und veröffentlichen sie in einem ImageNet-Klassifikator-Test, den wir ImageNet-A nennen. Dieser Datensatz dient als neue Methode zur Messung der Robustheit von Klassifikatoren. Wie l_p-Adversarial-Beispiele werden ImageNet-A-Beispiele erfolgreich auf unsichtbare oder Black-Box-Klassifikatoren übertragen. Beispielsweise erreicht ein DenseNet-121 auf ImageNet-A eine Genauigkeit von ca. 2%, was einem Genauigkeitsverlust von ca. 90% entspricht. Das Wiederherstellen dieser Genauigkeit ist nicht einfach, da ImageNet-A-Beispiele tiefe Fehler in aktuellen Klassifizierern ausnutzen, einschließlich ihrer übermäßigen Abhängigkeit von Farbe, Textur und Hintergrundinformationen. Wir stellen fest, dass beliebte Trainingstechniken zur Verbesserung der Robustheit nur geringe Auswirkungen haben. Wir zeigen jedoch, dass einige architektonische Änderungen die Robustheit gegenüber natürlichen Gegnern erhöhen können. Zukünftige Forschungen sind erforderlich, um eine robuste Verallgemeinerung dieses harten ImageNet-Testsets zu ermöglichen.

Weiterführende Informationen zur Signal- / Bildverarbeitung finden Sie unten. Michael Elad hat gerade Deep, Deep Trouble geschrieben: Deep Learning's Impact auf Bildverarbeitung, Mathematik und Humanität (SIAM News, 2017/05), Auszug:

Dann kehrten neuronale Netze plötzlich und mit aller Macht zurück.

Diese Tribüne ist von Interesse, da sie eine Verschiebung von der traditionellen "Bildverarbeitung", bei der versucht wird, die Daten zu modellieren / verstehen, zu einem Bereich der Korrektheit ohne so viel Einsicht zeigt.

Diese Domain entwickelt sich sehr schnell. Dies bedeutet nicht, dass es sich in eine beabsichtigte oder konstante Richtung entwickelt. Weder richtig noch falsch. Aber heute morgen hörte ich das folgende Sprichwort (oder ist es ein Witz?):

Ein schlechter Algorithmus mit einer großen Menge von Daten kann eine bessere Leistung erbringen als ein intelligenter Algorithmus mit Pauce- Daten.

Hier war mein sehr kurzer Versuch: Tiefes Lernen kann zwar hochmoderne Ergebnisse liefern, aber man versteht nicht immer, warum und ein Teil unserer wissenschaftlichen Arbeit besteht darin, zu erklären, warum Dinge funktionieren, was der Inhalt eines Datenstücks ist , usw.

Deep Learning erfordert (riesige) Datenbanken mit guten Tags. Jedes Mal, wenn Sie an einzelnen oder einzelnen Bildern basteln (dh ohne eine riesige Datenbank dahinter), insbesondere an Orten, an denen es unwahrscheinlich ist, dass "freie benutzerbasierte markierte Bilder" entstehen (im Ergänzungssatz des Sets " Lustige Katzen, die Spiele und Gesichter spielen "). Sie können sich eine Weile an die traditionelle Bildverarbeitung halten und profitieren. Ein kürzlich veröffentlichter Tweet fasst Folgendes zusammen:

(viele) gekennzeichnete Daten (ohne fehlende Variablen) sind für viele Domains ein Deal Breaker (und unnötig)

Wenn sie getötet werden (was ich kurzfristig bezweifle), sind sie noch nicht tot. Jede Fähigkeit, die Sie in den Bereichen Signalverarbeitung, Bildanalyse und Computer Vision erwerben, wird Ihnen in Zukunft helfen. Dies wird zum Beispiel im Blogbeitrag diskutiert: Haben wir Geometrie in Computer Vision vergessen? von Alex Kendall:

Deep Learning hat das Computer-Sehen revolutioniert. Heutzutage gibt es nicht viele Probleme, bei denen die leistungsstärkste Lösung nicht auf einem durchgängigen Deep-Learning-Modell basiert. Insbesondere Faltungs-Neuronale Netze sind beliebt, da sie in der Regel recht gut funktionieren. Bei diesen Modellen handelt es sich jedoch größtenteils um große Blackboxen. Es gibt viele Dinge, die wir nicht verstehen.

Ein konkretes Beispiel kann folgendes sein: Ein paar sehr dunkle (z. B. Überwachungs) Bilder vom selben Ort, die ausgewertet werden müssen, ob eine dieser Bilder eine bestimmte Änderung enthält, die erkannt werden sollte, sind möglicherweise mehr als eine Frage der herkömmlichen Bildverarbeitung Deep Learning (Stand heute).

Auf der anderen Seite kann Deep Learning, so erfolgreich es auch in großem Umfang ist, zu einer Fehlklassifizierung kleiner Datenmengen führen, die für einige Anwendungen "im Durchschnitt" harmlos sein kann. Zwei Bilder, die sich nur geringfügig vom menschlichen Auge unterscheiden, können über DL unterschiedlich klassifiziert werden. Oder zufällige Bilder können auf eine bestimmte Klasse eingestellt werden. Sehen Sie zum Beispiel, dass tiefe neuronale Netze leicht zu täuschen sind: Hochzuverlässige Vorhersagen für nicht erkennbare Bilder (Nguyen A, Yosinski J, Clune J. Proc. Computer Vision und Mustererkennung 2015), oder weist Deep Learning tiefe Fehler auf? , auf kontroversen Negativen:

Das Netzwerk kann ein Bild falsch klassifizieren, nachdem die Forscher eine bestimmte nicht wahrnehmbare Störung angewendet haben. Die Störungen werden durch Anpassen der Pixelwerte ermittelt, um den Vorhersagefehler zu maximieren.

Denken Sie bei allem Respekt vor "Deep Learning" an "Massenproduktion als Reaktion auf ein registriertes, bekanntes, massenvalidierbares oder erwartetes Verhalten" im Vergleich zu "einzigartigem Handwerk". Keiner ist (noch) besser in einer einzelnen Indexskala. Möglicherweise müssen beide für eine Weile nebeneinander existieren.

Tiefes Lernen durchdringt jedoch viele neue Bereiche, wie in den nachstehenden Referenzen beschrieben.

Glücklicherweise versuchen einige Leute, mathematische Gründe für tiefes Lernen zu finden. Ein Beispiel dafür sind Streunetzwerke oder Transformationen, die von Stéphane Mallat und Mitautoren vorgeschlagen wurden. Weitere Informationen finden Sie auf der ENS-Website . Oberschwingungsanalyse und nichtlineare Operatoren, Lipschitz-Funktionen, Translations- / Rotationsinvarianz, besser für den durchschnittlichen Signalverarbeiter. Siehe zum Beispiel Grundlegendes zu Deep Convolutional Networks .

Laurent Duval
quelle
1
Das Erweitern unzureichender Trainingsdaten mit entsprechend modifizierten Kopien hilft beim Verallgemeinern des Tiefenlernens. In letzter Zeit wurden Wege gefunden, um die Notwendigkeit einer vollständigen überwachten Kennzeichnung zu umgehen : Durch die unüberwachte Datenerweiterung werden automatisch Etiketten für den unbeschrifteten Teil der Trainingsdaten beim teilüberwachten Lernen erstellt und diese Daten für das Training verwendet. (Fühlen Sie sich frei, diese oder ähnliche Informationen in die Antwort aufzunehmen.)
Olli Niemitalo
1
Wenn Sie wissen, wie man "konsequent" steigert. OK bei den klassischen Datensätzen, ich gehe immer noch auf den wissenschaftlichen Daten herum, die ich behandeln werde (Geologie, Chemie)
Laurent Duval
@Laurent, zu dem, was Sie gesagt haben: "Unsere Aufgabe als Wissenschaftler besteht darin, zu erklären, warum die Dinge funktionieren" : Klingt so, als ob Data Science eine gültige Karriere für jemanden ist, der ernsthaft an DSP arbeitet. Gibt es noch andere Namen als den typischen "DSP-Ingenieur" -Titel, von dem Sie gehört haben?
JFonseca vor
21

Erstens gibt es nichts auszusetzen, wenn man grad in Bildverarbeitung oder Computer Vision arbeitet und Deep Learning einsetzt. Deep Learning ist kein Mord an Bildverarbeitung und Computer Vision, sondern lediglich das aktuelle Forschungsthema in diesen Bereichen.

Zweitens wird Deep Learning hauptsächlich zur Erkennung von Objektkategorien verwendet. Dies ist jedoch nur einer von vielen Bereichen der Bildverarbeitung. Es gibt andere Bereiche wie Objekterkennung, Verfolgung, 3D-Rekonstruktion usw., von denen viele noch immer auf "handgefertigten" Funktionen beruhen.

Dima
quelle
5
Seien Sie vorsichtig: DNNs sind sehr gut in der Lage, alle von Ihnen genannten Aufgaben zu erledigen : Objekterkennung, Verfolgung, 3D-Rekonstruktion usw. Die Signalverarbeitung ist jedoch ein Einblick in die physikalischen Aspekte der Signalmanipulation und in die Gründe, warum wir dies tun sollten manipulieren sie auf irgendeine Weise - und diese (ich glaube) werden ein Comeback machen, um zu erklären, warum adaptive Algorithmen wie DNNs funktionieren. Aber machen Sie keinen Fehler - DNNs sind sehr gut in der Lage, Transformationen von der Eingabe bis zum (differenzierbaren) Ziel durchzuführen.
Tarin Ziyaee
11

No Deep Learning beendet nicht die Bildverarbeitung. Sie benötigen große Datenmengen und viele Rechenressourcen, um tiefes Lernen zu erlernen. Es gibt viele Anwendungen, bei denen es wünschenswert ist, Bildverarbeitung mit weniger Rechenlast und geringerem Speicherbedarf und ohne Zugriff auf große Datenbanken durchführen zu können. Einige Beispiele sind Mobiltelefone, Tablets, mobile Kameras, Automobile und Quadrocopter. Deep Learning ist momentan sehr hoch entwickelt, da es einige sehr beeindruckende Ergebnisse bei der Klassifizierung gibt.

Die Klassifizierung ist eines von vielen Problemen, mit denen sich die Bildverarbeitung befasst. Selbst wenn Deep Learning alle Klassifizierungsprobleme lösen würde, wären noch viele andere Arten der Bildverarbeitung zu erledigen. Rauschunterdrückung, Bildregistrierung, Bewegungsberechnung, Morphing / Blending, Schärfen, optische Korrekturen und Transformationen, Berechnung von Geometrien, 3D-Schätzung, 3D + Zeitbewegungsmodelle, Stereovision, Datenkomprimierung und -codierung, Segmentierung, Deblurring, Bewegungsstabilisierung, Computergrafik, alle Arten von Rendering.

mathreadler
quelle
Entrauschen, 3D-Schätzung usw. - all diese Faktoren können sehr gut durch DNNs mit geeigneter Architektur und geeigneten Daten angenähert und gelöst werden.
Tarin Ziyaee
1
Ja ja und Sie können Ihre wöchentlichen Einkäufe in einem Jaguar erledigen (aber das ist nicht der Grund, warum sie gebaut wurden).
Kathreadler
1
Hehe, stimmt - aber das ist etwas anderes als zu sagen, dass Sie nicht mit Ihrem Jaguar einkaufen können.
Tarin Ziyaee
Es ist einfach, einem technischen Problem nützliche Einschränkungen aufzuerlegen, mit denen DNNs nur schwer fertig werden können. Zum Beispiel eine Einschränkung, dass die verwendete Methode nicht auf einen bestimmten Satz von Eingabedaten ausgerichtet sein sollte. Dann werden DNNs natürlich standardmäßig disqualifiziert, da sie alle ein Training benötigen und daher mit Trainingsdaten voreingenommen sind.
Kathreadler
Das gilt für jedes Engineering-Tool: Aber darum geht es nicht. Der Punkt ist, dass all diese Aufgaben, die Sie oben erwähnt haben, in der Tat sehr gut mit DNNs gelöst werden können. Ja, einige sind neuere Entwicklungen, aber es ist falsch , was zu sagen , dass sie kann nicht mit DNNs gelöst werden! Das ist alles!
Tarin Ziyaee
11

Heute hatten wir ein Gespräch mit einem Freund von mir. Es war ein regnerischer Tag hier in München, während ein großer Teil Europas eine Art sonnige Atmosphäre hatte. Die Leute tauschten Fotos in sozialen Medien aus, wo sie in schönen Sommerkleidern durch die Meere streiften. Sie ärgerte sich über diese Situation und wandte sich an mich und fragte: "Könnten Sie eine Software schreiben, um die Bilder in den sozialen Medien zu blockieren, die so niedliche Sommerfotos beinhalten, wenn das Wetter hier so schlecht ist?". Ich sagte, warum nicht. Alles, was Sie tun müssen, ist, eine große Anzahl von Sommerbildern und Negativbeispielen zu sammeln und diese durch ein Netzwerk zu speisen, das die Binärklassifizierung auf der Ebene "Block" oder "No-Block" durchführt. Trainieren und optimieren Sie das Netzwerk. Das ist es.

Dann drehte ich mich zu mir selbst: Weiß ich eigentlich, wie man einen einfachen Algorithmus schreibt, um zu entscheiden, ob das Wetter schön ist oder nicht, ohne dass die Maschine das Denken für mich übernimmt? Kaum ... vielleicht ... Für den neugierigen Leser gibt es hier einige Features, die Sie vielleicht entwerfen möchten, wenn Sie versuchen würden, es in Angriff zu nehmen:

Wetterklassifikation in zwei Klassen, Cewu Lu§ Di Lin, Jiaya Jia, Chi-Keung Tang , CVPR 2014

Offensichtlich würde mich diese CVPR-Veröffentlichung heutzutage nicht einmal mehr interessieren und ich gehe nur noch tiefer. So sehr ich das Deep Learning für seine robuste Leistung in vielen Szenarien mag, gehe ich auch vorsichtig damit um. Selbst wenn dadurch mein Wissen über die Bildverarbeitung nicht verloren gehen würde, verringert sich das von mir benötigte Fachwissen in Bezug auf Domänen. Intellektuell ist dies nicht sehr elegant.

Sobald sich der Einzelne entscheidet, auf dem richtigen Weg zu bleiben und von beiden Welten zu profitieren, ist er auf der sicheren Seite.

Tolga Birdal
quelle
7

Die kurze Antwort lautet: Nein. DL kann eine Tasse auf einem Foto erkennen, aber die Signalverarbeitung wird dadurch sowieso nicht unterbrochen. Das heißt, Ihre Frage ist in diesen unruhigen Tagen ziemlich relevant. Es gibt eine schöne Podiumsdiskussion über das Thema, mit Stéphane Mallat, etc. hier .

Dohmatob
quelle
5

Beim maschinellen Lernen wird die Datentechnik weiterhin verwendet, um die DNN zugeführten Daten vorzuverarbeiten und auszuwählen, um ihre Lernzeit und ihre Bewertungseffizienz zu verbessern. Die Bildverarbeitung (das Material zwischen dem Kamerasensor und den den DNNs zugeführten RGB / etc. - Bitmaps), eine Form der Datenverarbeitung, wird weiterhin benötigt.

hotpaw2
quelle
4

Ein gründliches Verständnis der Signalverarbeitung (zusammen mit linearer Algebra, Vektorrechnung, mathematischer Statistik usw.) ist für nicht-triviale Arbeiten im Bereich des Tiefenlernens, insbesondere im Bereich der Computersicht, unabdingbar.

Einige der aussagekräftigen Veröffentlichungen im Bereich Deep Learning (nachdem die meisten der niedrig hängenden Früchte gepflückt wurden) vermitteln ein gutes Verständnis der Signalverarbeitungskonzepte.

Einige Motivationskonzepte:

  • Dilated Convolutions : Schau dir diesen Blogpost an . Eine der ersten Gleichungen, die es gibt, ist Brot und Butter für eine Person, die gut mit Signalverarbeitungskonzepten vertraut ist (hah). Es ist auch eng verwandt mit dem bekannten Algorithmus der klassischen Wavelet-Signalverarbeitung.
  • Transponierte Faltungsschichten / Dekonv-Schichten. Auch hier grundlegende Signalverarbeitungskonzepte.
  • Gestaltung von Conv-Filtern - eine gute Vorstellung von Operatornormen und Kontraktionsabbildung ist erforderlich. Dies findet normalerweise entweder in einem Abschluss-EE-Kurs in Signaltheorie oder Steuersystemen oder in den Mathematikkursen in Analysis (Real oder Functional) statt.
  • Widersprüchliche Beispiele : Eine der ersten Arbeiten, die dies untersuchten ( "Faszinierende Eigenschaften von ..." ), formalisierte dies im Hinblick auf Störungen und verwendete Lipschitz-Konstanten der verschiedenen Schichten und Nichtlinearitäten in einem neuronalen Netzwerk, um die Empfindlichkeit gegenüber zu begrenzen solche Störungen. Einverstanden, die Analyse war sehr vorläufig, aber ich glaube, sie beweist erneut, dass ein nicht trivialer Fortschritt in irgendetwas, einschließlich des tiefen Lernens, ein nicht triviales Verständnis der Theorie erfordert.

Die Liste geht weiter. Selbst wenn Sie am Ende in der Bildverarbeitung arbeiten und tiefes Lernen für Ihre Probleme anwenden, wird der Hintergrund der Signalverarbeitung die Dinge für Sie sehr leicht verständlich machen.

AruniRC
quelle
1
Ja. Jede Abkürzung, die verwendet wird, um nicht zu lernen, was in das Netzwerk eingespeist werden soll, muss durch schlechtere Leistung auf die harte Tour erlernt werden.
Kathreadler
4

Ich mache eigentlich nicht viel Bildverarbeitung, aber ich habe für eine Organisation (US Navy) gearbeitet, die Forschungen zur Signalklassifizierung durchgeführt und finanziert hat, als neuronale Netze das letzte Mal ein heißes Thema waren, Mitte bis Ende der 80er Jahre. Ich musste eine große Anzahl von Marketing-Dingen durchstehen. Die Argumente lauteten wie folgt:

  • Es ist wie Ihr Gehirn neuronal und übertrifft statistische Techniken, da es einen linearen Klassifikator übertrifft. Ich kenne tatsächlich einige Leute, deren Papiere abgelehnt wurden, weil sie Statistiken zur Bewertung der Leistung verwendeten.
  • Neuronale Netze sind induktiv. Sie können Dinge richtig klassifizieren, wenn in ihren Trainingssätzen kein oder nur wenige Beispiele vorhanden sind.
  • DARPA finanziert die Arbeit und wir alle wissen, dass alles, was DARPA tut, ein Gewinner ist. (Google war noch nicht in der Nähe.)
  • Ist die Leistung nicht wunderbar, brauchen Sie keine Verwirrungsmatrix, brauchen Sie keine Klassenvorgesetzten? Ich kann Ihnen nur sagen, wie hoch meine Fehlerwahrscheinlichkeit ist. Ich brauche keine Grenzen, ich mache nur das One-Out-Hold-and-Retrain-Shuffle.
  • Wählen Sie einige Funktionen aus, es ist eine Black Box, Skalierung, Datenausrichtung, Störungsabweisung, fehlerhafte Beschriftungen, Auftreten mehrerer Klassen, nicht mein Problem.
  • Der Nebel der Mathematik, Boltzmann Machines
  • Lassen Sie uns eine SVD und vielleicht ein fraktales Dimension-Ding einwerfen.
  • Mit dem überwachten / unbeaufsichtigten Köder und Wechsel finde ich alle deine versteckten Muster. Ist diese assoziative Erinnerung nicht tiefgreifend?

Bischofs Buch brauchte, um meinen Zynismus zu unterdrücken.

In mehr als wenigen Anwendungen erfordert der optimale Signalverarbeitungsalgorithmus eine umfassende Aufzählungssuche über einen großen Parameterraum, der schnell unlösbar wird. Eine große Serverfarm kann den verfügbaren Suchbereich vergrößern, aber irgendwann müssen Sie eine Heuristik finden. DL scheint in der Lage zu sein, einige dieser Heuristiken zu finden, löst jedoch nicht die zugrunde liegende NP-Hard-Optimierung.

Stanley Pawlukiewicz
quelle
Sie haben vollkommen recht, wenn es darum geht, Zynismus zu dämpfen, da es so scheint, als würden viele Menschen niedergeschlagen. Ich wünschte manchmal, ich hätte das früher im Leben gelernt.
Kathreadler
3

Aus meiner Sicht an der Universität waren viele Signalverarbeiter ML gegenüber etwas feindlich eingestellt, ich vermute, sie fühlten sich bedroht, dass es in ihre Domäne eindrang. In letzter Zeit wurde jedoch viel über die Vorteile komplexer, tiefer neuronaler Netze geforscht, was darauf hindeuten könnte, dass das goldene Ticket wirklich ein solides Verständnis für beide Disziplinen darstellt.

Austin
quelle
1
Ja. Die Signalverarbeitung ist sehr eng mit dem maschinellen Lernen verbunden. Ein solides Verständnis der Signalverarbeitung hilft zu verstehen, wie ML-Algorithmen erstellt und verwendet werden und mit welchen Daten sie (un) geeignet sind.
Kathreadler
2

Nun ja. Genauso wie die Entwicklung in höheren Programmiersprachen wie C ++ und Python die Assembler-Programmierung "tötete". Das bedeutet jedoch nicht, dass es nicht relevant ist, Assembler zu lernen, wenn Sie sich für einen CS-Kurs anmelden. Es bietet großartige Einblicke in die Funktionsweise des Computers, in die Vorgänge hinter den Kulissen übergeordneter Sprachen, in die Grundprinzipien der Computersprache usw. Aber niemand, der bei Verstand ist, würde jetzt eine Desktop-App in Assembler programmieren.

Jochemspek
quelle