1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
|
/* hmgen.c CCMATH mathematics library source code.
*
* Copyright (C) 2000 Daniel A. Atkinson All rights reserved.
* This code may be redistributed under the terms of the GNU library
* public license (LGPL). ( See the lgpl.license file for details.)
* ------------------------------------------------------------------------
*/
#include <stdlib.h>
#include "ccmath.h"
void hmgen(Cpx *h, double *ev, Cpx *u, int n)
{
Cpx *v, *p;
int i, j;
double e;
v = (Cpx *)calloc(n * n, sizeof(Cpx));
cmcpy(v, u, n * n);
hconj(v, n);
for (i = 0, p = v; i < n; ++i) {
for (j = 0, e = ev[i]; j < n; ++j, ++p) {
p->re *= e;
p->im *= e;
}
}
cmmul(h, u, v, n);
free(v);
}
|