vtkParametricConicSpiral.cxx 3.05 KB
Newer Older
1 2 3 4 5
/*=========================================================================

  Program:   Visualization Toolkit
  Module:    vtkParametricConicSpiral.cxx

6
  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7 8 9
  All rights reserved.
  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.

10 11
     This software is distributed WITHOUT ANY WARRANTY; without even
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12 13 14 15 16 17 18 19 20
     PURPOSE.  See the above copyright notice for more information.

=========================================================================*/
#include "vtkParametricConicSpiral.h"
#include "vtkObjectFactory.h"
#include "vtkMath.h"

vtkStandardNewMacro(vtkParametricConicSpiral);

21
//----------------------------------------------------------------------------
22 23 24 25
vtkParametricConicSpiral::vtkParametricConicSpiral()
{
  // Preset triangulation parameters
  this->MinimumU = 0;
26
  this->MaximumU = 2.0 * vtkMath::Pi();
27
  this->MinimumV = 0;
28
  this->MaximumV = 2.0 * vtkMath::Pi();
29 30 31 32 33

  this->JoinU = 0;
  this->JoinV = 0;
  this->TwistU = 0;
  this->TwistV = 0;
34
  this->ClockwiseOrdering = 0;
35 36
  this->DerivativesAvailable = 1;

37
  // Conic Spiral
38 39 40 41 42 43
  this->A = 0.2;
  this->B = 1;
  this->C = 0.1;
  this->N = 2;
}

44
//----------------------------------------------------------------------------
45
vtkParametricConicSpiral::~vtkParametricConicSpiral() = default;
46

47
//----------------------------------------------------------------------------
48 49
void vtkParametricConicSpiral::Evaluate(double uvw[3], double Pt[3],
                                        double Duvw[9])
50
{
51 52 53 54
  double u = uvw[0];
  double v = uvw[1];
  double *Du = Duvw;
  double *Dv = Duvw + 3;
55

56
  double inv2pi = 1.0 / (2.0 * vtkMath::Pi());
57

58 59
  double cnv = cos(this->N * v);
  double snv = sin(this->N * v);
60 61 62 63
  double cu = cos(u);
  double su = sin(u);

  // The point
64 65 66
  Pt[0] = this->A * (1 - v * inv2pi) * cnv * (1 + cu) + this->C * cnv;
  Pt[1] = this->A * (1 - v * inv2pi) * snv * (1 + cu) + this->C * snv;
  Pt[2] = this->B * v * inv2pi + this->A * (1 - v * inv2pi) * su;
67

68
  // The derivatives are:
69 70 71 72 73 74 75 76
  Du[0] = -this->A * (1 - v * inv2pi) * cnv * su;
  Dv[0] = -this->A * inv2pi * cnv * (1 + cu) - this->A *
          (1 - v * inv2pi) * snv * this->N * (1 + cu) - this->C * snv * N;
  Du[1] = -this->A * (1 - v * inv2pi) * snv * su;
  Dv[1] = -this->A * inv2pi * snv * (1 + cu) + this->A *
          (1 - v * inv2pi) * cnv * this->N * (1 + cu) + C * cnv * this->N;
  Du[2] = this->A * (1 - v * inv2pi) * cu;
  Dv[2] = this->B * inv2pi - this->A * inv2pi * su;
77 78
}

79
//----------------------------------------------------------------------------
80 81
double vtkParametricConicSpiral::EvaluateScalar(double *, double *,
    double *)
82 83 84 85
{
  return 0;
}

86
//----------------------------------------------------------------------------
87 88
void vtkParametricConicSpiral::PrintSelf(ostream& os, vtkIndent indent)
{
89
  this->Superclass::PrintSelf(os, indent);
90 91 92 93 94 95

  os << indent << "A: " << this->A << "\n";
  os << indent << "B: " << this->B << "\n";
  os << indent << "C: " << this->C << "\n";
  os << indent << "N: " << this->N << "\n";
}