1 #include <gsl/gsl_test.h>
2 #include <gsl/gsl_ieee_utils.h>
3 #include <gsl/gsl_math.h>
4 #include <gsl/gsl_cblas.h>
10 const double flteps = 1e-4, dbleps = 1e-6;
19 float A[] = { -0.617f, 0.179f, -0.626f, 0.334f };
21 float C[] = { 0.346f, -0.903f, 0.022f, -0.839f, -0.715f, 0.049f, -0.338f, 0.149f };
23 float C_expected[] = { 0.0346f, 0.0f, 0.0022f, -0.0839f, -0.715f, 0.049f, -0.0338f, 0.0f };
24 cblas_cherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
27 for (i = 0; i < 4; i++) {
28 gsl_test_rel(C[2*i], C_expected[2*i], flteps, "cherk(case 1598) real");
29 gsl_test_rel(C[2*i+1], C_expected[2*i+1], flteps, "cherk(case 1598) imag");
43 float A[] = { -0.356f, -0.308f, 0.493f, -0.351f };
45 float C[] = { -0.898f, -0.905f, 0.002f, -0.219f, 0.881f, 0.879f, 0.275f, -0.351f };
47 float C_expected[] = { -0.0898f, 0.0f, 0.002f, -0.219f, 0.0881f, 0.0879f, 0.0275f, 0.0f };
48 cblas_cherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
51 for (i = 0; i < 4; i++) {
52 gsl_test_rel(C[2*i], C_expected[2*i], flteps, "cherk(case 1599) real");
53 gsl_test_rel(C[2*i+1], C_expected[2*i+1], flteps, "cherk(case 1599) imag");
67 float A[] = { -0.103f, -0.951f, -0.601f, -0.041f };
69 float C[] = { -0.918f, -0.018f, 0.991f, -0.789f, -0.698f, -0.067f, 0.956f, -0.599f };
71 float C_expected[] = { -0.826499f, 0.0f, 1.00109f, -0.845733f, -0.698f, -0.067f, 0.992288f, 0.0f };
72 cblas_cherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
75 for (i = 0; i < 4; i++) {
76 gsl_test_rel(C[2*i], C_expected[2*i], flteps, "cherk(case 1600) real");
77 gsl_test_rel(C[2*i+1], C_expected[2*i+1], flteps, "cherk(case 1600) imag");
91 float A[] = { -0.237f, 0.925f, -0.904f, -0.091f };
93 float C[] = { -0.572f, 0.915f, 0.398f, 0.222f, 0.016f, 0.288f, -0.078f, -0.507f };
95 float C_expected[] = { -0.480821f, 0.0f, 0.398f, 0.222f, 0.0290073f, 0.373777f, 0.0045497f, 0.0f };
96 cblas_cherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
99 for (i = 0; i < 4; i++) {
100 gsl_test_rel(C[2*i], C_expected[2*i], flteps, "cherk(case 1601) real");
101 gsl_test_rel(C[2*i+1], C_expected[2*i+1], flteps, "cherk(case 1601) imag");
115 float A[] = { 0.963f, -0.23f, -0.435f, 0.289f };
117 float C[] = { 0.282f, -0.272f, -0.516f, -0.594f, -0.001f, 0.155f, -0.39f, -0.354f };
119 float C_expected[] = { -0.294081f, 0.0f, -0.516f, -0.594f, 0.145613f, -0.0534771f, -0.0818238f, 0.0f };
120 cblas_cherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
123 for (i = 0; i < 4; i++) {
124 gsl_test_rel(C[2*i], C_expected[2*i], flteps, "cherk(case 1602) real");
125 gsl_test_rel(C[2*i+1], C_expected[2*i+1], flteps, "cherk(case 1602) imag");
139 float A[] = { 0.674f, 0.1f, -0.098f, 0.552f };
141 float C[] = { 0.089f, -0.523f, -0.551f, 0.618f, 0.67f, 0.247f, 0.975f, -0.714f };
143 float C_expected[] = { -0.139283f, 0.0f, 0.0032556f, -0.114554f, 0.67f, 0.247f, -0.0942924f, 0.0f };
144 cblas_cherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
147 for (i = 0; i < 4; i++) {
148 gsl_test_rel(C[2*i], C_expected[2*i], flteps, "cherk(case 1603) real");
149 gsl_test_rel(C[2*i+1], C_expected[2*i+1], flteps, "cherk(case 1603) imag");
163 float A[] = { 0.033f, -0.864f, 0.168f, 0.524f };
165 float C[] = { 0.788f, 0.016f, -0.436f, 0.749f, -0.89f, -0.87f, 0.421f, -0.203f };
167 float C_expected[] = { 0.826385f, 0.0f, -0.436f, 0.749f, -0.536192f, -0.249444f, 0.3449f, 0.0f };
168 cblas_cherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
171 for (i = 0; i < 4; i++) {
172 gsl_test_rel(C[2*i], C_expected[2*i], flteps, "cherk(case 1604) real");
173 gsl_test_rel(C[2*i+1], C_expected[2*i+1], flteps, "cherk(case 1604) imag");
187 float A[] = { 0.957f, -0.079f, 0.935f, 0.232f };
189 float C[] = { -0.744f, -0.061f, 0.195f, -0.574f, 0.551f, 0.478f, -0.337f, 0.1f };
191 float C_expected[] = { 0.84769f, 0.0f, 0.895967f, -0.353289f, 0.551f, 0.478f, 0.894349f, 0.0f };
192 cblas_cherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
195 for (i = 0; i < 4; i++) {
196 gsl_test_rel(C[2*i], C_expected[2*i], flteps, "cherk(case 1605) real");
197 gsl_test_rel(C[2*i+1], C_expected[2*i+1], flteps, "cherk(case 1605) imag");
211 double A[] = { 0.934, 0.664, 0.426, 0.263 };
213 double C[] = { 0.251, -0.97, 0.76, -0.349, 0.152, -0.899, -0.17, 0.707 };
215 double C_expected[] = { 1.564252, 0.0, 1.332516, -0.311778, 0.152, -0.899, 0.080645, 0.0 };
216 cblas_zherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
219 for (i = 0; i < 4; i++) {
220 gsl_test_rel(C[2*i], C_expected[2*i], dbleps, "zherk(case 1606) real");
221 gsl_test_rel(C[2*i+1], C_expected[2*i+1], dbleps, "zherk(case 1606) imag");
235 double A[] = { 0.16, 0.464, -0.623, 0.776 };
237 double C[] = { 0.771, -0.449, 0.776, 0.112, -0.134, 0.317, 0.547, -0.551 };
239 double C_expected[] = { 1.011896, 0.0, 0.776, 0.112, 0.126384, -0.096232, 1.537305, 0.0 };
240 cblas_zherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
243 for (i = 0; i < 4; i++) {
244 gsl_test_rel(C[2*i], C_expected[2*i], dbleps, "zherk(case 1607) real");
245 gsl_test_rel(C[2*i+1], C_expected[2*i+1], dbleps, "zherk(case 1607) imag");
259 double A[] = { 0.787, 0.057, -0.49, 0.47 };
261 double C[] = { -0.758, 0.912, 0.992, -0.356, 0.584, 0.806, 0.965, 0.674 };
263 double C_expected[] = { -0.6957382, 0.0, 0.956116, -0.316218, 0.584, 0.806, 1.0111, 0.0 };
264 cblas_zherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
267 for (i = 0; i < 4; i++) {
268 gsl_test_rel(C[2*i], C_expected[2*i], dbleps, "zherk(case 1608) real");
269 gsl_test_rel(C[2*i+1], C_expected[2*i+1], dbleps, "zherk(case 1608) imag");
283 double A[] = { 0.961, -0.384, 0.165, 0.395 };
285 double C[] = { -0.186, 0.404, -0.873, 0.09, -0.451, -0.972, -0.203, -0.304 };
287 double C_expected[] = { -0.0789023, 0.0, -0.873, 0.09, -0.4503115, -0.9277045, -0.184675, 0.0 };
288 cblas_zherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
291 for (i = 0; i < 4; i++) {
292 gsl_test_rel(C[2*i], C_expected[2*i], dbleps, "zherk(case 1609) real");
293 gsl_test_rel(C[2*i+1], C_expected[2*i+1], dbleps, "zherk(case 1609) imag");
307 double A[] = { 0.04, 0.608, 0.21, -0.44 };
309 double C[] = { 0.285, -0.943, 0.581, -0.56, 0.112, 0.529, 0.16, -0.913 };
311 double C_expected[] = { -0.0855, 0.0, 0.581, -0.56, -0.0336, -0.1587, -0.048, 0.0 };
312 cblas_zherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
315 for (i = 0; i < 4; i++) {
316 gsl_test_rel(C[2*i], C_expected[2*i], dbleps, "zherk(case 1610) real");
317 gsl_test_rel(C[2*i+1], C_expected[2*i+1], dbleps, "zherk(case 1610) imag");
331 double A[] = { -0.984, -0.398, -0.379, 0.919 };
333 double C[] = { -0.44, -0.087, 0.156, -0.945, -0.943, -0.355, 0.577, 0.053 };
335 double C_expected[] = { 0.132, 0.0, -0.0468, 0.2835, -0.943, -0.355, -0.1731, 0.0 };
336 cblas_zherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
339 for (i = 0; i < 4; i++) {
340 gsl_test_rel(C[2*i], C_expected[2*i], dbleps, "zherk(case 1611) real");
341 gsl_test_rel(C[2*i+1], C_expected[2*i+1], dbleps, "zherk(case 1611) imag");
355 double A[] = { 0.269, -0.428, -0.029, 0.964 };
357 double C[] = { 0.473, -0.932, -0.689, -0.072, -0.952, -0.862, 0.001, 0.282 };
359 double C_expected[] = { -0.217455, 0.0, -0.689, -0.072, 0.531607, 0.615096, 0.929137, 0.0 };
360 cblas_zherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
363 for (i = 0; i < 4; i++) {
364 gsl_test_rel(C[2*i], C_expected[2*i], dbleps, "zherk(case 1612) real");
365 gsl_test_rel(C[2*i+1], C_expected[2*i+1], dbleps, "zherk(case 1612) imag");
379 double A[] = { -0.303, -0.037, -0.411, -0.243 };
381 double C[] = { 0.652, -0.227, -0.849, 0.87, -0.051, -0.535, 0.418, -0.681 };
383 double C_expected[] = { -0.558822, 0.0, 0.982524, -0.928422, -0.051, -0.535, -0.19003, 0.0 };
384 cblas_zherk(order, uplo, trans, N, K, alpha, A, lda, beta, C, ldc);
387 for (i = 0; i < 4; i++) {
388 gsl_test_rel(C[2*i], C_expected[2*i], dbleps, "zherk(case 1613) real");
389 gsl_test_rel(C[2*i+1], C_expected[2*i+1], dbleps, "zherk(case 1613) imag");