diff options
author | Russ Cox <rsc@golang.org> | 2010-06-18 15:46:00 -0700 |
---|---|---|
committer | Russ Cox <rsc@golang.org> | 2010-06-18 15:46:00 -0700 |
commit | 9ca9a403b7cc7b20780492aea9ee46844b34f302 (patch) | |
tree | 856ce616828c0b3474d915b46ce5f07aba23fe51 /test/cmplxdivide.c | |
parent | 019a0f72006e4f0d19114f5bd92a91b4b29b0a93 (diff) | |
download | go-9ca9a403b7cc7b20780492aea9ee46844b34f302.tar.gz |
complex divide: match C99 implementation
R=iant, ken2, r, r2, ken3
CC=golang-dev
http://codereview.appspot.com/1686044
Diffstat (limited to 'test/cmplxdivide.c')
-rw-r--r-- | test/cmplxdivide.c | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/test/cmplxdivide.c b/test/cmplxdivide.c new file mode 100644 index 000000000..63473ba6c --- /dev/null +++ b/test/cmplxdivide.c @@ -0,0 +1,61 @@ +// Copyright 2010 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// gcc '-std=c99' cmplxdivide.c && a.out >cmplxdivide1.go + +#include <complex.h> +#include <math.h> +#include <stdio.h> +#include <string.h> + +#define nelem(x) (sizeof(x)/sizeof((x)[0])) + +double f[] = { + 0, + 1, + -1, + 2, + NAN, + INFINITY, + -INFINITY, +}; + +char* +fmt(double g) +{ + static char buf[10][30]; + static int n; + char *p; + + p = buf[n++]; + if(n == 10) + n = 0; + sprintf(p, "%g", g); + if(strcmp(p, "-0") == 0) + strcpy(p, "negzero"); + return p; +} + +int +main(void) +{ + int i, j, k, l; + double complex n, d, q; + + printf("// # generated by cmplxdivide.c\n"); + printf("\n"); + printf("package main\n"); + printf("var tests = []Test{\n"); + for(i=0; i<nelem(f); i++) + for(j=0; j<nelem(f); j++) + for(k=0; k<nelem(f); k++) + for(l=0; l<nelem(f); l++) { + n = f[i] + f[j]*I; + d = f[k] + f[l]*I; + q = n/d; + printf("\tTest{cmplx(%s, %s), cmplx(%s, %s), cmplx(%s, %s)},\n", fmt(creal(n)), fmt(cimag(n)), fmt(creal(d)), fmt(cimag(d)), fmt(creal(q)), fmt(cimag(q))); + } + printf("}\n"); + return 0; +} |