2
/* SUBROUTINE DLASSQ( N, X, INCX, SCALE, SUMSQ ) */
3
/* [scale,sumsq]=dlassq(x,[ scale, [sumsq]]) */
7
int ierr=0,un=1,deux=2,trois=3;
9
int mSCALE,nSCALE,lSCALE,mSUMSQ,nSUMSQ,lSUMSQ;
13
static int minlhs=1, minrhs=1, maxlhs=2, maxrhs=3;
14
CheckRhs(minrhs,maxrhs) ; CheckLhs(minlhs,maxlhs) ;
16
GetRhsVar(1, "d", &mX, &nX, &lX); /* X */
21
/* dlassq(x, scale, sumsq) */
22
GetRhsVar(2, "d", &mSCALE, &nSCALE, &lSCALE); /* SCALE */
23
GetRhsVar(3, "d", &mSUMSQ, &nSUMSQ, &lSUMSQ); /* SUMSQ */
26
/* dlassq(x, scale) */
28
GetRhsVar(2, "d", &mSCALE, &nSCALE, &lSCALE); /* SCALE */
29
CreateVar(3, "d", &un, &un, &lSUMSQ);
30
*stk(lSUMSQ)=SUMSQ; /* default */
35
CreateVar(2, "d", &un, &un, &lSCALE);
36
CreateVar(3, "d", &un, &un, &lSUMSQ);
37
*stk(lSUMSQ)=SUMSQ; *stk(lSCALE)=SCALE; /* default */
40
sciprint("%s: bad call to dassq",fname);
41
Error(9999); return 0;
43
C2F(dlassq)(&N , stk(lX), &un, stk(lSCALE), stk(lSUMSQ));
44
LhsVar(1) = 2; LhsVar(2) = 3; /* Return var #2 (SCALE) and #3 (SUMSQ) */