Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

corrected resize output vectors to handle vector variables #3838

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions include/mesh/mesh_function.h
Original file line number Diff line number Diff line change
Expand Up @@ -406,6 +406,11 @@ class MeshFunction : public FunctionBase<Number>,
* See \p enable_out_of_mesh_mode() for more details.
*/
DenseVector<Number> _out_of_mesh_value;

/**
* the new size to resize output to
*/
int _new_resize;
};


Expand Down
2 changes: 1 addition & 1 deletion src/apps/meshbcid.C
Original file line number Diff line number Diff line change
Expand Up @@ -212,4 +212,4 @@ int main(int argc, char ** argv)
libMesh::out << "Wrote mesh " << outputname << std::endl;

return 0;
}
}
54 changes: 39 additions & 15 deletions src/mesh/mesh_function.C
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,8 @@ MeshFunction::MeshFunction (const EquationSystems & eqn_systems,
_vector (vec),
_dof_map (dof_map),
_system_vars (std::move(vars)),
_out_of_mesh_mode (false)
_out_of_mesh_mode (false),
_new_resize (0)
{
}

Expand All @@ -67,7 +68,8 @@ MeshFunction::MeshFunction (const EquationSystems & eqn_systems,
_vector (vec),
_dof_map (dof_map),
_system_vars (1,var),
_out_of_mesh_mode (false)
_out_of_mesh_mode (false),
_new_resize (0)
{
}

Expand All @@ -78,7 +80,8 @@ MeshFunction::MeshFunction (const MeshFunction & mf):
_vector (mf._vector),
_dof_map (mf._dof_map),
_system_vars (mf._system_vars),
_out_of_mesh_mode (mf._out_of_mesh_mode)
_out_of_mesh_mode (mf._out_of_mesh_mode),
_new_resize (0)
{
// Initialize the mf and set the point locator if the
// input mf had done so.
Expand Down Expand Up @@ -118,8 +121,33 @@ void MeshFunction::init ()
const MeshBase & mesh = this->_eqn_systems.get_mesh();
_point_locator = mesh.sub_point_locator();

// ready for use
this->_initialized = true;
int vec_dim = 0;
int n_vector_vars = 0;
int n_scalar_vars = 0;

int total_variables = _dof_map.n_variables();
const MeshBase & mesh = this->_eqn_systems.get_mesh();
_point_locator = mesh.sub_point_locator();

for (int i = 0; i < total_variables; ++i)
{
FEType fe_type = _dof_map.variable_type(i);
if (fe_type != SCALAR)
{
n_vector_vars++;
int vector_dim = FEInterface::n_vec_dim(mesh, fe_type);
if (vector_dim > vec_dim)
vec_dim = vector_dim;
}
else
n_scalar_vars++;

}

_new_resize = vec_dim * n_vector_vars + n_scalar_vars;

// ready for use
this->_initialized = true;
}


Expand Down Expand Up @@ -242,10 +270,8 @@ void MeshFunction::operator() (const Point & p,
}
else
{
// resize the output vector to the number of output values
// that the user told us
output.resize (cast_int<unsigned int>
(this->_system_vars.size()));
// resize the output vector to the _new_resize
output.resize (_new_resize);


{
Expand Down Expand Up @@ -470,9 +496,8 @@ void MeshFunction::_gradient_on_elem (const Point & p,
{
libmesh_assert(element);

// resize the output vector to the number of output values
// that the user told us
output.resize (this->_system_vars.size());
// resize the output vector to the _new_resize
output.resize (_new_resize);

const unsigned int dim = element->dim();

Expand Down Expand Up @@ -587,9 +612,8 @@ void MeshFunction::hessian (const Point & p,
<< " are not yet implemented!"
<< std::endl);

// resize the output vector to the number of output values
// that the user told us
output.resize (this->_system_vars.size());
// resize the output vector to the _new_resize
output.resize (_new_resize);


{
Expand Down