本文整理汇总了C++中FunctionParser::value_list方法的典型用法代码示例。如果您正苦于以下问题:C++ FunctionParser::value_list方法的具体用法?C++ FunctionParser::value_list怎么用?C++ FunctionParser::value_list使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类FunctionParser
的用法示例。
在下文中一共展示了FunctionParser::value_list方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1:
void EigenvalueProblem<dim>::assemble_system()
{
QGauss<dim> quadrature_formula(2);
FEValues<dim> fe_values(fe, quadrature_formula,
update_values | update_gradients |
update_quadrature_points | update_JxW_values);
const size_t dofs_per_cell = fe.dofs_per_cell;
const size_t n_q_points = quadrature_formula.size();
FullMatrix<double> cell_stiffness_matrix (dofs_per_cell, dofs_per_cell);
FullMatrix<double> cell_mass_matrix (dofs_per_cell, dofs_per_cell);
std::vector<types::global_dof_index> local_dof_indices(dofs_per_cell);
FunctionParser<dim> potential;
potential.initialize(FunctionParser<dim>::default_variable_names(),
parameters.get("Potential"),
typename FunctionParser<dim>::ConstMap());
std::vector<double> potential_values(n_q_points);
for (auto cell : dof_handler.active_cell_iterators()) {
fe_values.reinit(cell);
cell_stiffness_matrix = 0;
cell_mass_matrix = 0;
potential.value_list(fe_values.get_quadrature_points(),
potential_values);
for (size_t q_point = 0; q_point < n_q_points; ++q_point) {
for (size_t i = 0; i < dofs_per_cell; ++i) {
for (size_t j = 0; j < dofs_per_cell; ++j) {
cell_stiffness_matrix(i, j) += (fe_values.shape_grad(i, q_point) *
fe_values.shape_grad(j, q_point)
+
potential_values[q_point] *
fe_values.shape_value(i, q_point) *
fe_values.shape_value(j, q_point)
) * fe_values.JxW(q_point);
cell_mass_matrix(i, j) += (fe_values.shape_value(i, q_point) *
fe_values.shape_value(j, q_point)
) * fe_values.JxW(q_point);
}
}
}
cell->get_dof_indices(local_dof_indices);
constraints.distribute_local_to_global(cell_stiffness_matrix,
local_dof_indices,
stiffness_matrix);
constraints.distribute_local_to_global(cell_mass_matrix,
local_dof_indices,
mass_matrix);
}
stiffness_matrix.compress(VectorOperation::add);
mass_matrix.compress(VectorOperation::add);
double min_spurious_eigenvalue = std::numeric_limits<double>::max(),
max_spurious_eigenvalue = -std::numeric_limits<double>::max();
for (size_t i = 0; i < dof_handler.n_dofs(); ++i) {
if (constraints.is_constrained(i)) {
const double ev = stiffness_matrix(i, i) / mass_matrix(i, i);
min_spurious_eigenvalue = std::min (min_spurious_eigenvalue, ev);
max_spurious_eigenvalue = std::max (max_spurious_eigenvalue, ev);
}
}
std::cout << " Spurious eigenvalues are all in the interval "
<< "[" << min_spurious_eigenvalue << "," << max_spurious_eigenvalue << "]"
<< std::endl;
}