v0.15.0
Loading...
Searching...
No Matches
PhotonDiffusion::OpCameraInteg Struct Reference
Inheritance diagram for PhotonDiffusion::OpCameraInteg:
[legend]
Collaboration diagram for PhotonDiffusion::OpCameraInteg:
[legend]

Public Member Functions

 OpCameraInteg (boost::shared_ptr< CommonData > common_data_ptr)
 
MoFEMErrorCode doWork (int side, EntityType type, EntitiesFieldData::EntData &data)
 

Public Attributes

boost::shared_ptr< CommonDatacommonDataPtr
 

Detailed Description

Definition at line 114 of file photon_diffusion.cpp.

Constructor & Destructor Documentation

◆ OpCameraInteg()

PhotonDiffusion::OpCameraInteg::OpCameraInteg ( boost::shared_ptr< CommonData > common_data_ptr)
inline
Examples
photon_diffusion.cpp.

Definition at line 116 of file photon_diffusion.cpp.

117 : BoundaryEleOp("PHOTON_FLUENCE_RATE", OPROW),
118 commonDataPtr(common_data_ptr) {
119 std::fill(&doEntities[MBVERTEX], &doEntities[MBMAXTYPE], false);
120 doEntities[MBTRI] = doEntities[MBQUAD] = true;
121 }
BoundaryEle::UserDataOperator BoundaryEleOp
boost::shared_ptr< CommonData > commonDataPtr

Member Function Documentation

◆ doWork()

MoFEMErrorCode PhotonDiffusion::OpCameraInteg::doWork ( int side,
EntityType type,
EntitiesFieldData::EntData & data )
Examples
photon_diffusion.cpp.

Definition at line 630 of file photon_diffusion.cpp.

631 {
633 const int nb_integration_pts = getGaussPts().size2();
634 const double area = getMeasure();
635 auto t_w = getFTensor0IntegrationWeight();
636 auto t_val = getFTensor0FromVec(*(commonDataPtr->approxVals));
637
638 double values_integ = 0;
639
640 for (int gg = 0; gg != nb_integration_pts; ++gg) {
641 const double alpha = t_w * area;
642
643 values_integ += alpha * t_val;
644
645 ++t_w;
646 ++t_val;
647 }
648
649 constexpr std::array<int, 1> indices = {CommonData::VALUES_INTEG};
650 std::array<double, 1> values;
651 values[0] = values_integ;
652 CHKERR VecSetValues(commonDataPtr->petscVec, 1, indices.data(), values.data(),
653 ADD_VALUES);
655}
#define MoFEMFunctionBegin
First executable line of each MoFEM function, used for error handling. Final line of MoFEM functions ...
#define MoFEMFunctionReturn(a)
Last executable line of each PETSc function used for error handling. Replaces return()
#define CHKERR
Inline error check.
static auto getFTensor0FromVec(ublas::vector< T, A > &data)
Get tensor rank 0 (scalar) form data vector.
MoFEMErrorCode VecSetValues(Vec V, const EntitiesFieldData::EntData &data, const double *ptr, InsertMode iora)
Assemble PETSc vector.

Member Data Documentation

◆ commonDataPtr

boost::shared_ptr<CommonData> PhotonDiffusion::OpCameraInteg::commonDataPtr
Examples
photon_diffusion.cpp.

Definition at line 115 of file photon_diffusion.cpp.


The documentation for this struct was generated from the following file: