189 SUBROUTINE csyr2k(UPLO,TRANS,N,K,ALPHA,A,LDA,B,LDB,BETA,C,LDC)
198 INTEGER K,LDA,LDB,LDC,N
202 COMPLEX A(lda,*),B(ldb,*),C(ldc,*)
219 INTEGER I,INFO,J,L,NROWA
224 parameter(one= (1.0e+0,0.0e+0))
226 parameter(zero= (0.0e+0,0.0e+0))
231 IF (lsame(trans,
'N'))
THEN
236 upper = lsame(uplo,
'U')
239 IF ((.NOT.upper) .AND. (.NOT.lsame(uplo,
'L')))
THEN
241 ELSE IF ((.NOT.lsame(trans,
'N')) .AND.
242 + (.NOT.lsame(trans,
'T')))
THEN
244 ELSE IF (n.LT.0)
THEN
246 ELSE IF (k.LT.0)
THEN
248 ELSE IF (lda.LT.max(1,nrowa))
THEN
250 ELSE IF (ldb.LT.max(1,nrowa))
THEN
252 ELSE IF (ldc.LT.max(1,n))
THEN
256 CALL xerbla(
'CSYR2K',info)
262 IF ((n.EQ.0) .OR. (((alpha.EQ.zero).OR.
263 + (k.EQ.0)).AND. (beta.EQ.one)))
RETURN
267 IF (alpha.EQ.zero)
THEN
269 IF (beta.EQ.zero)
THEN
283 IF (beta.EQ.zero)
THEN
302 IF (lsame(trans,
'N'))
THEN
308 IF (beta.EQ.zero)
THEN
312 ELSE IF (beta.NE.one)
THEN
318 IF ((a(j,l).NE.zero) .OR. (b(j,l).NE.zero))
THEN
322 c(i,j) = c(i,j) + a(i,l)*temp1 +
330 IF (beta.EQ.zero)
THEN
334 ELSE IF (beta.NE.one)
THEN
340 IF ((a(j,l).NE.zero) .OR. (b(j,l).NE.zero))
THEN
344 c(i,j) = c(i,j) + a(i,l)*temp1 +
361 temp1 = temp1 + a(l,i)*b(l,j)
362 temp2 = temp2 + b(l,i)*a(l,j)
364 IF (beta.EQ.zero)
THEN
365 c(i,j) = alpha*temp1 + alpha*temp2
367 c(i,j) = beta*c(i,j) + alpha*temp1 +
378 temp1 = temp1 + a(l,i)*b(l,j)
379 temp2 = temp2 + b(l,i)*a(l,j)
381 IF (beta.EQ.zero)
THEN
382 c(i,j) = alpha*temp1 + alpha*temp2
384 c(i,j) = beta*c(i,j) + alpha*temp1 +
subroutine xerbla(SRNAME, INFO)
XERBLA
subroutine csyr2k(UPLO, TRANS, N, K, ALPHA, A, LDA, B, LDB, BETA, C, LDC)
CSYR2K