TPZCompMesh *MalhaCompDois(TPZGeoMesh * gmesh, int pOrder, bool isdiscontinuous) { /// criar materiais int dim = 2; TPZMatPoisson3d *material; material = new TPZMatPoisson3d(matId,dim); TPZMaterial * mat(material); material->SetNoPenalty(); material->SetNonSymmetric(); REAL diff = -1.; REAL conv = 0.; TPZVec<REAL> convdir(3,0.); REAL flux = 0.; material->SetParameters(diff, conv, convdir); material->SetInternalFlux(flux); material->NStateVariables(); TPZCompEl::SetgOrder(pOrder); TPZCompMesh * cmesh = new TPZCompMesh(gmesh); cmesh->SetDimModel(dim); //cmesh->SetAllCreateFunctionsContinuous(); cmesh->InsertMaterialObject(mat); TPZAutoPointer<TPZFunction<STATE> > forcef = new TPZDummyFunction<STATE>(ForcingF, 5); material->SetForcingFunction(forcef); ///Inserir condicao de contorno TPZFMatrix<STATE> val1(2,2,0.), val2(2,1,0.); TPZMaterial * BCond0 = material->CreateBC(mat, bc0,dirichlet, val1, val2); TPZMaterial * BCond2 = material->CreateBC(mat, bc2,dirichlet, val1, val2); TPZMaterial * BCond1 = material->CreateBC(mat, bc1,dirichlet, val1, val2); TPZMaterial * BCond3 = material->CreateBC(mat, bc3,dirichlet, val1, val2); cmesh->InsertMaterialObject(BCond0); cmesh->InsertMaterialObject(BCond1); cmesh->InsertMaterialObject(BCond2); cmesh->InsertMaterialObject(BCond3); //Ajuste da estrutura de dados computacional if (isdiscontinuous==true) { //Set discontinuous functions cmesh->SetAllCreateFunctionsDiscontinuous(); cmesh->AutoBuild(); cmesh->ExpandSolution(); cmesh->AdjustBoundaryElements(); cmesh->CleanUpUnconnectedNodes(); } else{ cmesh->SetAllCreateFunctionsContinuous(); cmesh->AutoBuild(); cmesh->ExpandSolution(); cmesh->AdjustBoundaryElements(); cmesh->CleanUpUnconnectedNodes(); } return cmesh; }
TPZCompMesh *MeshL2(TPZGeoMesh *gmesh, int pOrder, int dim) { /// criar materiais dim = 2; TPZMatPoisson3d *material = new TPZMatPoisson3d( MatId, dim); material->NStateVariables(); TPZCompMesh * cmesh = new TPZCompMesh(gmesh); cmesh->SetDimModel(dim); TPZMaterial * mat(material); cmesh->InsertMaterialObject(mat); ///Inserir condicao de contorno // TPZFMatrix<STATE> val1(2,2,0.), val2(2,1,0.); // // TPZMaterial * BCond0 = material->CreateBC(mat, bc0,dirichlet, val1, val2); // TPZMaterial * BCond1 = material->CreateBC(mat, bc1,dirichlet, val1, val2); // TPZMaterial * BCond2 = material->CreateBC(mat, bc2,dirichlet, val1, val2); // TPZMaterial * BCond3 = material->CreateBC(mat, bc3,dirichlet, val1, val2); // // cmesh->InsertMaterialObject(BCond0); // cmesh->InsertMaterialObject(BCond1); // cmesh->InsertMaterialObject(BCond2); // cmesh->InsertMaterialObject(BCond3); // //solucao exata // TPZAutoPointer<TPZFunction<STATE> > solexata; // solexata = new TPZDummyFunction<STATE>(EstadoAd); // material->SetForcingFunctionExact(solexata); // // //funcao do lado direito da equacao do problema // TPZAutoPointer<TPZFunction<STATE> > force; // TPZDummyFunction<STATE> *dum; // // dum = new TPZDummyFunction<STATE>(OptForcing); // dum->SetPolynomialOrder(20); // force = dum; // material->SetForcingFunction(force); cmesh->SetDefaultOrder(pOrder); cmesh->SetDimModel(dim); cmesh->SetAllCreateFunctionsDiscontinuous(); //cmesh->SetAllCreateFunctionsContinuous(); //Ajuste da estrutura de dados computacional cmesh->AutoBuild(); return cmesh; }