// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen // SPDX-License-Identifier: BSD-3-Clause /** * @class vtkBrownianPoints * @brief assign random vector to points * * vtkBrownianPoints is a filter object that assigns a random vector (i.e., * magnitude and direction) to each point. The minimum and maximum speed * values can be controlled by the user. * * @sa * vtkRandomAttributeGenerator */ #ifndef vtkBrownianPoints_h #define vtkBrownianPoints_h #include "vtkDataSetAlgorithm.h" #include "vtkFiltersGeneralModule.h" // For export macro VTK_ABI_NAMESPACE_BEGIN class VTKFILTERSGENERAL_EXPORT vtkBrownianPoints : public vtkDataSetAlgorithm { public: /** * Create instance with minimum speed 0.0, maximum speed 1.0. */ static vtkBrownianPoints* New(); vtkTypeMacro(vtkBrownianPoints, vtkDataSetAlgorithm); void PrintSelf(ostream& os, vtkIndent indent) override; ///@{ /** * Set the minimum speed value. */ vtkSetClampMacro(MinimumSpeed, double, 0.0, VTK_DOUBLE_MAX); vtkGetMacro(MinimumSpeed, double); ///@} ///@{ /** * Set the maximum speed value. */ vtkSetClampMacro(MaximumSpeed, double, 0.0, VTK_DOUBLE_MAX); vtkGetMacro(MaximumSpeed, double); ///@} protected: vtkBrownianPoints(); ~vtkBrownianPoints() override = default; int RequestData(vtkInformation*, vtkInformationVector**, vtkInformationVector*) override; double MinimumSpeed; double MaximumSpeed; private: vtkBrownianPoints(const vtkBrownianPoints&) = delete; void operator=(const vtkBrownianPoints&) = delete; }; VTK_ABI_NAMESPACE_END #endif