X-Git-Url: https://pd.if.org/git/?p=hexagon;a=blobdiff_plain;f=t%2Fcenter.c;fp=t%2Fcenter.c;h=eecb80c3b0f6c8a828a0fb9c8659833f36ffcd6d;hp=1c039c9de97aa391e009fc2bf5c264886af94945;hb=06868ef42497f1cbc480831029f5f69b395dfdd2;hpb=c5a7aa5029146b2bcea5daae53c6aa3e5e33ed04 diff --git a/t/center.c b/t/center.c index 1c039c9..eecb80c 100644 --- a/t/center.c +++ b/t/center.c @@ -4,27 +4,36 @@ #include "ctap.h" +#define EPS 0.00000001 + int main(void) { - int start, x, y; + int x, y; + struct HL_hex start; + struct HL_point center; + double stride; + + stride = 1.5 / sqrt(3.0); plan(6); x = 0; y = 0; - start = HL_cantor_xy(x,y); - ok(HL_center_x(start) == x * 1.5 / sqrt(3.0), "%d %d center X", x, y); - ok(HL_center_y(start) == 0.0, "%d %d center Y", x, y); + start = HL_hex_xy(x,y); + center = HL_hexcenter(start); + is_double(center.x, x * stride, EPS, "%d %d center X", x, y); + is_double(center.y, 0.0, EPS, "%d %d center Y", x, y); x = 1; y = 1; - start = HL_cantor_xy(x,y); - ok(HL_center_x(start) == x * 1.5 / sqrt(3.0), "%d %d center X", x, y); - ok(HL_center_y(start) == 0.5, "%d %d center Y = %f", x, y, - HL_center_y(start)); + start = HL_hex_xy(x,y); + center = HL_hexcenter(start); + is_double(center.x, x * stride, EPS, "%d %d center X", x, y); + is_double(center.y, 0.5, EPS, "%d %d center Y", x, y); + x = 2; y = 2; - start = HL_cantor_xy(x,y); - ok(HL_center_x(start) == x * 1.5 / sqrt(3.0), "%d %d center X", x, y); - ok(HL_center_y(start) == 2.0, "%d %d center Y = %f", x, y, - HL_center_y(start)); + start = HL_hex_xy(x,y); + center = HL_hexcenter(start); + is_double(center.x, x * stride, EPS, "%d %d center X", x, y); + is_double(center.y, 2.0, EPS, "%d %d center Y", x, y); return 0; }