/* * Written by Matthias Drochner . * Public domain. */ #include #include double carg(double complex z) { union C { double complex c; double x[2]; } c = { .c = z}; double x = c.x[0]; double y = c.x[1]; return atan2(y, x); }