Herausforderungen in Systems-Engineering-Projekten – nicht-funktionale Anforderungen

Wonach suchen Sie zuerst, wenn Sie den Entschluss fassen, sich ein neues technisches Gerät zuzulegen? Sie fragen sich vollkommen nachvollziehbarerweise zunächst „Was kann es denn?“ bzw. „Was muss es können, damit ich es kaufe?“ Sie hinterfragen also die Funktionalität, denn das ist auch genau das, was uns auf sämtlichen Werbeflächen schon fast penetrant präsentiert wird.

Neuentwicklungen waren schon seit jeher ein Wettlauf darum, wer zuerst die neuesten, besten, innovativsten oder kreativsten Funktionen bietet. Ein Nebeneffekt davon, der sich uns auch immer wieder in unserem Tagesgeschäft offenbart, ist, dass dabei die nicht-funktionalen Aspekte auf der Strecke bleiben und kaum bis keine Beachtung finden.

Dieser Effekt wird durch die extrem kurzen Releasezyklen, wie Sie ja mittlerweile en vogue sind, noch zusätzlich unterfüttert. Von Release zu Release wird versucht, neue Funktionen zu entwickeln ohne zu viele Gedanken an Anforderungen wie die Qualität zu verschwenden. Leider wird oft vernachlässigt, dass es sich dabei um Kriterien handelt, die eine zentrale Rolle für die Kaufentscheidung des Kunden spielen und maßgeblich zum Produkterlebnis des Kunden beitragen. Es gibt sogar Untersuchungen, die ergeben, dass Stakeholder stellenweise über fehlende Funktionalitäten hinwegsehen, insofern das Look & Feel, also ein anderer nicht-funktionaler Aspekt, stimmig ist.

Unbenannt Wird den nicht-funktionalen Merkmalen eines Systems nicht ausreichend Beachtung geschenkt, leiden darunter häufig für den Kunden eminent wichtige Eigenschaften wie Performance oder Usability. Die logische Konsequenz ist ein unzufriedener Kunde. Leider werden derartige Defizite in der Entwicklung häufig erst zu spät identifiziert, so dass sich eine Nachbesserung extrem ressourcenaufwendig gestaltet.

Darüber hinaus tragen nicht-funktionale Anforderungen (kurz: nfAs) erheblich zur Vollständigkeit Ihrer Spezifikation bei. Denn nfAs dienen nicht ausschließlich der Ergänzung von funktionalen Anforderungen – ganz im Gegenteil.

Sie sind außerdem ein Indikator dafür, dass Funktionalitäten nur lückenhaft spezifiziert sind oder dienen als Begründung bzw. Verfeinerung für weitere funktionale Anforderungen.

Doch wie handhaben Sie am besten Ihre nfAs? Wie kann man dieser Problematik effektiv entgegen wirken?

Aus unserer Erfahrung wissen wir, dass jeder Stakeholder, der funktionale Anforderungen an Ihr System hat, im Allgemeinen auch nicht-funktionale Anforderungen hat. Es liegt an Ihnen als Systems bzw. Requirements Engineer, diese bestenfalls gleich im Prozess der Funktionserhebung mit zu ermitteln. Im Grunde genommen müssen Sie im Umgang mit nfAs die exakt gleichen Schritte durchlaufen, wie auch bei funktionalen Anforderungen. Also ermitteln, dokumentieren, prüfen und abstimmen sowie verwalten.

So wie jedes Projekt, hat auch unsere Blogserie ein Ende und zwar bereits mit diesem Artikel. Wir hoffen wir konnten Ihnen ein Bewusstsein für die Problemstellungen, die häufig im Systems-Engineering zu Tage treten, vermitteln und vielleicht dadurch bereits einen Mehrwert für Sie generieren.

Hiermit möchten wir uns von Ihnen verabschieden, Ihnen alles Gute und viel Erfolg wünschen und womöglich treffen Sie uns in einem Ihrer nächsten Systems-Engineering Vorhaben persönlich – wir würden uns sehr über eine Zusammenarbeit freuen.

Vielen Dank und viele Grüße,

Ihre SOPHISTen

PS: In Requirements-Engineering und -Management – Aus der Praxis von klassisch bis agil haben wir darüber hinaus Techniken und Hilfsmittel inklusive deren Anwendung im Realprojekt beschrieben, die Sie dabei unterstützen können mit Ihren nfAs fertig zu werden (z.B. das Vorgehen IVENA [Integriertes Vorgehen zur Erhebung nicht-funktionaler Anforderungen]). Auch die MASTeR-Schablonen für nicht-funktionale Anforderungen, die Sie in unserer MASTeR-Broschüre finden,  könnten für Sie ein wichtiges Hilfsmittel sein.

 

Schreibe einen Kommentar

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert