⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 zgemm.c

📁 SuperLU 2.2版本。对大型、稀疏、非对称的线性系统的直接求解
💻 C
📖 第 1 页 / 共 2 页
字号:
			d_cnjg(&z__3, &A(l,i));			i__4 = l + j * b_dim1;			z__2.r = z__3.r * B(l,j).r - z__3.i * B(l,j).i, 				z__2.i = z__3.r * B(l,j).i + z__3.i * B(l,j)				.r;			z__1.r = temp.r + z__2.r, z__1.i = temp.i + z__2.i;			temp.r = z__1.r, temp.i = z__1.i;/* L100: */		    }		    if (beta->r == 0. && beta->i == 0.) {			i__3 = i + j * c_dim1;			z__1.r = alpha->r * temp.r - alpha->i * temp.i, 				z__1.i = alpha->r * temp.i + alpha->i * 				temp.r;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    } else {			i__3 = i + j * c_dim1;			z__2.r = alpha->r * temp.r - alpha->i * temp.i, 				z__2.i = alpha->r * temp.i + alpha->i * 				temp.r;			i__4 = i + j * c_dim1;			z__3.r = beta->r * C(i,j).r - beta->i * C(i,j).i, 				z__3.i = beta->r * C(i,j).i + beta->i * C(i,j).r;			z__1.r = z__2.r + z__3.r, z__1.i = z__2.i + z__3.i;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    }/* L110: */		}/* L120: */	    }	} else {/*           Form  C := alpha*A'*B + beta*C */	    i__1 = *n;	    for (j = 1; j <= *n; ++j) {		i__2 = *m;		for (i = 1; i <= *m; ++i) {		    temp.r = 0., temp.i = 0.;		    i__3 = *k;		    for (l = 1; l <= *k; ++l) {			i__4 = l + i * a_dim1;			i__5 = l + j * b_dim1;			z__2.r = A(l,i).r * B(l,j).r - A(l,i).i * B(l,j)				.i, z__2.i = A(l,i).r * B(l,j).i + A(l,i)				.i * B(l,j).r;			z__1.r = temp.r + z__2.r, z__1.i = temp.i + z__2.i;			temp.r = z__1.r, temp.i = z__1.i;/* L130: */		    }		    if (beta->r == 0. && beta->i == 0.) {			i__3 = i + j * c_dim1;			z__1.r = alpha->r * temp.r - alpha->i * temp.i, 				z__1.i = alpha->r * temp.i + alpha->i * 				temp.r;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    } else {			i__3 = i + j * c_dim1;			z__2.r = alpha->r * temp.r - alpha->i * temp.i, 				z__2.i = alpha->r * temp.i + alpha->i * 				temp.r;			i__4 = i + j * c_dim1;			z__3.r = beta->r * C(i,j).r - beta->i * C(i,j).i, 				z__3.i = beta->r * C(i,j).i + beta->i * C(i,j).r;			z__1.r = z__2.r + z__3.r, z__1.i = z__2.i + z__3.i;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    }/* L140: */		}/* L150: */	    }	}    } else if (nota) {	if (conjb) {/*           Form  C := alpha*A*conjg( B' ) + beta*C. */	    i__1 = *n;	    for (j = 1; j <= *n; ++j) {		if (beta->r == 0. && beta->i == 0.) {		    i__2 = *m;		    for (i = 1; i <= *m; ++i) {			i__3 = i + j * c_dim1;			C(i,j).r = 0., C(i,j).i = 0.;/* L160: */		    }		} else if (beta->r != 1. || beta->i != 0.) {		    i__2 = *m;		    for (i = 1; i <= *m; ++i) {			i__3 = i + j * c_dim1;			i__4 = i + j * c_dim1;			z__1.r = beta->r * C(i,j).r - beta->i * C(i,j).i, 				z__1.i = beta->r * C(i,j).i + beta->i * C(i,j).r;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;/* L170: */		    }		}		i__2 = *k;		for (l = 1; l <= *k; ++l) {		    i__3 = j + l * b_dim1;		    if (B(j,l).r != 0. || B(j,l).i != 0.) {			d_cnjg(&z__2, &B(j,l));			z__1.r = alpha->r * z__2.r - alpha->i * z__2.i, 				z__1.i = alpha->r * z__2.i + alpha->i * 				z__2.r;			temp.r = z__1.r, temp.i = z__1.i;			i__3 = *m;			for (i = 1; i <= *m; ++i) {			    i__4 = i + j * c_dim1;			    i__5 = i + j * c_dim1;			    i__6 = i + l * a_dim1;			    z__2.r = temp.r * A(i,l).r - temp.i * A(i,l).i, 				    z__2.i = temp.r * A(i,l).i + temp.i * A(i,l).r;			    z__1.r = C(i,j).r + z__2.r, z__1.i = C(i,j).i + 				    z__2.i;			    C(i,j).r = z__1.r, C(i,j).i = z__1.i;/* L180: */			}		    }/* L190: */		}/* L200: */	    }	} else {/*           Form  C := alpha*A*B'          + beta*C */	    i__1 = *n;	    for (j = 1; j <= *n; ++j) {		if (beta->r == 0. && beta->i == 0.) {		    i__2 = *m;		    for (i = 1; i <= *m; ++i) {			i__3 = i + j * c_dim1;			C(i,j).r = 0., C(i,j).i = 0.;/* L210: */		    }		} else if (beta->r != 1. || beta->i != 0.) {		    i__2 = *m;		    for (i = 1; i <= *m; ++i) {			i__3 = i + j * c_dim1;			i__4 = i + j * c_dim1;			z__1.r = beta->r * C(i,j).r - beta->i * C(i,j).i, 				z__1.i = beta->r * C(i,j).i + beta->i * C(i,j).r;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;/* L220: */		    }		}		i__2 = *k;		for (l = 1; l <= *k; ++l) {		    i__3 = j + l * b_dim1;		    if (B(j,l).r != 0. || B(j,l).i != 0.) {			i__3 = j + l * b_dim1;			z__1.r = alpha->r * B(j,l).r - alpha->i * B(j,l).i, 				z__1.i = alpha->r * B(j,l).i + alpha->i * B(j,l).r;			temp.r = z__1.r, temp.i = z__1.i;			i__3 = *m;			for (i = 1; i <= *m; ++i) {			    i__4 = i + j * c_dim1;			    i__5 = i + j * c_dim1;			    i__6 = i + l * a_dim1;			    z__2.r = temp.r * A(i,l).r - temp.i * A(i,l).i, 				    z__2.i = temp.r * A(i,l).i + temp.i * A(i,l).r;			    z__1.r = C(i,j).r + z__2.r, z__1.i = C(i,j).i + 				    z__2.i;			    C(i,j).r = z__1.r, C(i,j).i = z__1.i;/* L230: */			}		    }/* L240: */		}/* L250: */	    }	}    } else if (conja) {	if (conjb) {/*           Form  C := alpha*conjg( A' )*conjg( B' ) + beta*C. */	    i__1 = *n;	    for (j = 1; j <= *n; ++j) {		i__2 = *m;		for (i = 1; i <= *m; ++i) {		    temp.r = 0., temp.i = 0.;		    i__3 = *k;		    for (l = 1; l <= *k; ++l) {			d_cnjg(&z__3, &A(l,i));			d_cnjg(&z__4, &B(j,l));			z__2.r = z__3.r * z__4.r - z__3.i * z__4.i, z__2.i = 				z__3.r * z__4.i + z__3.i * z__4.r;			z__1.r = temp.r + z__2.r, z__1.i = temp.i + z__2.i;			temp.r = z__1.r, temp.i = z__1.i;/* L260: */		    }		    if (beta->r == 0. && beta->i == 0.) {			i__3 = i + j * c_dim1;			z__1.r = alpha->r * temp.r - alpha->i * temp.i, 				z__1.i = alpha->r * temp.i + alpha->i * 				temp.r;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    } else {			i__3 = i + j * c_dim1;			z__2.r = alpha->r * temp.r - alpha->i * temp.i, 				z__2.i = alpha->r * temp.i + alpha->i * 				temp.r;			i__4 = i + j * c_dim1;			z__3.r = beta->r * C(i,j).r - beta->i * C(i,j).i, 				z__3.i = beta->r * C(i,j).i + beta->i * C(i,j).r;			z__1.r = z__2.r + z__3.r, z__1.i = z__2.i + z__3.i;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    }/* L270: */		}/* L280: */	    }	} else {/*           Form  C := alpha*conjg( A' )*B' + beta*C */	    i__1 = *n;	    for (j = 1; j <= *n; ++j) {		i__2 = *m;		for (i = 1; i <= *m; ++i) {		    temp.r = 0., temp.i = 0.;		    i__3 = *k;		    for (l = 1; l <= *k; ++l) {			d_cnjg(&z__3, &A(l,i));			i__4 = j + l * b_dim1;			z__2.r = z__3.r * B(j,l).r - z__3.i * B(j,l).i, 				z__2.i = z__3.r * B(j,l).i + z__3.i * B(j,l)				.r;			z__1.r = temp.r + z__2.r, z__1.i = temp.i + z__2.i;			temp.r = z__1.r, temp.i = z__1.i;/* L290: */		    }		    if (beta->r == 0. && beta->i == 0.) {			i__3 = i + j * c_dim1;			z__1.r = alpha->r * temp.r - alpha->i * temp.i, 				z__1.i = alpha->r * temp.i + alpha->i * 				temp.r;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    } else {			i__3 = i + j * c_dim1;			z__2.r = alpha->r * temp.r - alpha->i * temp.i, 				z__2.i = alpha->r * temp.i + alpha->i * 				temp.r;			i__4 = i + j * c_dim1;			z__3.r = beta->r * C(i,j).r - beta->i * C(i,j).i, 				z__3.i = beta->r * C(i,j).i + beta->i * C(i,j).r;			z__1.r = z__2.r + z__3.r, z__1.i = z__2.i + z__3.i;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    }/* L300: */		}/* L310: */	    }	}    } else {	if (conjb) {/*           Form  C := alpha*A'*conjg( B' ) + beta*C */	    i__1 = *n;	    for (j = 1; j <= *n; ++j) {		i__2 = *m;		for (i = 1; i <= *m; ++i) {		    temp.r = 0., temp.i = 0.;		    i__3 = *k;		    for (l = 1; l <= *k; ++l) {			i__4 = l + i * a_dim1;			d_cnjg(&z__3, &B(j,l));			z__2.r = A(l,i).r * z__3.r - A(l,i).i * z__3.i, 				z__2.i = A(l,i).r * z__3.i + A(l,i).i * 				z__3.r;			z__1.r = temp.r + z__2.r, z__1.i = temp.i + z__2.i;			temp.r = z__1.r, temp.i = z__1.i;/* L320: */		    }		    if (beta->r == 0. && beta->i == 0.) {			i__3 = i + j * c_dim1;			z__1.r = alpha->r * temp.r - alpha->i * temp.i, 				z__1.i = alpha->r * temp.i + alpha->i * 				temp.r;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    } else {			i__3 = i + j * c_dim1;			z__2.r = alpha->r * temp.r - alpha->i * temp.i, 				z__2.i = alpha->r * temp.i + alpha->i * 				temp.r;			i__4 = i + j * c_dim1;			z__3.r = beta->r * C(i,j).r - beta->i * C(i,j).i, 				z__3.i = beta->r * C(i,j).i + beta->i * C(i,j).r;			z__1.r = z__2.r + z__3.r, z__1.i = z__2.i + z__3.i;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    }/* L330: */		}/* L340: */	    }	} else {/*           Form  C := alpha*A'*B' + beta*C */	    i__1 = *n;	    for (j = 1; j <= *n; ++j) {		i__2 = *m;		for (i = 1; i <= *m; ++i) {		    temp.r = 0., temp.i = 0.;		    i__3 = *k;		    for (l = 1; l <= *k; ++l) {			i__4 = l + i * a_dim1;			i__5 = j + l * b_dim1;			z__2.r = A(l,i).r * B(j,l).r - A(l,i).i * B(j,l)				.i, z__2.i = A(l,i).r * B(j,l).i + A(l,i)				.i * B(j,l).r;			z__1.r = temp.r + z__2.r, z__1.i = temp.i + z__2.i;			temp.r = z__1.r, temp.i = z__1.i;/* L350: */		    }		    if (beta->r == 0. && beta->i == 0.) {			i__3 = i + j * c_dim1;			z__1.r = alpha->r * temp.r - alpha->i * temp.i, 				z__1.i = alpha->r * temp.i + alpha->i * 				temp.r;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    } else {			i__3 = i + j * c_dim1;			z__2.r = alpha->r * temp.r - alpha->i * temp.i, 				z__2.i = alpha->r * temp.i + alpha->i * 				temp.r;			i__4 = i + j * c_dim1;			z__3.r = beta->r * C(i,j).r - beta->i * C(i,j).i, 				z__3.i = beta->r * C(i,j).i + beta->i * C(i,j).r;			z__1.r = z__2.r + z__3.r, z__1.i = z__2.i + z__3.i;			C(i,j).r = z__1.r, C(i,j).i = z__1.i;		    }/* L360: */		}/* L370: */	    }	}    }    return 0;/*     End of ZGEMM . */} /* zgemm_ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -