Monday, May 30, 2011

Du-Reform auf Deutsch!

Wie wäre es, wenn wir das Siezen im deutschsprachigen Raum abschaffen?

Und uns einfach alle Duzen und mit Vornamen anreden, so wie im Englischen?

Meiner Ansicht nach hätte das enorme Vorteile - um nur ein paar zu nennen:

  • Gespräche sind offener und direkter. Muss auf Höflichkeitsfloskeln Rücksicht genommen werden, wird oft um den heißen Brei geredet. Unter Duzpartnern kann Klartext geredet werden.
  • Gespräche sind entspannter. Warum gelten Amerikaner als entspannter verglichen mit Deutschen? Der kumpelhaftere Umgang miteinander und die Anrede mit Vornamen spielen sicherlich eine Rolle dabei.
  • Keine Unklarheiten mehr über die richtige Anrede. Wer war nicht schon einmal in einer Situation, in der nicht ganz klar war, ob man sein Gegenüber nun mit "du" anreden durfte oder nicht? Besonders kompliziert kann es werden, wenn man versucht, die direkte Anrede ganz zu vermeiden. 
  • Keine Konflikte, wenn Meinungsverschiedenheiten zum Thema Duzen herrschen. Schon einmal vom Vorgesetzten abgewatscht worden, weil man dem Kunden das "du" angeboten hat? Solche Auseinandersetzungen sind zeit- und nervenraubend und vollkommen nutzlos.
  • Wenn auf Englisch und Deutsch kommuniziert wird, z.B. in internationalen Geschäftsbeziehungen, müssen keine unterschiedlichen Anreden mehr verwendet werden: "Herr Müller" auf Deutsch, "Peter" auf Englisch. Dies vereinfacht die Kommunikation erheblich.
Ohnehin ist man doch heutzutage mit vielen Mitmenschen bereits per du:
  • mit Familienmitgliedern und Freunden
  • unter Schülern und Studenten
  • unter jungen Leuten (ca. unter 35)
  • in vielen Firmen, als Teil der Unternehmenskultur
  • in einigen Parteien (SPD, Grüne), Gewerkschaften und Vereinen
  • in der Kneipe, auf Festen ...
Also - wozu noch das "Sie"? Meine Ansicht nach ist das ein alter Zopf, den wir in den nächsten Jahren abschneiden sollten.

Was ist mit den Vorteilen des Siezens?

Selbstverständlich hat das Siezen auch Vorteile. Die Anrede mit dem förmlichen "Sie" schafft eine respektvolle Distanz, die in manchen Situationen durchaus gewünscht sein kann. Beispiele sind: Arbeitskollegen, insbesondere Vorgesetzte; Polizisten, Lehrer, Richter. Eine Beleidigung rutscht nicht schnell heraus, wenn man per "Sie" ist. 

Stimmt alles. Aber- im englischsprachigen Raum geht das alles auch, und zwar ohne das "Sie". Ein Richter wird mit "Your Honor" angesprochen, im Deutschen könnte man weiterhin "Herr Richter" sagen. Bei einem Polizisten, auf englisch mit "Officer" anzusprechen,  wird es schon etwas schwieriger: "Herr Wachtmeister" ist etwas altertümlich, "Herr Polizist" etwas ungewöhnlich. Aber auch da würde sich sicherlich die eine oder andere Formulierung durchsetzen. 

Und wenn eine Beleidigung nur deswegen nicht ausgesprochen wird, weil man sich gerade siezt, dann ist das doch eher ein Indikator für ein tiefersitzendes Problem. Offene und direkte Kommunikation, wie sie das Duzen fördert, lässt die Gesprächspartner diese ansprechen und lösen.


Wie ließe sich das umsetzen? 

Vermutlich nicht durch Erlass von Oben. Man erinnere sich an den enormen und vielschichten Widerstand gegen die Reform der deutschen Rechtschreibung, welche im Jahr 1996 durch die deutsche Kultusministerkonferenz eingeführt wurde. Schwer vorstellbar, dass die Bevölkerung für eine weitere Sprachreform per Regierungsdekret zu begeistern ist. Von den enormen Verwaltungskosten ganz zu schweigen.

Mein Vorschlag ist daher, die Idee einer "Du-Reform" von unten zu verbreiten und für Zustimmung zu werben - zum Beispiel durch:
  • T-Shirts, Mützen, Tassen etc. mit einem Logo für die "Du-Reform". Ein einfacher Aufhänger für ein Gespräch, sei es mit Kollegen, in der Straßenbahn, im Café ...
  • E-Mail Signatur, auch und insbesondere in der geschäftlichen Korrespondenz. Zum Beispiel so: 
---
Peter Müller
Bereichsleiter Logistik 
- Ich befürworte die Du-Reform und lade meine Gesprächspartner ein, mich mit "du" anzusprechen. -

  • Verbreitung auf sozialen Netzwerken (Facebook, XING, StudiVz ...)
  • Ansprechen von Personen, die als Multiplikator wirken können: Schriftsteller, Journalisten, Lehrer, Professoren, Führungskräfte ...
Übrigens, die skandinavischen Länder Schweden, Dänemark, Finnland, Norwegen und Island haben eine Du-Reform in den 1960er und 70er Jahren erfolgreich durchgeführt.

Was hältst DU davon?

Feedback, bitte! Falls ich auf Zustimmung stoße, werde ich als nächsten Schritt eine Webseite www.du-reform.de einrichten und dann umgehend die erste Ladung T-Shirts und Tassen produzieren :-) . Ach ja, falls jemand künstlerisch begabt ist und ein Logo entwerfen will...

Also - Du-Reform, ja oder nein?






Saturday, January 15, 2011

Facebook Hacker Cup team: please read for your post-mortem

Facebook have launched their annual Hacker Cup programming competition, basically a clone of Google's code jam. The idea is: using any programming language of your choice, implement algorithms that solve a set of given problems, then run them on a set of test cases and submit the results and your source code. For example, one of the problem sets of last week's qualification round was called "Double Squares". In this simple problem, a test case consisted of a single integer number X, and the requirement was:
For each value of X, you should output the number of ways to write X as the sum of two squares.
Sounds easy? It is: just check each integer number M between 0 and sqrt(X) whether X-M*M is a square of another integer, and make sure not to double-count number pairs.

The real challenge is to spend the right amount of up-front thinking about the solution before diving into the implementation. Since Facebook will grade your submission not only based on correctness, but also on time, you'll want to start hacking as soon as possible. But without a clear plan on what you're doing, you might easily overlook the easiest approach. Or, even implement a non-optimal algorithm that doesn't perform well enough on larger input sets. I made both mistakes with "Double Squares": instead of spending a few extra minutes on up-front thinking, I immediately jumped into coding and started by creating an array of all square numbers up to X (of course I will need them!), and then got stuck in some kind of brute-force algorithm which would probably would have run for days .

Now, you really wanna make sure your algorithm works and performs well enough even for large input sets: Facebook won't give you the "real" test cases with the problem statement, just a few sample ones. Only once you're confident enough in your solution is when you should click the "download input file" link - a timer will start, and you have precisely six minutes to run your code against the test cases and submit the results.

A couple of things went wrong during the qualification round: for one thing, while the instructions mentioned the 6 minute time window, they were easy to overlook. So, according to the angry comments of many participants, a lot of people downloaded all the test cases up-front, only to find their time limit exceeded at submission time. Also, there were reports of technical problems, in particular from people using Chrome who weren't able to save the input file to disk.

Facebook responded in a reasonable way: after a couple of hours, they lifted the six minute limit and allowed all participants to submit their solutions, although with a hefty time penalty. Fair enough, since solving one of the problems was sufficient to succeed to round 1. Also, they promised:

We're aware that things haven't gone very smoothly during the qualification round, and we're sorry that some of you experienced some frustration. I wanted to let you know what we're doing to improve things from here on. (...) First off, we've compiled a list of bugs in the interface and things that people have been confused by. We'll address all of these points before the next round. 
The next round, which was supposed to consist of three different sub-rounds at different time slots, was announced for this weekend. But things didn't quite go as expected... while the risk of accidentally starting the six minute timer was mitigated by a confirmation popup (good job on that one), here are some of the problems that I and probably hundreds of others experienced:

  1. "After the Dance Battle" was a maze problem which required finding the shortest path from start to exit, with some obstacles such as walls and the ability to "warp" from one field to another one with the same color. Fairly easy to solve if you've ever done a breadth-first search on a graph.

    Problems: the example input had 5 test cases, the example output had 6. So this was already confusing. But to make things worse, the actual input file was inconsistent with the example input, and your code was likely to fail with something like an "index out of bounds" exception. Good luck fixing it within six minutes, and make sure not to panic..

  2. "Power Overwhelming" was basically a constrained optimization problem. Given a budget M and the cost of a warrior (W) and a "shield generator" (G), find the optimal number of warriors and shields to buy to maximize damage to an opponent. Damage created was the number of generators times the number of warriors.

    Problems: The original problem statement was wrong and asked to output the number of warriors for the optimal solution - which was inconsistent with the sample output. After about an hour, Facebook silently updated the page, which now asked to output the number of generators of the optimal solution. Wow. Now suddenly, my algorithm worked with the test input set and returned the expected results for all test cases - except one, which also turned out to be wrong.

  3. Submitting the results and source code would only work occasionally, mostly clicking the submit button would not provide any feedback to the user - while the six minute timer was running down to zero. Again, don't panic!

  4. Facebook realized that there were technical problems with the submission, and I can't believe what their response was: about 30 minutes before the end the round, they announced:
Given the high rate of submission failures we are experiencing, we are shutting down the first subround a little early.

Wow. I can only imagine the angry and frustrated faces of all the participants who, despite all the challenges,  managed to come up with a working implementation ready for submission - only to find the competition close prematurely...

 Anyways, here's my unsolicited advice to the team at Facebook who manages the Hacker Cup:


  • Minimize the risk of faulty problem statements by applying the same sound engineering principles used to write software: seek multiple peer reviews, ask people to "test" the problems (including the input/output data) end to end. As soon as there is a strong draft of a new problem, use version control (no kidding) and review every diff carefully and by multiple people. Once a problem is finalized, "ship" it. No more last-minute-changes!

  • Do a dry run of the competition. Simulate real load on your back-ends to minimize the risk of technical problems during submission. Also, make sure the UI is always responsive ("Submitting...").


  • No real-time changes after a round has started. Even if a problem statement is faulty, stick to it - figure out how to grade the submissions later. Don't change any other basic conditions, such as the end time of the round: it makes people angry and frustrated. Only exception: extending a deadline to compensate for technical problems is acceptable. But, don't make these decisions ad-hoc: think through possible scenarios up-front and have contingency plans available.


That all being said, I think the actual problems were pretty cool and if it weren't for all these difficulties, it could have been lots of fun. Given that my qualification remains valid and Hacker Cup doesn't get completely cancelled, I'm looking forward to the next round.