Call 2014 für IF in BW

Aus meinem Posteingang…

call-IF-BW-2014

Die Sommerhochschule für Informatikstudentinnen und IT-Fachfrauen findet 2014 wieder an der Uni in Freiburg statt. Dozentinnen und IT-Fachfrauen sind aufgerufen, ein Angebot abzugeben.

Zeitplan

  • Deadline Call for Lectures: 15. Jan. 2014 Verlängert: 24. Jan. 2014
  • Entscheidung Programmkomitee: Frühjahr 2014
  • Termin IF: 5. bis 9. August 2014

Themenwünsche

Um auch dieses Mal wieder ein anspruchsvolles und abwechslungsreiches Kursprogramm anbieten zu können, werden Kurs- und Vortragsangebote für folgende Themen gesucht:

  • Programmierung in Java, #, Web-Programmierung
  • Mobile Applikationen
  • Digitale Bildverarbeitung
  • Test Driven Development
  • 3D Visualisierung mit Open GL
  • Computergrafik /Digitale Bildbearbeitung
  • Arbeitsmethoden
  • Semantic Web, Web Services, Apache
  • Graphen und Algorithmen
  • Schreiben von Abschlußarbeiten
  • Grundladenvorlesungen für Informatikerinnen in Mathematik, Physik und Informatik
  • Social Skills

Andere Themenvorschläge werden selbstverständlich auch gern genommen.

Mehr Infos

Augen-Logo Maria

iqnite 2014 – Konferenzcall

iqnite-Konferenzen adressieren Softwarequalität und Testen und laden als Branchentreffpunkt die Software Quality Community ein.

zur Website

Termine

  • Beitragsschluss: 6. Dez. 2013
  • Benachrichtigung über Akzeptanz: 31. Jan. 2014
  • Einsendeschluss Vortragsfolien: 31. Mär. 2014
  • Konferenz: 20. bis 22. Mai 2014 (Düsseldorf)

Zielgruppe

Die Konferenz richtet sich an Projektleiter, Testmanager, Qualitätsbeauftragte und Testcentermanager, ebenso die Verantwortlichen für Themen der IT-Governance und/oder Qualitätssicherung. Willkommen sind auch alle, die Erfahrungen und Wissen in der operativen Qualitätssicherung haben oder ausbauen möchten.

Konferenzthemen

2014 besonders gefragt:

  • Qualität von Standardsoftware (SAP, Oracle, Microsoft, …)
  • Industrielle IT („Industry 4.0“, Siemens PLM u. Ä.)
  • Big Data & Quality
  • Qualität und Agilität
  • Qualität und Mobilität
  • Security und Safety

Darüber hinaus gern genommen werden folgende Themen:

  • Management: Qualitätssicherung und IT Governance, Projekt- bzw. Risikomanagement, Metriken, Kosten-Nutzen-Argumentation, Benchmarking, Kosteneffizienz/-wahrheit, Weiterbildung und Karriere im Bereich Softwaretesten
  • Prozesse: Prozessmodelle (V-Modell [XT], Scrum, RUP, etc.), Agilität, Process Improvement (TPI Next®, TMMi, SPICE, CMMI, ISO 15504), Requirements Management, Zusammenspiel von COBIT, ITIL®v3 und SW-Entwicklungsprozessen, Prozess-KPIs
  • Organisation: Zentrale versus dezentrale Testorganisation (Testfabrik, Crowd Testing), Testing as a Service, Managed Testing Services, Cloud Testing, Social Media
  • Methoden und Infrastruktur: Mobile Plattformen und Applikationen, Testdaten-/Testdatenmanagement (Synthetisierung, Anonymisierung), Testautomatisierung, Management von „Technical Debt“, Code Quality Management, Last & Performance Testing, Modellbasiertes Testen, Gamification

Beiträge

Relevante, innovative und in der Praxis umgesetzte oder zumindest umsetzbare Beiträge können eingereicht werden. Sie werden in die Level „Basis“, „Fortgeschrittene“ und „Expertise“ eingeteilt.

Akzeptanzkriterien

  • Relevanz für den Bereich Software-Qualitätsmanagement und -Testen
  • Innovationsgrad (entweder konzeptionell oder aber in Form von Erfahrungsberichten)
  • Anwendbarkeit
  • Didaktische Aufbereitung
  • Nutzen für das Unternehmen bzw. die anwendende Organisation

Eingereicht wird eine erweiterte Zusammenfassung (1 DIN A 4 Seite, 3500 Zeichen), nach folgender Struktur:

  • Motivation: Warum ist das Thema wichtig, wo sind heute Probleme bzw. Potentiale, wer ist von dem Bereich betroffen?
  • Basis: Was sind Vorbedingungen für die spätere Lösung? Worauf basiert sie? Was muss im Vorfeld vorhanden sein?
  • Lösung: Wie sieht die Lösung aus? Wie hilft es, das Problem zu lösen und/oder die Potentiale zu heben? Wie funktioniert die Lösung?
  • Ergebnis: Wie sieht eine konkrete Anwendung aus? Welche Mehrwerte können belegt werden? Was sind belegte Ergebnisse?
  • Ausblick: Welche Aspekte können noch weiter ausgebaut werden? Wohin geht die Reise bzgl. der Lösung
  • Vortragsessenz: Was nimmt eine Zuhörerin oder ein Zuhörer von dem Vortrag mit? Wann kann sie oder er das Gezeigte anwenden?

Konferenzsprache ist Deutsch, englischsprachige Beiträge sind möglich bei entsprechender Bewertung. Wer angenommen wir, schickt eine ausgearbeitete Präsentation (max. 15 Seiten) hinterher. Falls die nicht gut ist, kann der Beitrag noch abgelehnt werden.

Präsentationsformen

Folgende Vortragsformen sind vorgesehen:

  • Vorträge: Ein Vortrag sollte einen detaillierten Einblick in Erfahrungen, Forschungsergebnisse, Fallstudien, Lösungen oder zukünftige Entwicklungen geben. Praxisrelevante Vorträge aus den verschiedenen Branchen sind genauso willkommen wie Ergebnisse aus dem akademischen Bereich. (Dauer 40 Minuten inkl. Diskussion)
  • Tutorials: In einem Tutorial wird ein bestimmtes Schwerpunktthema ausführlich behandelt. Das Tutorial ermöglicht den Teilnehmerinnen und Teilnehmern, die Theorie mit der Praxis zu verbinden. (Dauer max. 4 Std)
  • Workshops: Workshops bieten den Teilnehmerinnen und Teilnehmern ein interaktives Forum, in dem sie ihre Ideen austauschen und voneinander lernen können. (Dauer 2 bis 4 Std)
  • Interaktive Sessions und alternative Formate: Wer eine Erfolgsgeschichte oder auch eine Misserfolgsgeschichte, ein provokatives Ergebnis o. ä. vorschlägt, das zwar zur Konferenz passt, aber nicht in die oberen drei Kategorien fällt, kann die Konferenz als Plattform nutzen. Das gilt auch für einen Austausch mit Gleichgesinnten. Oder ein völlig andere Formate (Film, Experiment, …). Die Konferenz als Plattform: Räumlichkeiten werden gestellt, das Format bestimmen die Anbietenden selbst. Die iqnite 2014 ist offen für alle spannenden Neuerungen.

Für Studierende

Bis zu 20 Studierende werden gesponsert und bekommen so eine kostenfreie Teilnahme an dieser Konferenz.

Das Sponsoring umfasst

  • Teilnahme an der Workshops und Präsentationen der iqnite 2014,
  • Teilnahme am Social Event am Mittwoch 21. Mai 2014 und
  • eine Einladung zu einem 45-minütigen „Konferenzbriefing“, in dem die Studierende eine Einführung ins Qualitätsmanagement und Testen bekommen, sowie anschließend einzelne Tracks, Stände und Vorträge eingeordnet werden.

Eingeladen sind Studierende, die

  • aktuell an einer Hochschule studieren,
  • dort überdurchschnittliche Leistungen zeigen, und
  • die Interesse am Themengebiet Qualitätsmanagement und Testen haben.

Bewerbungsschluss dafür ist der 25. Apr. 2014. Über die Bewerbungen entscheidet das iqnite-Programmkomitee in der Reihenfolge der Bewerbungseingänge.

Call unter
www.iqnite-conferences.com/de/programm/call-for-papers.aspx

Augen-Logo Maria

Karriere: IT-CareerCruise

zur Website

Am 21. Nov. 2013 sticht IT-KARRIEREMACHER.de auf dem Rhein in Köln zur ersten IT-CareerCruise in See. Von 10 bis 17 Uhr gibt es ein Rahmenprogramm, eine Meetinglounge und jede Menge Möglichkeiten für Studis und Absolventinnen oder Absolventen, mit potenziellen Arbeitgebern und Arbeitgeberinnen in Kontakt zu treten.

Bereiche: Ingenieurwissenschaften, Informatik, Mathematik, Technik, Naturwissenschaften

Bei der IT-CareerCruise auf der MS RheinFantasie präsentieren sich Unternehmen und informieren über Karrierechancen. Egal, ob Einstiegsposition, Nebenjob, Werkstudentenprogramm oder Thema für die Abschlussarbeit.

Mehr Infos:

www.it-karrieremacher.de/event/it-careercruise

Augen-Logo Maria

Gender-UseIT 2014 in Berlin: HCI, Web-Usability und UX unter Gendergesichtspunkten

Aus meinem Posteingang…

zur Website

Die #GUI2014 findet am 3. und 4. Apr. 2014 in Berlin statt, Beiträge und Teilnahme sind herzlich gern genommen.

#GUI2014

Die Fachkonferenz #GUI2014 ist ein Begegnungsort für Expertinnen und Experten aus Hochschulen, Forschungseinrichtungen und Unternehmen im Bereich Usability, UX und Gender. Sie bietet eine Plattform zum Kennenlernen und zum Austausch über verschiedene Herangehensweisen, Methoden und Beispiele zur Integration des Genderaspektes in den Usability-Prozess und in das Design von User Experience.

Beiträge

Gesucht sind Beiträge zu Projekten, Good-Practice-Beispielen, Untersuchungen sowie Zukunftsvisionen und Positionen. Beiträge (max. 1 DIN A4-Seite) könnt Ihr über die Webseite https://sec.kompetenzz.net/conftool einreichen. Angenommene Beiträge werden später im Tagungsband veröffentlicht.

Einreichungsschluss: 24. Nov. 2013

Mehr Infos unter www.gender-useit.de.

Für inhaltliche Rückfragen wendet Euch an Frau Prof. Dr. Nicola Marsden, Hochschule Heilbronn. Für organisatorische Rückfragen steht Euch das Team des Koordinierungsbüros Gender-UseIT vom Kompetenzzentrum Technik-Diversity-Chancengleichheit jederzeit zur Verfügung.

Bitte auch weitersagen!

Augen-Logo Maria

ditact_shortcuts im November

zur ditact-WebsiteAus meinem Posteingang…

An die ditact_Teilnehmerinnnen

Vom 7. bis 9. Nov. 2013 finden am ICT&S Center, Universität Salzburg, wieder die ditact_shortcuts statt. Die Teilnahme an allen Veranstaltungen ist kostenfrei.

Programm

Do 7. Nov. von 18 Uhr:
Eröffnungsvortrag von Mag.a Romy Sigl (COWORKINGSALZBURG)
„Neues Arbeiten in der IT- und Kreativbranche“

Im Anschluss laden wir zu Diskussion und Netzwerken bei Getränken und Snacks.

Fr 8. Nov. von 8 bis 15 Uhr:
Workshop von Mag.a Alexandra Kreuzeder
„Die Walt-Disney-Strategie. Projekte kreativ umsetzen“

Fr 8. Nov. von 9 bis 15:45 Uhr und Sa 9. Nov. von 9 bis 12:15 Uhr:
Workshop von Dipl-Ing.in (FH) Renate Pinggera
„Agile Softwareentwicklung“

Mehr Infos

Details gibt es im Infoblatt. Anmeldung unter http://ditact.ac.at/event/ditact_shortcuts-13_11 und allgemeine Infos unter www.ditact.ac.at.

Das ditact_team freut sich auf ein spannendes und informatives Wochenende!

Augen-Logo Maria

Vernetztes Leben und Arbeiten

Aus meinem Posteingang… die Erinnerung zur Jahrestagung des dib vom 15.-17.11.2013 an der Uni in Stuttgart-Vaihingen:

„Mit dem Tagungsmotto Vernetztes Leben und Arbeiten möchte der deutsche ingenieurinnenbund e.V. (dib) Ingenieurinnen, Frauen in MINT-Berufen und Studentinnen aus technischen Fachrichtungen ansprechen.

Neue Informations- und Kommunikationstechniken spielen nicht nur bei der jungen Generation (Stichwort soziale Netzwerke) eine wichtige Rolle, sondern sind auch grundlegend für die moderne Arbeitswelt. So lässt sich der zunehmende Anteil erneuerbarer – also volatiler – Energien und Elektromobilität nicht ohne intelligente Netze steuern. Maschinen kommunizieren untereinander, Automobile mit der Infrastruktur u.a.m. Es bieten sich neue  Möglichkeiten, beispielsweise beim Monitoring pflegebedürftiger Personen. Mit der Vertiefung dieses Themas schlägt die Tagung auch eine Brücke zum Wissenschaftsjahr 2013, das dem demografischen Wandel gewidmet ist.

Die dib-Tagung wird am Freitagnachmittag mit mehreren Exkursionen eröffnet. Den ganzen Freitag über steht der Markt der Möglichkeiten, wie auch das Expeditionsmobil N, allen Interessierten offen. Am Abend gibt es ein Einführungsreferat und weitere Angebote. Der Samstag beginnt mit einer Keynote zum Tagungsthema. Anschließend stehen mehrere parallele Workshops sowie Vorträge und Exkursionen auf dem Programm. Zusätzlich werden Angebote zu Softskill-Themen wie z. B. Bewerbung, Führung, Karriereplanung vorbereitet.

Weitere Informationen und Anmeldung (wenn Übernachtung gewünscht wird bitte bis 20.10.!) unter www.dibev.de.“

Augen-Logo Maria

Ist doch kein Beinbruch? Wenn doch, dann mach den Drucker schon mal an…

zur Website Wer schon mal ein Gipsbein hatte, kennt das – vor allem im Sommer. Es ist warm, schwitzig, fies. Und Duschen oder Baden geht auch irgendwie nicht so gut… Jetzt gibt es endlich eine Alternative. Und in ein paar Jahren könnte die sogar „hausbesuchtauglich“ sein. Alles, was man braucht, ist ein 3D-Drucker. Okay, und ein Röntgenbild sowie ärztliches Personal für die korrekte Diagnose.

Mehr Infos
http://jakevilldesign.dunked.com/cortex

Augen-Logo Maria

Exkursion zur SGL Rotec in Lemwerder

Im Rahmen der Veranstaltung „Sustainable Material in Products of Wind Energy“ von Rosa Garcia Sanchez durften wir die Firma SGL Rotec besichtigen. Diese Exkursion zu dem Hersteller von Rotorblättern für Windräder führte uns nach Lemwerder im Bremer Norden.

Während der Führung sahen wir einen Teil der Produktion der Rotorblätter. Wir lernten den Aufbau eines Rotorblattes mit den einzelnen Schichten kennen. Ein weiteres Augenmerk lag auf den Arten der Abfallstoffe sowie Resten der Produktion und darauf, wie diese möglicherweise weiter verwertet werden können bzw. ob sie entsorgt werden müssen.

Als Höhepunkt durften wir uns sogar ein Rotorblatt von innen anschauen. Dabei ist auch das Gruppenfoto entstanden.

Lemwerder

Es war eine interessante und lehrreiche Exkursion. Sie hat mir – und sicher auch allen anderen Teilnehmerinnen – großen Spaß gemacht.

Augen-Logo Stefanie (Redaktion: Alke)

Arduino mit Dr. Blinken – Ein Einblick

Bereits am Mittwochmittag kurz nach Beginn des Kurses blinkten die ersten Leuchtdioden, gesteuert vom Microcontroller Arduino, auf den Tischen der Teilnehmerinnen.

Am Donnerstagmorgen dann die Frage an alle: „Wie lange programmierst du schon?“

Habe ich mir dazu je schon mal Gedanken gemacht?

Anhand der Ergebnisse wurden dann Zweierteams gebildet und die Arduino-Programmierung mit LEDs weiter erforscht. Die erste Aufgabe, einen Würfel zu programmieren, wurde in Angriff genommen. Da ich in den letzten Jahren primär mit Java entwickelt habe, kam ich einerseits dann doch irgendwann ins Schwitzen – so halbseiden objektorientiert mit Modulen ohne und mit Klassen geht halt nur in C++, der Sprache, mit der Arduino programmiert wird. Andererseits kramte ich mit Genuss die Erinnerungen an intensive Zeiten mit Pointern und Header-Dateien während meines Studiums hervor.

Am Ende leuchteten auf meiner an den Arduino angeschlossenen LED-Platine per Knopfdruck zufällige Würfelpunktmuster – ganz wie beim Original.

Bildquelle

Nun die Frage an die Kursleiterin Dr. Blinken: „Béla, wann und wie bist du dazu gekommen, LEDs mit dem Arduino zum Leuchten zu bringen?“

Béla: „Vor anderthalb Jahren habe ich mein erstes Projekt zusammengelötet, ein Bausatz von der Blinken Area. Ich war schon öfter auf dem Chaos Communication Congress und fand die Projekte von Blinkenlights schon immer ziemlich toll. Ich habe dann auch angefangen, mich ein bisschen mit Elektronik zu beschäftigen und mit dem Arduino herumexperimentiert.“

Links zum Thema Arduino:

Augen-Logo Sybille (Redaktion: Alke)

Sommeruni Bremen – Auszug aus dem Kurs „Sicher und kompetent Verhandeln“

In diesem Kurs ging es um etwas Alltägliches, das einen großen Stellenwert sowohl im Beruflichen als auch im Privaten hat: das Verhandeln. Um erfolgreich zu verhandeln, solltest Du zunächst wissen, welches Deine eignen Ziele sind, und überlegen, welche Motive deine Verhandlungspartnerin hat. Wichtig ist es, die verschiedenen Verhandlungsmethoden zu kennen und anwenden zu können. Wir haben viel mit Metaplankärtchen auf Tafeln gearbeitet – hier findet Ihr die Ergebnisse.

Faktoren, die die Verhandlung beeinflussen

Dies können sein: Rolle und Position der Verhandlungspartner, Wahrnehmung und Kommunikation als auch Vorbereitung und Zielerklärung. Doch was gehört noch alles dazu? Seht selbst:

Bild 1

Wichtig ist es, sich dieser Faktoren bewusst zu sein und sie in die Vorüberlegungen zu einer Verhandlung einzubeziehen.

(©Alke Rockmann)

Verhandlungsstile

Ein Teil der Vorüberlegungen ist nun gemacht – aber wie geht es weiter? Welche Wege führen zu welchem Ziel?

Bild 2

Super wenn man es schafft, mit seinem Verhandlungspartner auf der sachlichen Ebene zu diskutieren.

(©Alke Rockmann)

Nach einem Rollenspiel am Nachmittag sind wir nun gespannt, was uns der heutige Tag bringt. Noch ein Tipp zum Verhandeln: Wenn nächsten Mal jemand zu Dir sagt: „Das ist unmöglich“, gebe nicht klein bei sondern frage zurück, was daran denn unmöglich ist. Oder unter welchen Umständen der Gegenüber es als möglich betrachtet.

Augen-Logo Alke

Vom sinnvollen Fortbilden und vom sauberen Code

zur Website

Sauberer Code ist  eine Arbeitserleichterung, wer einmal – in fremdem Code – herumgearbeitet hat, weiß das. Und manchmal ist „fremder Code“ mein eigener Code von vorletztem Jahr… Clean Code Developer haben ein Wertesystem entwickelt, das dieses Übel an der Wurzel packt. Das skizziere ich Euch mal hier, zuerst die vier Werte:

  • Evolvierbarkeit
  • Korrektheit
  • Produktionseffizienz
  • Reflexion

Evolvierbarkeit

Damit Änderungen möglich sind, muss jede Software eine innere Struktur haben, die Änderungen ermöglicht. Das ist für Clean Coder „Evolvierbarkeit“.

Alle, die ein Auto besitzen, wissen, dass es regelmäßig einen Ölwechsel braucht. Nicht etwa, weil das Öl zu dem Zeitpunkt aufgebraucht wäre, nicht einmal deshalb, weil das Öl zu dem Zeitpunkt bereits völlig wirkungslos wäre. Nein, es wird getauscht, weil Erfahrungswerte des Herstellers zeigen, dass der Motor durch den rechtzeitigen Ölwechsel geschont wird und somit länger hält.

Das ist bei Software anders. Es gibt – auf den ersten Blick – keine Verschleißteile oder ähnliches.

Software wird in der Regel über lange Zeiträume betrieben. Während dieser Zeit ändern sich die Rahmenbedingungen, müssen Features ergänzt werden. Im Idealfall kostet die Implementierung eines Features einen festen Betrag, der unabhängig davon ist, wann das Feature realisiert wird.

Natürlich gibt es beim Betrieb der Software immer etwas zu tun. So sollte vielleicht regelmäßig geprüft werden, ob die Logdateien noch ausreichend freien Platz auf der Festplatte lassen, ob eine Datenbank überläuft oder der Speicher sich zunehmend füllt.

In der Praxis steigt der Aufwand (nicht nur der Preis) für ein Feature umso mehr, je später es realisiert wird. Am Anfang sind Features preiswert, am Ende ist es gar nicht mehr möglich Features zu ergänzen, weil niemand mehr durchblickt. Die Kosten steigen exponentiell. Schließlich wird die Software weggeworfen und neu entwickelt.

Das Gemeine an exponentiellem Wachstum:

  1. Anfangs erkennt man kaum, dass die Kosten anwachsen. Die Steigung ist moderat.
  2. Erkennt man, dass die Kosten steigen, ist es zu spät. Ein Gegensteuern ist nicht mehr möglich.

Je einfacher die Software an geänderte Rahmenbedingungen angepasst werden kann, desto höher ist ihre Evolvierbarkeit. Doch Evolvierbarkeit erhält man nicht nachträglich. Sie muss von vorneherein berücksichtigt werden.

Beispiel

Klassen sollten genau eine Verantwortlichkeit haben. Ist eine Klasse für mehr als eine Sache zuständig, ist es schwerer sie zu überblicken. Das behindert Änderungen, denn diese bedingen, dass man den Quellcode versteht. Die Kopplung zwischen den Klassen ist größer als bei „Einzelverantwortlichkeit“. Plötzlich hängt alles mit allem zusammen.

Dies kann man nur verhindern, indem Funktionseinheiten eine klar definierte Verantwortlichkeit haben und man die Kopplung im Blick behält.

Hat man in einem Softwaresystem eine Reihe von Klassen angesammelt, die jeweils für mehrere Dinge verantwortlich sind, ist es im Nachhinein nur schwer möglich, diesen Zustand zu beseitigen. Die Kopplung ist so groß, dass es schwer fällt, einzelne Funktionseinheiten heraus zu lösen. Sollen in diesem Dickicht neue Features realisiert werden, ist das sehr aufwändig. Wenn nicht rechtzeitig begonnen wird, das Dickicht zu lichten, wird die Situation mit jeder Änderung schlimmer.

Korrektheit

Software muss funktional korrekt sein. Ein Buchhaltungsprogramm muss die Buchungen ordnungsgemäß verbuchen, eine Tabellenkalkulation muss richtig rechnen. Und auch die nicht-funktionalen Anforderungen müssen erfüllt sein. Das Programm muss schonend mit Ressourcen wie Speicher, Prozessorzeit, Plattenplatz etc. umgehen, die Antwortzeiten müssen in einem definierten Rahmen liegen. Erst wenn alle Anforderungen erfüllt sind, ist die erstellte Software korrekt.

Was kann man konkret für Korrektheit tun? Testen ist nicht die Lösung. Korrektheit muss bereits während der Entwicklung berücksichtigt werden. Nochmal: Die Entwickler müssen sich mit der Frage der Korrektheit auseinandersetzen.

Und damit sie das überhaupt können, muss ihnen klar sein, was die Anforderungen sind. Schon daran mangelt es zu oft. Die Aufgabe der Entwickler ist, bei unklaren Anforderungen nachzufragen, statt in eine Glaskugel zu schauen oder den schwarzen Peter zu „den Anderen“ zu schieben.

Verglichen mit dem Automobilbau steht die Softwareenwicklung beim Thema Korrektheit schlecht da. Ein Auto besteht aus vielen Teilen, deren Korrektheit jeweils einzeln nachgewiesen und überprüft werden kann. Stellen Dir vor, Du müsstest zur Fehlersuche mit einem Meßgerät in der Hand bei Tempo 200 auf der Motorhaube eines Autos sitzen, um dort verfolgen zu können, was sich in der Maschine abspielt. Hmmm… das ist komisch? Ein Debugger wird in vielen Fällen genau so eingesetzt.

Produktionseffizienz

Entwicklungszeit und Preis der Software spielen immer eine Rolle. Der Preis ist höher, wenn die Produktion der Software nicht effizient erfolgt. Das beginnt bei manuellen Arbeitsschritten, die nicht automatisiert werden und geht bis zu hohen Fehlerraten, die mehrmaliges Nachbessern erfordern. In letzter Konsequenz bedeutet Produktionseffizienz, dass die Software über Jahre oder gar Jahrzehnte weiterentwickelt werden kann, statt irgendwann die alte Software wegzuschmeißen und wieder ganz von vorne beginnen zu müssen.

Gleichzeitig reduziert eine hohe Produktionseffizienz die Anfälligkeit für Fehler.

Die Produktionseffizienz hilft, andere Werte in ein maßvolles Verhältnis zu setzen. Wer unendlich viel Aufwand für die Korrektheit treibt, macht am Ende auch etwas falsch.

Reflexion

Ohne Rückschau ist keine Weiterentwicklung möglich. Nur wer reflektiert, wie er eine Aufgabenstellung gelöst hat, kann beurteilen, ob der gewählte Weg einfach oder beschwerlich war. Lernen basiert auf Reflexion.

In so einem schnelllebigen Bereich wie der Informatik ist es besonders wichtig, stets neue Erkenntnisse zu berücksichtigen. Dazu ist Reflexion auf allen Ebenen erforderlich. Angefangen beim Reflektieren über die Implementation beim Pair Programming oder Code Review, das tägliche Reflektieren des Teams, die Reflexion nach jeder Iteration, bis hin zur Reflexion der gesamten Branche über ihr Tun. Ohne Reflexion keine Weiterentwicklung.

Clean Code Developer Grade

  • Schwarzer 0. Grad
  • Roter 1. Grad
  • Oranger 2. Grad
  • Gelber 3. Grad
  • Grüner 4. Grad
  • Blauer 5. Grad
  • Weißer 6. Grad
  • … und von vorn

Clean Code Developer*in ist man nicht einfach, sondern man wird es. Es geht nämlich nicht darum, ein paar Regeln auswendig zu lernen, sondern das CCD-Wertesystem zu verinnerlichen. Das braucht Übung … und Zeit. Deshalb gibt es die Unterteilung in CCD-Grade, die man als Entwickler*in eine nach der anderen durchläuft. Achtung: Der gesamte Prozess ist als Kreis zu verstehen: wer alle Grade bearbeitet hat, beginnt wieder von vorne.

Jedem Grad ist eine Farbe zugeordnet. (Wer mag, kann dabei ein CCD-Armband als tragen, gibt’s natürlich über die Website zu erstehen…)
Anders als im Judo entspricht die Farbe nicht einem erreichten Grad, sondern dem in Arbeit befindlichen.

Schwarzer 0. Grad

Den schwarzen Grad hat jeder, der sich für CCD interessiert. Man kann es tragen, wenn man für den ersten richtigen Grad noch nicht alle Voraussetzungen erfüllt.

Roter 1. Grad

Der Weg zum Clean Code Developer beginnt mit dem roten Grad. Mit dem roten Grad setzt die Übungspraxis ein. Er enthält nur Elemente, die absolut unverzichtbar sind. Der Einstieg soll so leicht wie möglich sein. Auf dieser Stufe geht es deshalb noch nicht so sehr um Softwareentwicklungsprinzipien, als vielmehr um den Aufbau einer fundamentalen Haltung zur Softwareentwicklung.

Oranger 2. Grad

Nachdem im roten Grad die Grundlagen für den Prozess der kontinuierlichen Verbesserung geschaffen wurden, geht es im orangen Grad darum, einige fundamentale Prinzipien auf den Code anzuwenden und erste Erfahrungen mit dem wichtigsten Mittel zur Produktivitätssteigerung zu gewinnen: Automatisierung von Abläufen. Die Automatisierung dient der Korrektheitsprüfung. Es geht also nicht um eine nice-to-have-Eigenschaft von Code, sondern um seine Essenz.

Gelber 3. Grad

Beim gelben Grad geht es vollends um automatisierte Tests. Beim orangen Grad ging es noch um die von außen ansetzbaren Integrationstests. Für sie war nicht unbedingt ein Eingriff in den Code nötig. Ab dem gelben Grad allerdings geht es nicht mehr ohne Tests unter der Oberfläche. Und nicht nur das: getestet werden sollen die kleinstmöglichen Einheiten, nicht nur funktionale Durchstiche. Das bedeutet eine Änderung der Codierungspraxis, denn sonst lassen sich einzelne Klassen nicht isoliert, d. h. unabhängig von genutzten Diensten prüfen. Deshalb gehören zum gelben Grad auch objektorientierte Prinzipien, denn nur mit ihnen ist eine Ablösung von zu testendem Code von seinem „Untergrund“ möglich.

Grüner 4. Grad

Im grünen Grad geht es weiter mit der Automatisierung. Automatisierung ist Schlüssel zur Produktivität und Reaktionsfähigkeit. Nur wenn maximal viele Tätigkeiten in der Softwareentwicklung automatisiert sind, kann sich der Clean Code Developer auf’s Wesentliche konzentrieren: die Implementation von Kundenanforderungen. Ohne Automatisierung hängt die Entwicklung sonst oft an Kleinigkeiten, was Zeit kostet. Korrektheitsprüfungen und Releases sind dann eher eine Strafe. Nach der Automatisierung der Tests steht jetzt die Produktion auf dem Plan. Code am Entwicklerarbeitsplatz zu testen, geschenkt. Ihn auf einem unabhängigen Rechner zum Laufen zu bringen und zu testen, ist eine ganz andere Nummer. Nur dort lassen sich mehr oder weniger subtile Abhängigkeiten vom Entwicklerarbeitsplatz finden. Dazu gibt es im 4. Grad noch mit weitere Prinzipien zur Codestrukturierung und ein Werkzeug für bessere Architekturen.

Blauer 5. Grad

Mit dem blauen Grad geht die Automatisierung noch einen Schritt weiter. Jetzt steht das Deployment an. Vor allem geht es im blauen Grad aber nun um Aspekte der Softwareentwicklung jenseits von Code und Tools: Clean Code Developer kümmern sich nicht nur um gute Strukturen im Kleinen, sondern planen sie von vornherein im Großen. Es geht also um Architektur. Zur Softwareentwicklung insgesamt gehört an dieser Stelle auch ein passendes Vorgehensmodell. Das ist iterativ und soll während der Arbeit am blauen Grad nun auch eingeübt werden.

Weißer 6. Grad

In den weißen Grad fließen alle Prinzipien, Regeln und Praktiken ein. Auf der Ebene des weißen Grades arbeitet ein CCD nur, wenn er ständig das ganze CCD-Wertesystem im Blick hat. Das macht klar, dass nur wirklich fortgeschrittene Softwareentwickler*innen mit mehreren Jahren Erfahrung und in einer geeigneten Umgebung mit dem weißen Grad arbeiten können.

Bedeutung der Grade

Die Grade drücken keinen Wert aus. Wer am blauen Grad arbeitet ist nicht „besser“ oder „weiter“ als jemand, der am orangen Grad arbeitet. Die Grade sind nur ein didaktisches Hilfsmittel. Die vielen Bausteine lassen sich schlicht in kleinen Happen besser aneignen als in einem großen Anlauf.

Deshalb ist es wichtig, dass alle, die sich für CCD interessieren, mit dem roten Grad beginnt. Aus didaktischen Gründen ist es der beste Einstieg – auch wenn man meint, man würde doch auch schon in der täglichen Arbeit andere Werte umsetzen. Denn unabhängig von der heutigen Projektpraxis ist es neu und ungewohnt, sich dermaßen bewusst mit Prinzipien und Praktiken auseinanderzusetzen. Insbesondere die tägliche Reflektion darüber ist wahrscheinlich noch nicht Gewohnheit.

Ein stumpfes Abhaken von Programmiergewohnheiten, die man davon schon beherzigt, ist letztlich unerheblich. Es geht nicht um „Verdienst“, sondern um Iterationen und kleine Happen. Grade sind Gucklöcher auf das große Ganze.

Fortbildung: Fortwährend immer weiter und weiter bilden

Das Wertesystem und die Bausteine mögen starr aussehen, wie in Stein gemeißelt. So ist es aber nicht. Es ist immer nur vorläufig, bis die Community sieht, dass etwas verändert werden sollte. Noch viel stärker im Fluss ist die Welt der Werkzeuge: Programmiersprachen, IDEs, Frameworks, Plattformen, Serverprodukte verändern sich ständig. Tendenziell wird das, was es zu wissen und zu können gilt, immer nur mehr und mehr. Ein Ende ist nicht in Sicht.

Professionalität bedeutet, informierte Entscheidungen zu treffen. Daher die Notwendigkeit, sich ständig fortzubilden. Wahrscheinlich ist Softwareentwicklung sogar der Bereich mit der größten Notwendigkeit dazu.

Aspekte der Fortbildung sind deswegen Bestandteile mehrerer Grade (Orange, Gelb, Grün). Damit wird deutlich, dass Fortbildung immer ein Thema ist, aber eben auch einer Entwicklung folgen muss. Von 0 auf 100 bei der Fortbildung in einem Grad ist nicht möglich. Nicht nur Softwareentwicklung braucht Übung, auch Sich-Fortbilden will gelernt sein.

In den Graden geht es aber lediglich um die Fortbildungsformen (Lesen, Networking, Veröffentlichen). Wieviel Zeit sie benötigt, geben sie nicht vor. Daumenregel: Fortbildung sollte unabhängig von der Form mindestens 20% der Arbeitszeit ausmachen.

Ja, das meinen die Leite von CleanCodeDeveloper.de genau so. 20% der Arbeitszeit für Fortbildung. In der Regel also 1 Tag/Woche nur für die Fortbildung. Nicht weniger. (Google macht vor, dass das funktioniert.)

20% klingt dennoch sehr viel. Aber keine Angst, Fortbildung ist gar nicht so schlimm für den, der sie bezahlen soll. Denn Fortbildung ist einiges nicht, was man zunächst damit verbindet:

  • Fortbildung ist kein Urlaub
  • Fortbildung ist keine Abwesenheit vom Arbeitsplatz
  • Fortbildung bedeutet, dass Nutzen für Projekte gestiftet werden kann
  • Fortbildung braucht kann mit kleinem Budget für Schulungen oder Software funktionieren

Fortbildung bedeutet vor allem Spielraum für Fehler.

Anders formuliert: Während 20% der Arbeitszeit sollte ein professioneller Softwareentwickler keine Angst vor Fehlern haben.

Das bedeutet im Extremfall, dass die 20% ohne direkten Gewinn für ein Projekt sind. Vergleichen Sie die Fortbildung mit dem Üben beim Musizieren. Auf der Bühne muss die Musikerin performen, tunlichst fehlerfrei. Um ihr Können auf gleichem Stand zu halten oder sogar zu verbessern, muss die Musikerin natürlich üben. Dabei sind Fehler ausdrücklich zugelassen, da sonst keine Weiterentwicklung möglich wäre. Es bedarf also zweier unterschiedlicher „Betriebsarten“.

Erst unter der Voraussetzung eines solchen Spielraums für Fehler geht es darum, wie er sinnvoll ausgefüllt wird. Einziger Anspruch an mögliche Inhalte sollte sein, dass ein Bezug zur Arbeit erkennbar ist. Wer die 20% Spielraum für die private Wohnungssuche oder Sport im unternehmenseigenen Fitnesscenter nutzt, bildet sich nicht fort. (Wobei der Sport zumindes – auch geistig – die Leistungsfähigkeit stärkt ;)

Arten von Fortbildung

  • Studium von Fachpublikationen (online/offline, Blog/Zeitschrift/Buch/Video)
  • Ausprobieren von Gelesenem: Technologien, Verfahren, Werkzeuge
  • Besuch von Fachveranstaltungen (Schulung, Konferenz, Community-Event)
  • Publikation eigenen Fachwissens: unternehmensintern (z. B. Firmen-Wiki) oder auf öffentlichen Plattformen (Blog, Zeitschrift, Buch, Fachkonferenz)

Ob Lektüre, Experimente oder Publikationen direkt mit einem Projekt im Zusammenhang stehen, ist nachrangig. Sie können, müssen aber nicht. Ein CCD kann eine Technologie mit Blick auf das Firmenprojekt evaluieren oder nur aus allgemeinem Interesse. Nutzen für das Projekt entsteht in jedem (!) Fall!!! Entweder unmittelbar oder mittelbar. Denn jede Kenntnis einer Technologie oder eines Verfahrens, auch wenn der Einsatz im Projekt noch nicht absehbar ist, macht optionenreicher.

Hinweis für die Entscheider*in: Entwickler, die sich kontinuierlich fortbilden, stellen einen Wert dar. Sie sind erfahrener, innovativer, flexibler. Zugehört: „Das dient Ihrem Erfolg!“

Hinweis für die Softwareentwickler*in: Wer sich fortbildet, wird wertvoller. Er gewinnt an Erfahrung, ist nicht in einer Nische festgenagelt. Das dient der „Employability“.

Übung

Clean Code Developer zu werden braucht Zeit. Schätzungsweise muss man pro Grad sicher mehr als 21 Tage einplanen. Denn 21 Tage (3 Wochen) – so sagt die Psychologie – brauchen Menschen, um Neues oder allgemein Veränderungen als Gewohnheit zu etablieren.

Wer auf einer CCD-Stufe arbeitet, soll deshalb so vorgehen: Am Abend jedes Arbeitstages reflektiert der CCD darüber, ob er die Prinzipien seines Grades (und der darunter liegenden) eingehalten hat. Wenn ja, behält er das Armband an dem Arm, an dem es ist. Wenn nein, wechselt er das Armband jedoch zum anderen Arm! Das ist wichtig, denn durch den Akt des Wechselns macht sich der Entwickler bewusst, dass er und welche Prinzipien er noch besser verinnerlichen muss. Diese physische Aktion hat einen eigenen Einfluss auf das Gehirn.

Sobald ein Entwickler dann auf einer Stufe 21 Tage ohne Wechseln des Armbands gearbeitet hat, kann er den Grad als gemeistert ansehen, zum nächsten übergehen und das nächste Armband überstreifen.

Natürlich gibt es keine formale Kontrolle, ob während eines Tages wirklich alle Prinzipien beachtet worden sind. Es liegt an der Ehrlichkeit jeder Einzelnen sich und der CCD-Community gegenüber, darüber nach bestem Wissen und Gewissen zu urteilen.

Da kein Grad besser oder schlechter ist als ein anderer, lohnt sich Mogelei ohnehin nicht. Entwickler*innen, die den weißen Grad gemeistert haben, beginnen wieder beim roten Grad. So demonstrieren sie ihre Überzeugung, dass Softwareentwicklung ständiges Lernen ist.

Mehr Infos unter
www.cleancodedeveloper.de

Augen-Logo Maria

OpenStreetMap Bremen: Mapping Party

Da fiel mir doch jetzt in Bremen ein Flyer in die Finger:

zur Website

Worum geht’s?

Treffen in Bremen, dann ausschwärmen, um die freie Weltkarte zu verbessern. Danach wird dann nett gefeiert.

Wann? 8. Sep. 2013 von 10:30 bis 17 h

Wo?

Hackerspace e. V., Bornstr. 14/15 in Bremen. Mitzubringen sind folgende Dinge, wenn Ihr sowas habt: Smartphone, GPS, Laptop, Kamera, Fahrrad, Schreibzeug… Wer Lust hat, kann sich vorher auch unverbindlich anmelden.

Mehr Infos:

osm-bremen.de

Augen-Logo Maria

Neuauflage Broschüre „Ingenieurinnen haben viele Gesichter“

Aus meinem Posteingang…

Die Neufassung der dib-Broschüre „Ingenieurinnen haben viele Gesichter“ macht Fortschritte. Vom 10. bis 24. Aug. 2013 findet eine Online-Feedbackrunde mit fünf bis sechs Fragen zum Entwurf statt. Dafür möchte man Mädchen (11. oder 12. Jahrgangsstufe) ansprechen. Interessierte können sich direkt an Inge Hack wenden:  inge.hack(beim)dibev.de

… meldet die Regionalgruppe Rhein-Ruhr des dib.

Augen-Logo Maria

„Linux-Programmiererin wehrt sich gegen Gewalt in der Sprache“

Aus meinem Posteingang…

Hallo,

hier ist ein Hinweis auf ein Interview „Why This Hacker Stood Up Against ‚Verbal Abuse‘ in Linux Land“ [1] mit einer Linux-Programmiererin, die sich gegen den respektlosen Umgangston und Beschimpfungen auf einer Linux-Kernel-Mailingliste wehrt. Dabei hat Sarah Sharp niemand Geringeren als Linus Torvalds kritisiert… (siehe [2] und [3]).

Viele Grüße
Wiebke

[1] „Why This Hacker Stood Up Against ‚Verbal Abuse‘ in Linux Land“ von Robert McMillan, 2013-07-19
www.wired.com/wiredenterprise/2013/07/sarah_sharp

[2] e-Mail von Sarah Sharp an Linus Torvalds et al. Sie schreibt dort: „I won’t be the nice girl anymore“
marc.info/?l=linux-kernel&m=137390362508794&w=2

[3] Link zum Blog von Sarah Sharp. Dort sind weitere interessante Blog-Einträge zum Thema „Frauen[anteil] in der Linux-Community“:
sarah.thesharps.us/2013/07/15/no-more-verbal-abuse

Augen-Logo Maria

Sommertipp: Freude macht Freude

zum Blog

Lest doch mal den Blog von Juli. Ich kenne sie nicht persönlich, sie hat als Ruhrpottkind aber natürlich meine Sympathie:
heimatpottential.blogspot.de.

Angefixt hat mich der Artikel zur Freude:
heimatpottential.blogspot.de/2013/07/eine-ode-freude-schafft-freude.html.

Sie hat aber noch mehr auf dem Kasten, sie hat 2012 nämlich das Netzwerk „Blogowski“ gegründet, mit derzeit run 40 Pott-Bloggerinnen, die nicht nur als Linkliste existieren, sondern sich monatlich auch persönlich treffen.

Augen-Logo Maria

„reif für MINT“ für Interessenten, die multiplizieren

Aus meinem Posteingang…

Das Jugendmagazin „reif für MINT“ kann ab sofort von Lehrer*innen, Hochschuldozent*innen und anderen Multiplikator*innen und Interessenten kostenlos bestellt werden. Im Heft werden Menschen und Projekte vorgestellt, die in der MINT-Forschung Bahnbrechendes leisten. Es geht um die Zukunft der 3D-Technik, um vernetztes Wohnen und Hirnforschung, um einen 18-Jährigen, der die Relativitätstheorie am Computer simuliert hat, und um eine 74-Jährige, die vor über 50 Jahren unter Männern Maschinenbau studiert hat. Es geht um Technik, Forschung, Innovation und Zukunft.
Das Magazin „reif für MINT“ kann kostenlos bestellt werden:

Augen-Logo Maria

ditact_women’s IT summerstudies 2013

Aus meinem Posteingang…

26. Aug. 2013 bis 7. Sep. 2013

Liebe ditact_Teilnehmerin!

Die ditact 2013 rückt näher, bis Mittwoch 31.Juli gibt es noch die Möglichkeit dich zu den Kursen anzumelden! Einen Überblick über das Angebot findest du auf www.ditact.ac.at. Und nicht vergessen: am 26. August findet das Opening statt, zu dem wir dich herzlich einladen!

Die ditact_women’s IT summerstudies 2013 wird mit dem Vortrag „Technische Innovation durch Geschlechterforschung? Mit wissenschaftlichen Methoden gegen Einseitigkeit und Stereotypisierung“ von Prof.in Dr.in Corinna Bath eröffnet.

Wir freuen und darauf dich bei der Sommeruni wieder zu sehen!

Liebe Grüße & ein schönes Wochenende,

Alexandra, Carina und Maria

Augen-Logo Maria