Filter.h 3.19 KB
Newer Older
Utkarsh Ayachit's avatar
Utkarsh Ayachit committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
//============================================================================
//  Copyright (c) Kitware, Inc.
//  All rights reserved.
//  See LICENSE.txt for details.
//  This software is distributed WITHOUT ANY WARRANTY; without even
//  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
//  PURPOSE.  See the above copyright notice for more information.
//
//  Copyright 2014 National Technology & Engineering Solutions of Sandia, LLC (NTESS).
//  Copyright 2014 UT-Battelle, LLC.
//  Copyright 2014 Los Alamos National Security.
//
//  Under the terms of Contract DE-NA0003525 with NTESS,
//  the U.S. Government retains certain rights in this software.
//
//  Under the terms of Contract DE-AC52-06NA25396 with Los Alamos National
//  Laboratory (LANL), the U.S. Government retains certain rights in
//  this software.
//============================================================================
#ifndef vtk_m_filter_Filter_h
#define vtk_m_filter_Filter_h

#include <vtkm/cont/CoordinateSystem.h>
#include <vtkm/cont/DataSet.h>
#include <vtkm/cont/Field.h>
#include <vtkm/cont/MultiBlock.h>
#include <vtkm/cont/RuntimeDeviceTracker.h>

#include <vtkm/filter/FieldSelection.h>
#include <vtkm/filter/PolicyBase.h>


namespace vtkm
{
namespace filter
{
template <typename Derived>
class Filter
{
public:
  VTKM_CONT
  Filter();

  VTKM_CONT
  ~Filter();

  VTKM_CONT
  void SetRuntimeDeviceTracker(const vtkm::cont::RuntimeDeviceTracker& tracker)
  {
    this->Tracker = tracker;
  }

  VTKM_CONT
  const vtkm::cont::RuntimeDeviceTracker& GetRuntimeDeviceTracker() const { return this->Tracker; }
  VTKM_CONT
  vtkm::cont::RuntimeDeviceTracker& GetRuntimeDeviceTracker() { return this->Tracker; }

  //@{
  /// Executes the filter on the input and producer an result dataset.
  /// FieldSelection can be specified to indicate which fields should be passed
  /// on from the input to the output.
  ///
  /// On success, this the dataset produced. On error, vtkm::cont::ErrorExecution will be thrown.
  VTKM_CONT
65
66
67
68
  vtkm::cont::DataSet Execute(
    const vtkm::cont::DataSet& input,
    const vtkm::filter::FieldSelection& fieldSelection =
      vtkm::filter::FieldSelection(vtkm::filter::FieldSelection::MODE_ALL));
Utkarsh Ayachit's avatar
Utkarsh Ayachit committed
69
70

  template <typename DerivedPolicy>
71
72
73
74
75
  VTKM_CONT vtkm::cont::DataSet Execute(
    const vtkm::cont::DataSet& input,
    const vtkm::filter::PolicyBase<DerivedPolicy>& policy,
    const vtkm::filter::FieldSelection& fieldSelection =
      vtkm::filter::FieldSelection(vtkm::filter::FieldSelection::MODE_ALL));
Utkarsh Ayachit's avatar
Utkarsh Ayachit committed
76
77
78
79
80
  //@}

  //@{
  /// MultiBlock variants of execute.
  VTKM_CONT
81
82
83
84
  vtkm::cont::MultiBlock Execute(
    const vtkm::cont::MultiBlock& input,
    const vtkm::filter::FieldSelection& fieldSelection =
      vtkm::filter::FieldSelection(vtkm::filter::FieldSelection::MODE_ALL));
Utkarsh Ayachit's avatar
Utkarsh Ayachit committed
85
86

  template <typename DerivedPolicy>
87
88
89
90
91
  VTKM_CONT vtkm::cont::MultiBlock Execute(
    const vtkm::cont::MultiBlock& input,
    const vtkm::filter::PolicyBase<DerivedPolicy>& policy,
    const vtkm::filter::FieldSelection& fieldSelection =
      vtkm::filter::FieldSelection(vtkm::filter::FieldSelection::MODE_ALL));
Utkarsh Ayachit's avatar
Utkarsh Ayachit committed
92
93
94
95
96
97
98
99
100
101
  //@}

private:
  vtkm::cont::RuntimeDeviceTracker Tracker;
};
}
} // namespace vtkm::filter

#include <vtkm/filter/Filter.hxx>
#endif