Archimedean Spirals
Windows only
Overview
It is possible to define an Archimedean Spiral with polar coordinates. In polar coordinates $$(r, θ)$$, an Archimedean Spiral can be described by the following equation:
$$r = a+bθ$$with real numbers $$a$$ and $$b$$. Changing the parameter a will turn the spiral, while $$b$$ controls the distance between successive turnings…
Sample
Once the polar coordinates have been calculated, we can use RhinoScript’s Polar
method to convert them to Cartesian coordinates, which will allow us to plot the curve using RhinoScript’s AddInterpCurve
method.
The following sample script code demonstrates how to create an interpolated curve through the points that were calculated using the above equation…
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' ArchimedeanSpiral.rvb -- June 2008
' If this code works, it was written by Dale Fugier.
' If not, I don't know who wrote it.
' Works with Rhino 4.0.
Option Explicit
Sub ArchimedeanSpiral()
Dim a_const, b_const, step_angle, num_points
Dim curr_angle, base_point, radius, points(), i
Rhino.Print "Archimedean Spiral (r = a + bθ)"
a_const = Rhino.GetReal("Value of 'A' constant", 1.0, 0.01)
If IsNull(a_const) Then Exit Sub
b_const = Rhino.GetReal("Value of 'B' constant", 1.0, 0.01)
If IsNull(a_const) Then Exit Sub
num_points = Rhino.GetInteger("Number of points to calculate", 10, 2)
If IsNull(num_points) Then Exit Sub
step_angle = Rhino.GetReal("Angle between points", 30.0, 1.0, 45.0)
If IsNull(step_angle) Then Exit Sub
curr_angle = 0.0
base_point = Array(0.0, 0.0, 0.0)
ReDim points(num_points - 1)
For i = 0 To UBound(points)
radius = a_const + (b_const * curr_angle)
points(i) = Rhino.Polar(base_point, radius, curr_angle)
curr_angle = curr_angle + step_angle
Next
Rhino.AddInterpCurve points
'Rhino.AddPoints points
End Sub