48#if VTK_VERSION_STRIPPED < 940
49 vtkNew<vtkIdFilter> id_filter;
50 id_filter->SetInputData(bulk_mesh);
51 id_filter->SetCellIdsArrayName(
"bulk_element_ids");
52 id_filter->SetPointIds(
false);
53 id_filter->SetCellIds(
true);
57 vtkNew<vtkGenerateIds> generate_ids;
58 generate_ids->SetInputData(bulk_mesh);
59 generate_ids->SetCellIdsArrayName(
"bulk_element_ids");
60 generate_ids->PointIdsOff();
61 generate_ids->CellIdsOn();
62 generate_ids->Update();
64 static_cast<vtkUnstructuredGrid*
>(generate_ids->GetOutput());
66 locator_ = vtkSmartPointer<vtkCellTreeLocator>::New();
82 vtkSmartPointer<vtkUnstructuredGrid>
find(Eigen::Vector3d
const& coords,
83 double const tolerance)
87 vtkNew<vtkExtractCells> extract_cells;
89 extract_cells->SetCellList(cell_ids);
90 extract_cells->Update();
91 auto const filtered_bulk_mesh = extract_cells->GetOutput();
93 return filtered_bulk_mesh;
98 double const tolerance)
100 std::array<double, 6> bbox = {
101 coords[0] - tolerance, coords[0] + tolerance,
102 coords[1] - tolerance, coords[1] + tolerance,
103 coords[2] - tolerance, coords[2] + tolerance};
105 vtkNew<vtkIdList> cell_ids;
106 locator_->FindCellsWithinBounds(bbox.data(), cell_ids);