本文整理汇总了C++中PetscLogFlops函数的典型用法代码示例。如果您正苦于以下问题:C++ PetscLogFlops函数的具体用法?C++ PetscLogFlops怎么用?C++ PetscLogFlops使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了PetscLogFlops函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: AppCtxInitialize
/*
AppCtxInitialize - Sets initial values for the application context parameters
Input:
ptr - void user-defined application context
Output:
ptr - user-defined application context with the default or user-provided
parameters
*/
static int AppCtxInitialize(void *ptr) {
AppCtx *user = (AppCtx*)ptr;
PetscTruth flg;
int info;
/* Specify default parameters */
user->mx = user->my = 11;
user->b = -0.5;
user->t = 0.5;
user->l = -0.5;
user->r = 0.5;
user->fx=0.5;
user->fy=0.5;
user->bheight=0.0;
/* Check for command line arguments that override defaults */
info = PetscOptionsGetInt(TAO_NULL, "-mx", &user->mx, &flg); CHKERRQ(info);
info = PetscOptionsGetInt(TAO_NULL, "-my", &user->my, &flg); CHKERRQ(info);
info = PetscOptionsGetReal(TAO_NULL, "-bottom", &user->b, &flg); CHKERRQ(info);
info = PetscOptionsGetReal(TAO_NULL, "-top", &user->t, &flg); CHKERRQ(info);
info = PetscOptionsGetReal(TAO_NULL, "-left", &user->l, &flg); CHKERRQ(info);
info = PetscOptionsGetReal(TAO_NULL, "-right", &user->r, &flg); CHKERRQ(info);
info = PetscOptionsGetReal(PETSC_NULL,"-bmx",&user->fx,&flg); CHKERRQ(info);
info = PetscOptionsGetReal(PETSC_NULL,"-bmy",&user->fy,&flg); CHKERRQ(info);
info = PetscOptionsGetReal(PETSC_NULL,"-bheight",&user->bheight,&flg); CHKERRQ(info);
user->hx = (user->r - user->l) / (user->mx - 1);
user->hy = (user->t - user->b) / (user->my - 1);
user->area = 0.5 * user->hx * user->hy;
info = PetscLogFlops(8); CHKERRQ(info);
return 0;
} /* AppCtxInitialize */
示例2: PCApply_PBJacobi_7
static PetscErrorCode PCApply_PBJacobi_7(PC pc,Vec x,Vec y)
{
PC_PBJacobi *jac = (PC_PBJacobi*)pc->data;
PetscErrorCode ierr;
PetscInt i,m = jac->mbs;
const MatScalar *diag = jac->diag;
PetscScalar x0,x1,x2,x3,x4,x5,x6,*xx,*yy;
PetscFunctionBegin;
ierr = VecGetArray(x,&xx);CHKERRQ(ierr);
ierr = VecGetArray(y,&yy);CHKERRQ(ierr);
for (i=0; i<m; i++) {
x0 = xx[7*i]; x1 = xx[7*i+1]; x2 = xx[7*i+2]; x3 = xx[7*i+3]; x4 = xx[7*i+4]; x5 = xx[7*i+5]; x6 = xx[7*i+6];
yy[7*i] = diag[0]*x0 + diag[7]*x1 + diag[14]*x2 + diag[21]*x3 + diag[28]*x4 + diag[35]*x5 + diag[42]*x6;
yy[7*i+1] = diag[1]*x0 + diag[8]*x1 + diag[15]*x2 + diag[22]*x3 + diag[29]*x4 + diag[36]*x5 + diag[43]*x6;
yy[7*i+2] = diag[2]*x0 + diag[9]*x1 + diag[16]*x2 + diag[23]*x3 + diag[30]*x4 + diag[37]*x5 + diag[44]*x6;
yy[7*i+3] = diag[3]*x0 + diag[10]*x1 + diag[17]*x2 + diag[24]*x3 + diag[31]*x4 + diag[38]*x5 + diag[45]*x6;
yy[7*i+4] = diag[4]*x0 + diag[11]*x1 + diag[18]*x2 + diag[25]*x3 + diag[32]*x4 + diag[39]*x5 + diag[46]*x6;
yy[7*i+5] = diag[5]*x0 + diag[12]*x1 + diag[19]*x2 + diag[26]*x3 + diag[33]*x4 + diag[40]*x5 + diag[47]*x6;
yy[7*i+6] = diag[6]*x0 + diag[13]*x1 + diag[20]*x2 + diag[27]*x3 + diag[34]*x4 + diag[41]*x5 + diag[48]*x6;
diag += 49;
}
ierr = VecRestoreArray(x,&xx);CHKERRQ(ierr);
ierr = VecRestoreArray(y,&yy);CHKERRQ(ierr);
ierr = PetscLogFlops(80.0*m);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例3: MatSolve_SeqSBSTRM_5_NaturalOrdering_inplace
PetscErrorCode MatSolve_SeqSBSTRM_5_NaturalOrdering_inplace(Mat A,Vec bb,Vec xx)
{
Mat_SeqSBAIJ *a =(Mat_SeqSBAIJ*)A->data;
PetscInt mbs=a->mbs,*ai=a->i,*aj=a->j,bs=A->rmap->bs,bs2 = a->bs2;
PetscScalar *x,*b;
PetscErrorCode ierr;
Mat_SeqSBSTRM *sbstrm = (Mat_SeqSBSTRM*)A->spptr;
MatScalar *as =sbstrm->as;
PetscFunctionBegin;
#if 0
#endif
ierr = VecGetArray(bb,&b);CHKERRQ(ierr);
ierr = VecGetArray(xx,&x);CHKERRQ(ierr);
/* solve U^T * D * y = b by forward substitution */
ierr = PetscMemcpy(x,b,5*mbs*sizeof(PetscScalar));CHKERRQ(ierr); /* x <- b */
ierr = MatForwardSolve_SeqSBSTRM_5_NaturalOrdering(ai,aj,as,mbs,x);CHKERRQ(ierr);
/* solve U*x = y by back substitution */
ierr = MatBackwardSolve_SeqSBSTRM_5_NaturalOrdering(ai,aj,as,mbs,x);CHKERRQ(ierr);
ierr = VecRestoreArray(bb,&b);CHKERRQ(ierr);
ierr = VecRestoreArray(xx,&x);CHKERRQ(ierr);
ierr = PetscLogFlops(4.0*bs2*a->nz - (bs+2.0*bs2)*mbs);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例4: PCApply_PBJacobi_5
static PetscErrorCode PCApply_PBJacobi_5(PC pc,Vec x,Vec y)
{
PC_PBJacobi *jac = (PC_PBJacobi*)pc->data;
PetscErrorCode ierr;
PetscInt i,m = jac->mbs;
const MatScalar *diag = jac->diag;
PetscScalar x0,x1,x2,x3,x4,*xx,*yy;
PetscFunctionBegin;
ierr = VecGetArray(x,&xx);CHKERRQ(ierr);
ierr = VecGetArray(y,&yy);CHKERRQ(ierr);
for (i=0; i<m; i++) {
x0 = xx[5*i]; x1 = xx[5*i+1]; x2 = xx[5*i+2]; x3 = xx[5*i+3]; x4 = xx[5*i+4];
yy[5*i] = diag[0]*x0 + diag[5]*x1 + diag[10]*x2 + diag[15]*x3 + diag[20]*x4;
yy[5*i+1] = diag[1]*x0 + diag[6]*x1 + diag[11]*x2 + diag[16]*x3 + diag[21]*x4;
yy[5*i+2] = diag[2]*x0 + diag[7]*x1 + diag[12]*x2 + diag[17]*x3 + diag[22]*x4;
yy[5*i+3] = diag[3]*x0 + diag[8]*x1 + diag[13]*x2 + diag[18]*x3 + diag[23]*x4;
yy[5*i+4] = diag[4]*x0 + diag[9]*x1 + diag[14]*x2 + diag[19]*x3 + diag[24]*x4;
diag += 25;
}
ierr = VecRestoreArray(x,&xx);CHKERRQ(ierr);
ierr = VecRestoreArray(y,&yy);CHKERRQ(ierr);
ierr = PetscLogFlops(45.0*m);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例5: F
/*
ComputeFunction - Evaluates nonlinear function, F(x).
Input Parameters:
. X - input vector
. user - user-defined application context
Output Parameter:
. F - function vector
*/
PetscErrorCode ComputeFunction(AppCtx *user,Vec X,Vec F)
{
PetscErrorCode ierr;
PetscInt i,j,row,mx,my,xs,ys,xm,ym,gxs,gys,gxm,gym;
PetscReal two = 2.0,one = 1.0,lambda,hx,hy,hxdhy,hydhx,sc;
PetscScalar u,uxx,uyy,*x,*f;
Vec localX = user->localX;
mx = user->mx; my = user->my; lambda = user->param;
hx = one/(PetscReal)(mx-1); hy = one/(PetscReal)(my-1);
sc = hx*hy*lambda; hxdhy = hx/hy; hydhx = hy/hx;
/*
Scatter ghost points to local vector, using the 2-step process
DMGlobalToLocalBegin(), DMGlobalToLocalEnd().
By placing code between these two statements, computations can be
done while messages are in transition.
*/
ierr = DMGlobalToLocalBegin(user->da,X,INSERT_VALUES,localX);CHKERRQ(ierr);
ierr = DMGlobalToLocalEnd(user->da,X,INSERT_VALUES,localX);CHKERRQ(ierr);
/*
Get pointers to vector data
*/
ierr = VecGetArray(localX,&x);CHKERRQ(ierr);
ierr = VecGetArray(F,&f);CHKERRQ(ierr);
/*
Get local grid boundaries
*/
ierr = DMDAGetCorners(user->da,&xs,&ys,NULL,&xm,&ym,NULL);CHKERRQ(ierr);
ierr = DMDAGetGhostCorners(user->da,&gxs,&gys,NULL,&gxm,&gym,NULL);CHKERRQ(ierr);
/*
Compute function over the locally owned part of the grid
*/
for (j=ys; j<ys+ym; j++) {
row = (j - gys)*gxm + xs - gxs - 1;
for (i=xs; i<xs+xm; i++) {
row++;
if (i == 0 || j == 0 || i == mx-1 || j == my-1) {
f[row] = x[row];
continue;
}
u = x[row];
uxx = (two*u - x[row-1] - x[row+1])*hydhx;
uyy = (two*u - x[row-gxm] - x[row+gxm])*hxdhy;
f[row] = uxx + uyy - sc*PetscExpScalar(u);
}
}
/*
Restore vectors
*/
ierr = VecRestoreArray(localX,&x);CHKERRQ(ierr);
ierr = VecRestoreArray(F,&f);CHKERRQ(ierr);
ierr = PetscLogFlops(11.0*ym*xm);CHKERRQ(ierr);
return 0;
}
示例6: MatMultTranspose_SeqBSTRM_5
PetscErrorCode MatMultTranspose_SeqBSTRM_5(Mat A,Vec xx,Vec zz)
{
Mat_SeqBAIJ *a = (Mat_SeqBAIJ*)A->data;
Mat_SeqBSTRM *sbstrm = (Mat_SeqBSTRM*)A->spptr;
PetscScalar zero = 0.0;
PetscScalar *z = 0;
PetscScalar *x,*xb;
const MatScalar *v1, *v2, *v3, *v4, *v5;
PetscScalar x1, x2, x3, x4, x5;
PetscErrorCode ierr;
PetscInt mbs =a->mbs,i,*aj=a->j,*ai=a->i,n,*ib,cval,j;
PetscInt nonzerorow=0;
PetscInt slen;
PetscFunctionBegin;
ierr = VecSet(zz,zero);CHKERRQ(ierr);
ierr = VecGetArray(xx,&x);CHKERRQ(ierr);
ierr = VecGetArray(zz,&z);CHKERRQ(ierr);
slen = 5*(ai[mbs]-ai[0]);
v1 = sbstrm->as;
v2 = v1 + slen;
v3 = v2 + slen;
v4 = v3 + slen;
v5 = v4 + slen;
xb = x;
for (i=0; i<mbs; i++) {
n = ai[i+1] - ai[i];
nonzerorow += (n>0);
x1 = xb[0]; x2 = xb[1]; x3 = xb[2]; x4 = xb[3]; x5 = xb[4]; xb += 5;
ib = aj + ai[i];
PetscPrefetchBlock(ib+n,n,0,PETSC_PREFETCH_HINT_NTA); /* Indices for the next row (assumes same size as this one) */
PetscPrefetchBlock(v1+5*n,5*n,0,PETSC_PREFETCH_HINT_NTA); /* Entries for the next row */
PetscPrefetchBlock(v2+5*n,5*n,0,PETSC_PREFETCH_HINT_NTA); /* Entries for the next row */
PetscPrefetchBlock(v3+5*n,5*n,0,PETSC_PREFETCH_HINT_NTA); /* Entries for the next row */
PetscPrefetchBlock(v4+5*n,5*n,0,PETSC_PREFETCH_HINT_NTA); /* Entries for the next row */
PetscPrefetchBlock(v5+5*n,5*n,0,PETSC_PREFETCH_HINT_NTA); /* Entries for the next row */
for (j=0; j<n; j++) {
cval = ib[j]*5;
z[cval] += v1[0]*x1 + v2[0]*x2 + v3[0]*x3 + v4[0]*x4 + v5[0]*x5;
z[cval+1] += v1[1]*x1 + v2[1]*x2 + v3[1]*x3 + v4[1]*x4 + v5[1]*x5;
z[cval+2] += v1[2]*x1 + v2[2]*x2 + v3[2]*x3 + v4[2]*x4 + v5[2]*x5;
z[cval+3] += v1[3]*x1 + v2[3]*x2 + v3[3]*x3 + v4[3]*x4 + v5[3]*x5;
z[cval+4] += v1[4]*x1 + v2[4]*x2 + v3[4]*x3 + v4[4]*x4 + v5[4]*x5;
v1 += 5; v2 += 5; v3 += 5; v4 += 5; v5 += 5;
}
}
ierr = VecRestoreArray(xx,&x);CHKERRQ(ierr);
ierr = VecRestoreArray(zz,&z);CHKERRQ(ierr);
ierr = PetscLogFlops(50.0*a->nz - 5.0*nonzerorow);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例7: MatMult_AIJCRL
/*
Shared by both sequential and parallel versions of CRL matrix: MATMPIAIJCRL and MATSEQAIJCRL
- the scatter is used only in the parallel version
*/
PetscErrorCode MatMult_AIJCRL(Mat A,Vec xx,Vec yy)
{
Mat_AIJCRL *aijcrl = (Mat_AIJCRL*) A->spptr;
PetscInt m = aijcrl->m; /* Number of rows in the matrix. */
PetscInt rmax = aijcrl->rmax,*icols = aijcrl->icols;
PetscScalar *acols = aijcrl->acols;
PetscErrorCode ierr;
PetscScalar *x,*y;
#if !defined(PETSC_USE_FORTRAN_KERNEL_MULTCRL)
PetscInt i,j,ii;
#endif
#if defined(PETSC_HAVE_PRAGMA_DISJOINT)
#pragma disjoint(*x,*y,*aa)
#endif
PetscFunctionBegin;
if (aijcrl->xscat) {
ierr = VecCopy(xx,aijcrl->xwork);CHKERRQ(ierr);
/* get remote values needed for local part of multiply */
ierr = VecScatterBegin(aijcrl->xscat,xx,aijcrl->fwork,INSERT_VALUES,SCATTER_FORWARD);CHKERRQ(ierr);
ierr = VecScatterEnd(aijcrl->xscat,xx,aijcrl->fwork,INSERT_VALUES,SCATTER_FORWARD);CHKERRQ(ierr);
xx = aijcrl->xwork;
}
ierr = VecGetArray(xx,&x);CHKERRQ(ierr);
ierr = VecGetArray(yy,&y);CHKERRQ(ierr);
#if defined(PETSC_USE_FORTRAN_KERNEL_MULTCRL)
fortranmultcrl_(&m,&rmax,x,y,icols,acols);
#else
/* first column */
for (j=0; j<m; j++) y[j] = acols[j]*x[icols[j]];
/* other columns */
#if defined(PETSC_HAVE_CRAY_VECTOR)
#pragma _CRI preferstream
#endif
for (i=1; i<rmax; i++) {
ii = i*m;
#if defined(PETSC_HAVE_CRAY_VECTOR)
#pragma _CRI prefervector
#endif
for (j=0; j<m; j++) y[j] = y[j] + acols[ii+j]*x[icols[ii+j]];
}
#if defined(PETSC_HAVE_CRAY_VECTOR)
#pragma _CRI ivdep
#endif
#endif
ierr = PetscLogFlops(2.0*aijcrl->nz - m);CHKERRQ(ierr);
ierr = VecRestoreArray(xx,&x);CHKERRQ(ierr);
ierr = VecRestoreArray(yy,&y);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例8: VecAYPX_Seq
PetscErrorCode VecAYPX_Seq(Vec yin,PetscScalar alpha,Vec xin)
{
PetscErrorCode ierr;
PetscInt n = yin->map->n;
PetscScalar *yy;
const PetscScalar *xx;
PetscFunctionBegin;
if (alpha == (PetscScalar)0.0) {
ierr = VecCopy(xin,yin);CHKERRQ(ierr);
} else if (alpha == (PetscScalar)1.0) {
ierr = VecAXPY_Seq(yin,alpha,xin);CHKERRQ(ierr);
} else if (alpha == (PetscScalar)-1.0) {
PetscInt i;
ierr = VecGetArrayRead(xin,&xx);CHKERRQ(ierr);
ierr = VecGetArray(yin,&yy);CHKERRQ(ierr);
for (i=0; i<n; i++) {
yy[i] = xx[i] - yy[i];
}
ierr = VecRestoreArrayRead(xin,&xx);CHKERRQ(ierr);
ierr = VecRestoreArray(yin,&yy);CHKERRQ(ierr);
ierr = PetscLogFlops(1.0*n);CHKERRQ(ierr);
} else {
ierr = VecGetArrayRead(xin,&xx);CHKERRQ(ierr);
ierr = VecGetArray(yin,&yy);CHKERRQ(ierr);
#if defined(PETSC_USE_FORTRAN_KERNEL_AYPX)
{
PetscScalar oalpha = alpha;
fortranaypx_(&n,&oalpha,xx,yy);
}
#else
{
PetscInt i;
for (i=0; i<n; i++) {
yy[i] = xx[i] + alpha*yy[i];
}
}
#endif
ierr = VecRestoreArrayRead(xin,&xx);CHKERRQ(ierr);
ierr = VecRestoreArray(yin,&yy);CHKERRQ(ierr);
ierr = PetscLogFlops(2.0*n);CHKERRQ(ierr);
}
PetscFunctionReturn(0);
}
示例9: MatMult_SeqBSTRM_4
PetscErrorCode MatMult_SeqBSTRM_4(Mat A,Vec xx,Vec zz)
{
Mat_SeqBAIJ *a = (Mat_SeqBAIJ*)A->data;
Mat_SeqBSTRM *bstrm = (Mat_SeqBSTRM*)A->spptr;
PetscScalar *z = 0,sum1,sum2,sum3,sum4,x1,x2,x3,x4,*zarray;
const PetscScalar *x,*xb;
const MatScalar *v1, *v2, *v3, *v4;
PetscErrorCode ierr;
PetscInt mbs,i,*idx,*ii,j,n,*ridx=NULL,nonzerorow=0;
PetscBool usecprow=a->compressedrow.use;
PetscInt slen;
PetscFunctionBegin;
ierr = VecGetArray(xx,(PetscScalar**)&x);CHKERRQ(ierr);
ierr = VecGetArray(zz,&zarray);CHKERRQ(ierr);
idx = a->j;
if (usecprow) {
mbs = a->compressedrow.nrows;
ii = a->compressedrow.i;
ridx = a->compressedrow.rindex;
} else {
mbs = a->mbs;
ii = a->i;
z = zarray;
}
slen = 4*(ii[mbs]-ii[0]);
v1 = bstrm->as;
v2 = v1 + slen;
v3 = v2 + slen;
v4 = v3 + slen;
for (i=0; i<mbs; i++) {
n = ii[1] - ii[0]; ii++;
sum1 = 0.0; sum2 = 0.0; sum3 = 0.0; sum4 = 0.0;
nonzerorow += (n>0);
for (j=0; j<n; j++) {
xb = x + 4*(*idx++);
x1 = xb[0]; x2 = xb[1]; x3 = xb[2]; x4 = xb[3];
sum1 += v1[0]*x1 + v1[1]*x2 + v1[2]*x3 + v1[3]*x4;
sum2 += v2[0]*x1 + v2[1]*x2 + v2[2]*x3 + v2[3]*x4;
sum3 += v3[0]*x1 + v3[1]*x2 + v3[2]*x3 + v3[3]*x4;
sum4 += v4[0]*x1 + v4[1]*x2 + v4[2]*x3 + v4[3]*x4;
v1 += 4; v2 += 4; v3 += 4; v4 += 4;
}
if (usecprow) z = zarray + 4*ridx[i];
z[0] = sum1; z[1] = sum2; z[2] = sum3; z[3] = sum4;
if (!usecprow) z += 4;
}
ierr = VecRestoreArray(xx,(PetscScalar**)&x);CHKERRQ(ierr);
ierr = VecRestoreArray(zz,&zarray);CHKERRQ(ierr);
ierr = PetscLogFlops(32*a->nz - 4*nonzerorow);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例10: Gradiant
/*
Evaluates FU = Gradiant(L(w,u,lambda))
This local function acts on the ghosted version of U (accessed via DMCompositeGetLocalVectors() and
DMCompositeScatter()) BUT the global, nonghosted version of FU (via DMCompositeGetAccess()).
*/
PetscErrorCode ComputeFunction(SNES snes,Vec U,Vec FU,void *ctx)
{
PetscErrorCode ierr;
PetscInt xs,xm,i,N;
ULambda *u_lambda,*fu_lambda;
PetscScalar d,h,*w,*fw;
Vec vw,vfw,vu_lambda,vfu_lambda;
DM packer,red,da;
PetscFunctionBeginUser;
ierr = VecGetDM(U, &packer);CHKERRQ(ierr);
ierr = DMCompositeGetEntries(packer,&red,&da);CHKERRQ(ierr);
ierr = DMCompositeGetLocalVectors(packer,&vw,&vu_lambda);CHKERRQ(ierr);
ierr = DMCompositeScatter(packer,U,vw,vu_lambda);CHKERRQ(ierr);
ierr = DMCompositeGetAccess(packer,FU,&vfw,&vfu_lambda);CHKERRQ(ierr);
ierr = DMDAGetCorners(da,&xs,NULL,NULL,&xm,NULL,NULL);CHKERRQ(ierr);
ierr = DMDAGetInfo(da,0,&N,0,0,0,0,0,0,0,0,0,0,0);CHKERRQ(ierr);
ierr = VecGetArray(vw,&w);CHKERRQ(ierr);
ierr = VecGetArray(vfw,&fw);CHKERRQ(ierr);
ierr = DMDAVecGetArray(da,vu_lambda,&u_lambda);CHKERRQ(ierr);
ierr = DMDAVecGetArray(da,vfu_lambda,&fu_lambda);CHKERRQ(ierr);
d = N-1.0;
h = 1.0/d;
/* derivative of L() w.r.t. w */
if (xs == 0) { /* only first processor computes this */
fw[0] = -2.0*d*u_lambda[0].lambda;
}
/* derivative of L() w.r.t. u */
for (i=xs; i<xs+xm; i++) {
if (i == 0) fu_lambda[0].lambda = h*u_lambda[0].u + 2.*d*u_lambda[0].lambda - d*u_lambda[1].lambda;
else if (i == 1) fu_lambda[1].lambda = 2.*h*u_lambda[1].u + 2.*d*u_lambda[1].lambda - d*u_lambda[2].lambda;
else if (i == N-1) fu_lambda[N-1].lambda = h*u_lambda[N-1].u + 2.*d*u_lambda[N-1].lambda - d*u_lambda[N-2].lambda;
else if (i == N-2) fu_lambda[N-2].lambda = 2.*h*u_lambda[N-2].u + 2.*d*u_lambda[N-2].lambda - d*u_lambda[N-3].lambda;
else fu_lambda[i].lambda = 2.*h*u_lambda[i].u - d*(u_lambda[i+1].lambda - 2.0*u_lambda[i].lambda + u_lambda[i-1].lambda);
}
/* derivative of L() w.r.t. lambda */
for (i=xs; i<xs+xm; i++) {
if (i == 0) fu_lambda[0].u = 2.0*d*(u_lambda[0].u - w[0]);
else if (i == N-1) fu_lambda[N-1].u = 2.0*d*u_lambda[N-1].u;
else fu_lambda[i].u = -(d*(u_lambda[i+1].u - 2.0*u_lambda[i].u + u_lambda[i-1].u) - 2.0*h);
}
ierr = VecRestoreArray(vw,&w);CHKERRQ(ierr);
ierr = VecRestoreArray(vfw,&fw);CHKERRQ(ierr);
ierr = DMDAVecRestoreArray(da,vu_lambda,&u_lambda);CHKERRQ(ierr);
ierr = DMDAVecRestoreArray(da,vfu_lambda,&fu_lambda);CHKERRQ(ierr);
ierr = DMCompositeRestoreLocalVectors(packer,&vw,&vu_lambda);CHKERRQ(ierr);
ierr = DMCompositeRestoreAccess(packer,FU,&vfw,&vfu_lambda);CHKERRQ(ierr);
ierr = PetscLogFlops(13.0*N);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例11: MSA_InitialPoint
/*
MSA_InitialPoint - Calculates the initial guess in one of three ways.
Input Parameters:
. user - user-defined application context
. X - vector for initial guess
Output Parameters:
. X - newly computed initial guess
*/
static int MSA_InitialPoint(AppCtx * user, Vec X)
{
int info;
PetscInt start2=-1,i,j;
PetscReal start1=0;
PetscTruth flg1,flg2;
info = PetscOptionsGetReal(PETSC_NULL,"-start",&start1,&flg1); CHKERRQ(info);
info = PetscOptionsGetInt(PETSC_NULL,"-random",&start2,&flg2); CHKERRQ(info);
if (flg1){ /* The zero vector is reasonable */
info = VecSet(X, start1); CHKERRQ(info);
} else if (flg2 && start2>0){ /* Try a random start between -0.5 and 0.5 */
PetscRandom rctx; PetscScalar np5=-0.5;
info = PetscRandomCreate(PETSC_COMM_WORLD,&rctx);
CHKERRQ(info);
for (i=0; i<start2; i++){
info = VecSetRandom(X, rctx); CHKERRQ(info);
}
info = PetscRandomDestroy(rctx); CHKERRQ(info);
info = VecShift(X, np5); CHKERRQ(info);
} else { /* Take an average of the boundary conditions */
PetscInt xs,xm,ys,ym;
PetscInt mx=user->mx,my=user->my;
PetscScalar **x;
/* Get local mesh boundaries */
info = DAGetCorners(user->da,&xs,&ys,PETSC_NULL,&xm,&ym,PETSC_NULL); CHKERRQ(info);
/* Get pointers to vector data */
info = DAVecGetArray(user->da,X,(void**)&x);
/* Perform local computations */
for (j=ys; j<ys+ym; j++){
for (i=xs; i< xs+xm; i++){
x[j][i] = ( ((j+1)*user->bottom[i-xs+1]+(my-j+1)*user->top[i-xs+1])/(my+2)+
((i+1)*user->left[j-ys+1]+(mx-i+1)*user->right[j-ys+1])/(mx+2))/2.0;
}
}
/* Restore vectors */
info = DAVecRestoreArray(user->da,X,(void**)&x); CHKERRQ(info);
info = PetscLogFlops(9*xm*ym); CHKERRQ(info);
}
return 0;
}
示例12: ILU
/*
Special case where the matrix was ILU(0) factored in the natural
ordering. This eliminates the need for the column and row permutation.
*/
PetscErrorCode MatSolve_SeqBAIJ_1_NaturalOrdering_inplace(Mat A,Vec bb,Vec xx)
{
Mat_SeqBAIJ *a = (Mat_SeqBAIJ*)A->data;
const PetscInt n = a->mbs,*vi,*ai=a->i,*aj=a->j,*diag=a->diag;
PetscErrorCode ierr;
const MatScalar *aa=a->a,*v;
PetscScalar *x;
const PetscScalar *b;
PetscScalar s1,x1;
PetscInt jdx,idt,idx,nz,i;
PetscFunctionBegin;
ierr = VecGetArrayRead(bb,&b);CHKERRQ(ierr);
ierr = VecGetArray(xx,&x);CHKERRQ(ierr);
/* forward solve the lower triangular */
idx = 0;
x[0] = b[0];
for (i=1; i<n; i++) {
v = aa + ai[i];
vi = aj + ai[i];
nz = diag[i] - ai[i];
idx += 1;
s1 = b[idx];
while (nz--) {
jdx = *vi++;
x1 = x[jdx];
s1 -= v[0]*x1;
v += 1;
}
x[idx] = s1;
}
/* backward solve the upper triangular */
for (i=n-1; i>=0; i--) {
v = aa + diag[i] + 1;
vi = aj + diag[i] + 1;
nz = ai[i+1] - diag[i] - 1;
idt = i;
s1 = x[idt];
while (nz--) {
idx = *vi++;
x1 = x[idx];
s1 -= v[0]*x1;
v += 1;
}
v = aa + diag[i];
x[idt] = v[0]*s1;
}
ierr = VecRestoreArrayRead(bb,&b);CHKERRQ(ierr);
ierr = VecRestoreArray(xx,&x);CHKERRQ(ierr);
ierr = PetscLogFlops(2.0*(a->nz) - A->cmap->n);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例13: EvaluateFunction
PetscErrorCode EvaluateFunction(Tao tao, Vec X, Vec F, void *ptr)
{
AppCtx *user = (AppCtx *)ptr;
PetscInt i;
PetscReal *x,*f;
PetscErrorCode ierr;
PetscFunctionBegin;
ierr = VecGetArray(X,&x);CHKERRQ(ierr);
ierr = VecGetArray(F,&f);CHKERRQ(ierr);
if (user->size == 1) {
/* Single processor */
for (i=0;i<NOBSERVATIONS;i++) {
ierr = RunSimulation(x,i,&f[i],user);CHKERRQ(ierr);
}
} else {
/* Multiprocessor master */
PetscMPIInt tag;
PetscInt finishedtasks,next_task,checkedin;
PetscReal f_i;
MPI_Status status;
next_task=0;
finishedtasks=0;
checkedin=0;
while(finishedtasks < NOBSERVATIONS || checkedin < user->size-1) {
ierr = MPI_Recv(&f_i,1,MPIU_REAL,MPI_ANY_SOURCE,MPI_ANY_TAG,PETSC_COMM_WORLD,&status);CHKERRQ(ierr);
if (status.MPI_TAG == IDLE_TAG) {
checkedin++;
} else {
tag = status.MPI_TAG;
f[tag] = (PetscReal)f_i;
finishedtasks++;
}
if (next_task<NOBSERVATIONS) {
ierr = MPI_Send(x,NPARAMETERS,MPIU_REAL,status.MPI_SOURCE,next_task,PETSC_COMM_WORLD);CHKERRQ(ierr);
next_task++;
} else {
/* Send idle message */
ierr = MPI_Send(x,NPARAMETERS,MPIU_REAL,status.MPI_SOURCE,IDLE_TAG,PETSC_COMM_WORLD);CHKERRQ(ierr);
}
}
}
ierr = VecRestoreArray(X,&x);CHKERRQ(ierr);
ierr = VecRestoreArray(F,&f);CHKERRQ(ierr);
PetscLogFlops(6*NOBSERVATIONS);
PetscFunctionReturn(0);
}
示例14: MatScale_MPIDense
PetscErrorCode MatScale_MPIDense(Mat inA,PetscScalar alpha)
{
Mat_MPIDense *A = (Mat_MPIDense*)inA->data;
Mat_SeqDense *a = (Mat_SeqDense*)A->A->data;
PetscScalar oalpha = alpha;
PetscErrorCode ierr;
PetscBLASInt one = 1,nz = PetscBLASIntCast(inA->rmap->n*inA->cmap->N);
PetscFunctionBegin;
BLASscal_(&nz,&oalpha,a->v,&one);
ierr = PetscLogFlops(nz);CHKERRQ(ierr);
PetscFunctionReturn(0);
}
示例15: FormIFunctionLocal
PetscErrorCode FormIFunctionLocal(DMDALocalInfo *info,PetscScalar ptime,PetscScalar **x,PetscScalar **xt,PetscScalar **f,void *ctx)
{
PetscErrorCode ierr;
PetscInt i,j;
PetscReal hx,hy,hxdhy,hydhx,scale;
PetscScalar u,uxx,uyy;
Vec C;
PetscScalar **c;
PetscFunctionBeginUser;
ierr = DMGetNamedGlobalVector(info->da,"coefficient",&C);CHKERRQ(ierr);
ierr = DMDAVecGetArray(info->da,C,&c);CHKERRQ(ierr);
hx = 10.0/((PetscReal)(info->mx-1));
hy = 10.0/((PetscReal)(info->my-1));
/*
dhx = 1. / hx;
dhy = 1. / hy;
*/
hxdhy = hx/hy;
hydhx = hy/hx;
scale = hx*hy;
for (j=info->ys; j<info->ys+info->ym; j++) {
for (i=info->xs; i<info->xs+info->xm; i++) {
f[j][i] = xt[j][i]*scale;
if (i == 0) {
/* f[j][i] += (x[j][i] - x[j][i+1])*dhx; */
} else if (i == info->mx-1) {
/* f[j][i] += (x[j][i] - x[j][i-1])*dhx; */
} else if (j == 0) {
/* f[j][i] += (x[j][i] - x[j+1][i])*dhy; */
} else if (j == info->my-1) {
/* f[j][i] += (x[j][i] - x[j-1][i])*dhy; */
} else {
u = x[j][i];
uyy = (2.0*u - x[j-1][i] - x[j+1][i])*hxdhy;
uxx = (2.0*u - x[j][i-1] - x[j][i+1])*hydhx;
f[j][i] += c[j][i]*(uxx + uyy);
}
}
}
ierr = PetscLogFlops(11.*info->ym*info->xm);CHKERRQ(ierr);
ierr = DMDAVecRestoreArray(info->da,C,&c);CHKERRQ(ierr);
ierr = DMRestoreNamedGlobalVector(info->da,"coefficient",&C);CHKERRQ(ierr);
PetscFunctionReturn(0);
}