void twoD_diffusion_problem<Scalar,MeshScalar,BasisScalar,LocalOrdinal,GlobalOrdinal, Node>:: computeResponse(const Tpetra_Vector& x, const Tpetra_Vector& p, Tpetra_Vector& g) { // g = average of x Teuchos::ArrayRCP<Scalar> g_view = g.get1dViewNonConst(); x.meanValue(g_view()); g_view[0] *= Scalar(x.getGlobalLength()) / Scalar(mesh.size()); }
void Albany::SolutionTwoNormResponseFunction:: evaluateResponseT(const double current_time, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, Tpetra_Vector& gT) { Teuchos::ScalarTraits<ST>::magnitudeType twonorm = xT.norm2(); Teuchos::ArrayRCP<ST> gT_nonconstView = gT.get1dViewNonConst(); gT_nonconstView[0] = twonorm; }
void Albany::SolutionAverageResponseFunction:: evaluateResponseT(const double current_time, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, Tpetra_Vector& gT) { ST mean = xT.meanValue(); Teuchos::ArrayRCP<ST> gT_nonconstView = gT.get1dViewNonConst(); gT_nonconstView[0] = mean; }
void Albany::SolutionMaxValueResponseFunction:: evaluateGradientT(const double current_time, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, ParamVec* deriv_p, Tpetra_Vector* gT, Tpetra_MultiVector* dg_dxT, Tpetra_MultiVector* dg_dxdotT, Tpetra_MultiVector* dg_dxdotdotT, Tpetra_MultiVector* dg_dpT) { int global_index; double mxv; computeMaxValueT(xT, mxv, global_index); // Evaluate response g if (gT != NULL) { Teuchos::ArrayRCP<ST> gT_nonconstView = gT->get1dViewNonConst(); gT_nonconstView[0] = mxv; } Teuchos::ArrayRCP<const ST> xT_constView = xT.get1dView(); // Evaluate dg/dx if (dg_dxT != NULL) { Teuchos::ArrayRCP<ST> dg_dxT_nonconstView; int im = -1; for (int i=0; i<xT.getMap()->getNodeNumElements(); i++) { dg_dxT_nonconstView = dg_dxT->getDataNonConst(0); if (xT_constView[i] == mxv) { dg_dxT_nonconstView[i] = 1.0; im = i; } else dg_dxT_nonconstView[i] = 0.0; } } // Evaluate dg/dxdot if (dg_dxdotT != NULL) dg_dxdotT->putScalar(0.0); if (dg_dxdotdotT != NULL) dg_dxdotdotT->putScalar(0.0); // Evaluate dg/dp if (dg_dpT != NULL) dg_dpT->putScalar(0.0); }
void Albany::SolutionAverageResponseFunction:: evaluateTangentT(const double alpha, const double beta, const double omega, const double current_time, bool sum_derivs, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, ParamVec* deriv_p, const Tpetra_MultiVector* VxdotT, const Tpetra_MultiVector* VxdotdotT, const Tpetra_MultiVector* VxT, const Tpetra_MultiVector* VpT, Tpetra_Vector* gT, Tpetra_MultiVector* gxT, Tpetra_MultiVector* gpT) { // Evaluate response g if (gT != NULL) { ST mean = xT.meanValue(); Teuchos::ArrayRCP<ST> gT_nonconstView = gT->get1dViewNonConst(); gT_nonconstView[0] = mean; } // Evaluate tangent of g = dg/dx*Vx + dg/dxdot*Vxdot + dg/dp*Vp // If Vx == NULL, Vx is the identity if (gxT != NULL) { Teuchos::ArrayRCP<ST> gxT_nonconstView; if (VxT != NULL) { Teuchos::Array<ST> means; means.resize(VxT->getNumVectors()); VxT->meanValue(means()); for (int j=0; j<VxT->getNumVectors(); j++) { gxT_nonconstView = gxT->getDataNonConst(j); gxT_nonconstView[0] = means[j]; } } else { gxT->putScalar(1.0/xT.getGlobalLength()); } gxT->scale(alpha); } if (gpT != NULL) gpT->putScalar(0.0); }
//============================================================================== int Ifpack2_LocalFilter::ExtractDiagonalCopy(Tpetra_Vector & Diagonal) const { if (!Diagonal.Map().SameAs(*Map_)) IFPACK2_CHK_ERR(-1); Diagonal = *Diagonal_; return(0); }
void Albany::GenericSTKFieldContainer<Interleaved>::fillVectorHelperT(Tpetra_Vector &solnT, ScalarFieldType *solution_field, const Teuchos::RCP<const Tpetra_Map>& node_mapT, const stk::mesh::Bucket & bucket, int offset){ // Fill the result vector // Create a multidimensional array view of the // solution field data for this bucket of nodes. // The array is two dimensional ( Cartesian X NumberNodes ) // and indexed by ( 0..2 , 0..NumberNodes-1 ) BucketArray<ScalarFieldType> solution_array(*solution_field, bucket); const int num_nodes_in_bucket = solution_array.dimension(0); stk::mesh::BulkData& mesh = solution_field->get_mesh(); for (std::size_t i=0; i < num_nodes_in_bucket; i++) { const GO node_gid = mesh.identifier(bucket[i]) - 1; int node_lid = node_mapT->getLocalElement(node_gid); solnT.replaceLocalValue(getDOF(node_lid, offset), solution_array(i)); } }
void Albany::GenericSTKFieldContainer<Interleaved>::saveVectorHelperT(const Tpetra_Vector& solnT, ScalarFieldType* solution_field, const Teuchos::RCP<const Tpetra_Map>& node_mapT, const stk::mesh::Bucket& bucket, int offset) { // Fill the result vector // Create a multidimensional array view of the // solution field data for this bucket of nodes. // The array is two dimensional ( Cartesian X NumberNodes ) // and indexed by ( 0..2 , 0..NumberNodes-1 ) BucketArray<ScalarFieldType> solution_array(*solution_field, bucket); const int num_nodes_in_bucket = solution_array.dimension(0); stk::mesh::BulkData& mesh = solution_field->get_mesh(); //get const (read-only) view of solnT Teuchos::ArrayRCP<const ST> solnT_constView = solnT.get1dView(); for(std::size_t i = 0; i < num_nodes_in_bucket; i++) { const GO node_gid = mesh.identifier(bucket[i]) - 1; if(node_mapT->getLocalElement(node_gid) != Teuchos::OrdinalTraits<LO>::invalid()){ int node_lid = node_mapT->getLocalElement(node_gid); solution_array(i) = solnT_constView[getDOF(node_lid, offset)]; } } }
//============================================================================== int Ifpack2_ReorderFilter:: ExtractDiagonalCopy(Tpetra_Vector & Diagonal) const { Tpetra_Vector DiagonalTilde(Diagonal.Map()); IFPACK2_CHK_ERR(Matrix()->ExtractDiagonalCopy(DiagonalTilde)); IFPACK2_CHK_ERR((Reordering_->P(DiagonalTilde,Diagonal))); return(0); }
void Albany::SolutionTwoNormResponseFunction:: evaluateGradientT(const double current_time, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, ParamVec* deriv_p, Tpetra_Vector* gT, Tpetra_MultiVector* dg_dxT, Tpetra_MultiVector* dg_dxdotT, Tpetra_MultiVector* dg_dxdotdotT, Tpetra_MultiVector* dg_dpT) { Teuchos::ScalarTraits<ST>::magnitudeType nrm = xT.norm2(); // Evaluate response g Teuchos::ArrayRCP<ST> gT_nonconstView; if (gT != NULL) { gT_nonconstView = gT->get1dViewNonConst(); gT_nonconstView[0] = nrm; } // Evaluate dg/dx if (dg_dxT != NULL) { //double nrm; if (gT != NULL) nrm = gT_nonconstView[0]; else nrm = xT.norm2(); dg_dxT->scale(1.0/nrm,xT); } // Evaluate dg/dxdot if (dg_dxdotT != NULL) dg_dxdotT->putScalar(0.0); if (dg_dxdotdotT != NULL) dg_dxdotdotT->putScalar(0.0); // Evaluate dg/dp if (dg_dpT != NULL) dg_dpT->putScalar(0.0); }
void Albany::AlbanyPeridigmOBCFunctional:: evaluateResponseT(const double current_time, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, Tpetra_Vector& gT) { LCM::PeridigmManager& peridigmManager = *LCM::PeridigmManager::self(); Teuchos::ArrayRCP<ST> gT_nonconstView = gT.get1dViewNonConst(); peridigmManager.obcOverlappingElementSearch(); gT_nonconstView[0] = peridigmManager.obcEvaluateFunctional(); }
void Albany::SolutionMaxValueResponseFunction:: evaluateResponseT(const double current_time, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, Tpetra_Vector& gT) { int index; Teuchos::ArrayRCP<ST> gT_nonconstView = gT.get1dViewNonConst(); computeMaxValueT(xT, gT_nonconstView[0], index); }
void twoD_diffusion_problem<Scalar,MeshScalar,BasisScalar,LocalOrdinal,GlobalOrdinal, Node>:: computeResidual(const Tpetra_Vector& x, const Tpetra_Vector& p, Tpetra_Vector& f) { // f = A*x - b if (log_normal) computeA(*lnFunc, p, *A); else computeA(*klFunc, p, *A); A->apply(x,f); f.update(-1.0, *b, 1.0); }
void Albany::SolutionAverageResponseFunction:: evaluateGradientT(const double current_time, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, ParamVec* deriv_p, Tpetra_Vector* gT, Tpetra_MultiVector* dg_dxT, Tpetra_MultiVector* dg_dxdotT, Tpetra_MultiVector* dg_dxdotdotT, Tpetra_MultiVector* dg_dpT) { // Evaluate response g if (gT != NULL) { ST mean = xT.meanValue(); Teuchos::ArrayRCP<ST> gT_nonconstView = gT->get1dViewNonConst(); gT_nonconstView[0] = mean; } // Evaluate dg/dx if (dg_dxT != NULL) dg_dxT->putScalar(1.0 / xT.getGlobalLength()); // Evaluate dg/dxdot if (dg_dxdotT != NULL) dg_dxdotT->putScalar(0.0); if (dg_dxdotdotT != NULL) dg_dxdotdotT->putScalar(0.0); // Evaluate dg/dp if (dg_dpT != NULL) dg_dpT->putScalar(0.0); }
void Albany::SolutionTwoNormResponseFunction:: evaluateTangentT(const double alpha, const double beta, const double omega, const double current_time, bool sum_derivs, const Tpetra_Vector* xdotT, const Tpetra_Vector* xdotdotT, const Tpetra_Vector& xT, const Teuchos::Array<ParamVec>& p, ParamVec* deriv_p, const Tpetra_MultiVector* VxdotT, const Tpetra_MultiVector* VxdotdotT, const Tpetra_MultiVector* VxT, const Tpetra_MultiVector* VpT, Tpetra_Vector* gT, Tpetra_MultiVector* gxT, Tpetra_MultiVector* gpT) { Teuchos::ScalarTraits<ST>::magnitudeType nrm = xT.norm2(); // Evaluate response g if (gT != NULL) { Teuchos::ArrayRCP<ST> gT_nonconstView = gT->get1dViewNonConst(); gT_nonconstView[0] = nrm; } // Evaluate tangent of g = dg/dx*dx/dp + dg/dxdot*dxdot/dp + dg/dp // dg/dx = 1/||x|| * x^T Teuchos::ETransp T = Teuchos::TRANS; Teuchos::ETransp N = Teuchos::NO_TRANS; if (gxT != NULL) { if (VxT != NULL) gxT->multiply(T, N, alpha/nrm, xT, *VxT, 0.0); else gxT->update(alpha/nrm, xT, 0.0); } if (gpT != NULL) gpT->putScalar(0.0); }
void Albany::SolutionMaxValueResponseFunction:: computeMaxValueT(const Tpetra_Vector& xT, double& global_max, int& global_index) { //The following is needed b/c Epetra_MaxDouble comes from Trilinos Epetra package. double Tpetra_MaxDouble = 1.0E+100; double my_max = -Tpetra_MaxDouble; int my_index = -1, index; Teuchos::ArrayRCP<const ST> xT_constView = xT.get1dView(); // Loop over nodes to find max value for equation eq int num_my_nodes = xT.getLocalLength() / neq; for (int node=0; node<num_my_nodes; node++) { if (interleavedOrdering) index = node*neq+eq; else index = node + eq*num_my_nodes; if (xT_constView[index] > my_max) { my_max = xT_constView[index]; my_index = index; } } // Check remainder (AGS: NOT SURE HOW THIS CODE GETS CALLED?) if (num_my_nodes*neq+eq < xT.getLocalLength()) { if (interleavedOrdering) index = num_my_nodes*neq+eq; else index = num_my_nodes + eq*num_my_nodes; if (xT_constView[index] > my_max) { my_max = xT_constView[index]; my_index = index; } } Teuchos::RCP<const Teuchos::Comm<int> > commT = xT.getMap()->getComm(); // Get max value across all proc's Teuchos::reduceAll(*commT, Teuchos::REDUCE_MAX, my_max, Teuchos::ptr(&global_max)); // Compute min of all global indices equal to max value if (my_max == global_max) my_index = xT.getMap()->getGlobalElement(my_index); else my_index = xT.getGlobalLength(); Teuchos::reduceAll(*commT, Teuchos::REDUCE_MIN, my_index, Teuchos::ptr(&global_index)); }
void twoD_diffusion_problem<Scalar,MeshScalar,BasisScalar,LocalOrdinal,GlobalOrdinal, Node>:: computeA(const FuncT& func, const Tpetra_Vector& p, Tpetra_CrsMatrix& jac) { using Teuchos::ArrayView; using Teuchos::arrayView; jac.resumeFill(); jac.setAllToScalar(0.0); Teuchos::ArrayRCP<const Scalar> p_view = p.get1dView(); Teuchos::Array<Scalar> rv(p_view()); size_t NumMyElements = x_map->getNodeNumElements(); ArrayView<const GlobalOrdinal> MyGlobalElements = x_map->getNodeElementList (); MeshScalar h2 = h*h; Scalar val; for(size_t i=0 ; i<NumMyElements; ++i ) { // Center GlobalOrdinal global_idx = MyGlobalElements[i]; if (mesh[global_idx].boundary) { val = 1.0; jac.replaceGlobalValues(global_idx, arrayView(&global_idx,1), arrayView(&val,1)); } else { Scalar a_down = -func(mesh[global_idx].x, mesh[global_idx].y-h/2.0, rv)/h2; Scalar a_left = -func(mesh[global_idx].x-h/2.0, mesh[global_idx].y, rv)/h2; Scalar a_right = -func(mesh[global_idx].x+h/2.0, mesh[global_idx].y, rv)/h2; Scalar a_up = -func(mesh[global_idx].x, mesh[global_idx].y+h/2.0, rv)/h2; // Center val = -(a_down + a_left + a_right + a_up); jac.replaceGlobalValues(global_idx, arrayView(&global_idx,1), arrayView(&val,1)); // Down if (!(eliminate_bcs && mesh[mesh[global_idx].down].boundary)) jac.replaceGlobalValues(global_idx, arrayView(&mesh[global_idx].down,1), arrayView(&a_down,1)); // Left if (!(eliminate_bcs && mesh[mesh[global_idx].left].boundary)) jac.replaceGlobalValues(global_idx, arrayView(&mesh[global_idx].left,1), arrayView(&a_left,1)); // Right if (!(eliminate_bcs && mesh[mesh[global_idx].right].boundary)) jac.replaceGlobalValues(global_idx, arrayView(&mesh[global_idx].right,1), arrayView(&a_right,1)); // Up if (!(eliminate_bcs && mesh[mesh[global_idx].up].boundary)) jac.replaceGlobalValues(global_idx, arrayView(&mesh[global_idx].up,1), arrayView(&a_up,1)); } } jac.fillComplete(); }