Pan A Dial Variable
This function allows one to observe the effect of altering a single dial setting (e.g. wall
declination, latitude, length of gnomon, x-axis thread offset, etc) without having to open up the setup
dialog. The user can quickly increment or decrement the chosen setting by the amount
specified and observe the effect on the dial display.
Most of the variables have preset ranges. The utility will let you know if an attempt is made
to exceed it.
⇒ Note that because these operations recalculate the entire dial,
if many special settings are selected (e.g. babylonian hours, the equation of time, etc), it may take
a few seconds for the viewport to refresh and the new dial to display.
Gnomon/Style Projection
Polar Gnomon (Parallel to Earth-rotational axis)
For polar gnomons (style parallel to the Earth's
rotation axis) clicking the button will toggle display of the projection of the style
onto the plane of the dial (sometimes referred to as the substyle).
Hovering over the end point will generate a
"tool tip" that displays the 2D coordinate of this point. The style angle (i.e. the angle the
style makes with the dial plane) and the distance of the nodus (i.e. the very tip of the style) above the dial plane are given
in the dial summary to the left of the dial graphic.
These three pieces of information: 1) substyle coordinate; 2) style angle;
and 3) style distance (i.e. ⊥ distance of the nodus from the dial plane), are sufficient to accurately place the style in its correct position.
(Strictly speaking, one only really needs #1 in addition to either #2 or #3, but for the sake
of completeness, they are all given.)
Note that for a dial which has a polar style, the
dial's center and origin are the same.
Perpendicular Gnomon
The projection of a perpendicular gnomon onto the plane of the dial
is just the origin of the dial itself and therefore is
not particularly instructive. Instead, imagine a line, parallel to the Earth's axis, and
passing through the tip of the perpendicular gnomon. Clicking the button
will toggle the display of the projection of this line and point of intersection onto the face of the dial.
This point is the dial center (the point at which the hour lines converge)
Laying out a dial using polar coordinates must be done from the dial center, which
is not the same location as the dial origin (The dial origin and dial center are only
the same when using a polar style).
If the dial's center and origin lie too far apart, using polar coordinates is probably
not feasible.
2D & 3D Data
There is a lot of output in this section, most of which is not necessary for constructing the dial.
It is included anyway, however, since it should help in visualizing the sun's position and movement and how that
translates into the dial face coordinates (DF_x,DF_y) that can be used by themselves
for constructing the dial.
Each separate table represents data for a specific solar declination. Inspection of the output
will show that as watch time increases, the sun's hour angle and azimuth uniformly increase while the
sun's altitude increases then decreases. Note that azimuth is measured from due north clockwise
in the horizontal plane.
The direction cosines of the sun represent a unit vector which points from the
origin of the 3D cartesian coordinate system toward the sun. A negative value for dz
indicates the sun is below the horizon. (Note that due east and due north in the horizontal plane
are positive-x and positive-y, respectively.)
A 3D dial coordinate represents a point in 3D space where a line with the direction
cosines of the sun and passing through the tip of the gnomon
(or through both threads in the case of a bifilar dial) intersects the dial plane.
• The coordinate system used in performing most calculations is the familiar 3D Cartesian system (i.e. XYZ axes, right-handed).
• Due east (in the horizontal plane) is the postive x-axis.
• Due north (in the horizontal plane) is the positive y-axis.
• Vertical (i.e. zenith direction) is the positive z-axis.
A 2D dial coordinate represents the projection of the 3D point onto the plane of the dial.
2D coordinates (DF_x,DF_y) are the ones to be used in laying out the dial.
NOTE: The coordinates (DF_x,DF_y) represent the values exported to the DXF file.
About
•
This program is intended to be a reasonably straightforward,
interactive utility for the
generation of numerical data which can then be used for
the layout and construction of a variety of sundial types.
It was originally intended and designed for personal
use, but morphed over time into the present incarnation.
•
Because this program is written entirely in Javascript, anyone is free to
download and use it external to this website (save it as a "Complete Web Page").
•
The intended target audience is anyone relatively new to dialing. It is assumed that if one is interested in creating a dial with
details such as altitude and azimuth lines, planetary hour lines, sidereal time, etc. this is not the utility for you. With this utility one
can customize the solar calendar, and include the equation of time as well as babylonian and italian hour lines. For most folks, this will
be plenty.
•
Proper useage does require a basic level of understanding on the part of the user (I'm assuming experienced
dialists already have favorite or preferred "dialing software").
If you are serious about
making a sundial, it is strongly recommended one spend a little time becoming familiar with
the general theory and nomenclature about dials. Some possible starting points may be found at
Additional Help.
•
If you are a person who prefers reading "instructions", begin with
Getting Started.
If your modus operandi is to jump right in, you can start with either
Dial Setup
(to change the settings to your particular locale) or
Display Dial,
which will generate the "default" dial
(a horizontal dial with a "polar" gnomon located in southwest Missouri).
• Every effort has been made to ensure the output of this program is
accurate, but no warranty is either expressed or implied. Users accept full responsibility
for the accuracy and reliability of any sundial they construct using data provided by this
utility.
•
It is something of a "work in progress", so if you have questions, a suggestion,
or want to report a bug, I can be contacted at:
bill -AT- jamesriverstudio -DOT- com.
© 2015 Bill Horst
Layout/Construction Data
The output of these functions provide the data necessary for dial construction.
DXF File
The output of this function is a plain ASCII text file the structure of which is
recognizable by CAD programs. The visible elements in the dial SVG viewport
are converted to LINE, TEXT and POLYLINE elements and written to layers reflecting the
different types of paths displayed (e.g. hour lines, calendar paths, hours 'til sunset, horizon, etc.).
It is left to the user to assign line-weight/type, color, etc.
SVG File
The output of this function is an XML/SVG document
which can be opened in Inkscape for the purpose
printing your sundial layout to exact scale (this eliminates having to plot points by hand
and is easier for most people than trying to use the DXF file in conjunction with a CAD program).
Inkscape is FREE software
which runs on almost every conceivable computer (i.e. Mac, Linux, Windows, etc). Even if you don't want to learn to
use the application in general, it can still be used for the purpose of printing your sundial
with only minor effort on your part by following
these instructions.
Cartesian*
Data is given in familiar (x,y) coordinate form. Values are relative to the dial origin.
Polar*
When a dial center exists, data is given in polar coordinate form (r,θ).
Values are relative to the dial center,
with θ measured counter-clockwise from what would constitute the positive x-direction,
and ranging from 0° → 360°. Strictly speaking, all of this data is derived from the
cartesian data, but this output is an attempt to save the interested user intermediate steps that might
prove tedious.
Import DXF File
This function does not export data,
rather, it scans a DXF file and attempts to render LINE and POLYLINE elements to
SVG path elements underneath the dial on display. It may be used to directly compare the
output from this utility against DXF output from other dial programs.
* Note that in the case of analemmatic dials, all layout data is presented
together, so it doesn't matter which button you click to display the information.
Equation of Time
For each hour angle displayed on the dial graphic one can separately toggle the hour line and
the analemma associated with the hour line. In addition, once the analemma is displayed, one has the
option for displaying individual data points for the 1st, 11th, and 22nd of each month.
The options for toggling all the hourlines/analemmas will turn off/on the display of the entire
set of elements. If the state of the display is somewhat "mixed", it will choose the opposite state (i.e. all on vs.
all off) which is most consistent with the current state.
If one clicks to toggle all analemmas for the first time, it may take few seconds to calculate the
entire display.
Equation of Time / Analemma Layout Data
There is a lot of data in this section, but it is mostly redundant. It is done this way to maximize
the number of options available when it comes to actually laying out the dial on the surface where
it is to be constructed.
- DF_x & DF_y
-
These entries are the familiar cartesian coordinates of the point on the analemma.
They are measured relative to the dial origin.
- R & Theta*
-
These entries are the familiar polar coordinates of the point on the analemma.
They are measured relative to the dial center.
- // Dist & |- Dist*
-
These two entries stand for parallel and perpendicular distance,
and are measured relative to the standard hour line for the analemma
in question.
-
The parallel distance is measured from the dial center along the standard
hour line.
-
The perpendicular distance is measured at a 90° angle from the point on the
hour angle line as determined using the parallel distance.
* For situations in which the
dial center is located a long way away
(i.e. ∞), these data are not calculated.
Hour Lines
In the past, some civilizations and cultures considered the start of the day, and hence the first
hour of the day, to coincide with sunrise (Babylonians), while other (the Romans, or Italians) ended
the day at sunset, which also meant that for counting purposes, the first hour of the new day
began at sunset.
Babylonian hour lines indicate the number of hours the sun has been above the
horizon, or the number of hours that have elapsed since sunrise.
Italian hour lines indicate the number of hours of sunlight left in the day,
or the number of hours until sunset.
DXF File
Because this application runs inside a browser, it is somewhat limited in terms of its ability to
perform routine file operations on a user's computer.
⇐ Select all the text displayed in the text window to the
left and paste it into an ASCII text editor (e.g. "Notepad"), then save it on your
computer giving it whatever name you choose, with a file extension of
DXF (NOTE: make sure there are no blank lines at the beginning of the file).
SVG File
-
You can use this SVG file, in conjunction with Inkscape,
to print an image of the sundial exactly to scale.
This eliminates the tedium of having to hand-plot individual points. If you are unfamiliar with Inkscape, try this
short tutorial
to see how its done.
If you need any hints/instructions, try clicking the headings...
-
Saving the File to Disk
Because this application runs inside a browser, it is somewhat limited in terms of its ability to
perform routine file operations on a user's computer.
Select all the text displayed in the text window below
and paste it into an ASCII text editor (e.g. "Notepad"), then save it on your
computer giving it whatever name you choose, with a file extension of
SVG (NOTE: make sure there are no blank lines at the beginning of the file).
-
Adjustments for Paper Size & Units
This SVG document has been formatted for use with
Inkscape for the purpose
of printing an image of the sundial to scale. It assumes you will be printing on
8½ × 11"
paper (i.e. standard "letter" paper size) and that the units used for the dial
are inches (i.e. the numerical value for the length of the gnomon represents inches).
To change these default setting, you can either edit the text yourself using the following
instructions, or select the appropriate radio button to the right.
-
If you are using legal-size paper,
change the height and viewbox
parameters to read: height='1260' and viewbox='0 0 765 1260'.
-
If you are using A4 paper size, change the width, height and viewbox
parameters to read: width='744', height='1052' and viewbox='0 0 744 1052'.
-
If you are using units of centimeters instead of inches, you will need
to edit the parameter transform='matrix(96,0,0,-96,0,0)' to read:
transform='matrix(37.795,0,0,-37.795,0,0)'.
In time I intend to handle the conversion to other paper sizes and units programmatically, but right
now I'm in a hurry and am concentrating on just getting the routine in place and a series of instructions
written for how to use it in conjunction with Inkscape .... March 2011, BH.
Import DXF File
This function is intended to provide a rapid method for checking the numerical results of
this utility against the DXF output of other sundial calculators
(noteably, ZW2000
&
SONNE).
NOTE: My original intention was for this to be
a temporary function, but I decided to leave it in place to allow
any user with enough interest and skepticism to double-check the soundness
of the calculations. If you find a discrepancy for a particular dial,
please let me know.
SHOW/HIDE
I've personally checked the following dials and found no discrepancies:
Classic Dials :: Polar Gnomon
(Checked against ZW2000)
|
Standard Meridian |
Local Meridian |
Latitude |
Inclination |
Declination |
90 | 93.3 | 37.5 | 0 | 0 | SEE COMPARISON |
Shepherd's Dials
(Checked against SONNE: local time (with & w/out EoT), std time (with & w/out EoT))
|
Standard Meridian |
Local Meridian |
Latitude |
90 | 93.3 | 37.5 | SEE COMPARISON |
90 | 93.3 | 10 | SEE COMPARISON |
90 | 93.3 | -40 | SEE COMPARISON |
I didn't spend a great deal of time debugging this utility; once I could reliably check
both
ZW2000 and
SONNE my interest faded pretty rapidly, so your success in
checking against DXF output from other dial calculators may or may not meet with good results.
(Results of some of my checking can be found at:
https://docs.google.com/presentation/d/1bQFW5dTdnBvhqA4PmwVhmyJFABOVKLOcNzSAPKIvC9o/edit#slide=id.i0 .)
|
Here is a screenshot of a comparison between the default dial (modified to have
a perpendicular gnomon)and the output from ZW2000. The plot shows standard
time, standard time plus the EoT, babylonian and italian hour lines, and
the solar calendar for seven declinations.
|
-
• DXF output from ZW2000 can be copied and pasted directly for dials with
perpendicular gnomons. Polar gnomon dials require using "offsets" equal to the
coordinates of the substyle.
-
• DXF output from SONNE must also employ 'offsets' to translate the drawing
to line up. Its largely trial & error...good starting values are the coordinates of the SONNE
dial origin, which is offset from the DXF origin (use <TAB> to place the 'focus' on the input areas).
dx:
dy:
The function takes the DXF file and attempts to
render the LINE and POLYLINE elements to SVG path elements. These path elements
are displayed underneath the current dial's elements and are given a
larger width and bright color in order to provide contrast.
⇐Simply paste the ASCII contents from the DXF file and click Render DXF to SVG.
(NOTE: If you can't paste, try double-clicking on the input area to acquire the necessary 'focus'.
Also, use <TAB> to place the 'focus' on the input areas for dx and dy.)
Solar Calendar
These functions allow one to alter the declination values for which the solar calendar paths are
drawn.
When a dial is first drawn, it is drawn using a fairly standard set of values
(0°, ±11.5°, ±20°, ±23.44°) which roughly correspond to the passage
of the sun from one constellation of the Zodiac to the next (around the 22nd± of each month).
The paths for these values can be easily removed from the display (or restored).
User-specified custom values are also possible.
, as is toggling the entire set of paths corresponding to
the first day of each calendar month (e.g. Jan 1st, Feb 1st, etc.).
HELP FILE : Wall Declination Calculator
X-AXIS
Y-AXIS
gnomon
To Sun
Shadow
( Delta-X , Delta-Y )
•
If the readings were taken during "daylight savings time", you should make this
correction yourself before entering data in the "Watch" field. Note that
times after 12PM need to be between 12 and 24 (e.g. 1:33:30 PM would
be entered as 13:33:30).
•
Calculations involving the PZS triangle use the latitude and longitude(s)
from the "Dial Setup" dialog.
•
If your watch is not synchronized with GMT, enter the correction that would
need to be applied for it to read mean time (e.g. if your watch is
fast, enter a negative correction, and vice versa).
DATA TABLE DEFINITIONS
- Watch
-
Enter the time recorded directly from your watch.
- Delta-X
-
The horizontal distance of the nodus' shadow from the origin.
- Delta-Y
-
The vertical distance of the nodus' shadow from the origin.
- Local Time
-
This value is the recorded watch time corrected for longitude, the equation
of time, and any watch corrections (i.e. in the event your watch isn't
synchronized with GMT).
- LHA
-
This is the sun's local hour angle, given in decimal degrees.
- Alt1
-
The sun's altitude calculated using the PZS triangle.
- Alt2
-
The sun's altitude calculated using the shadow coordinates and the length of the
gnomon.
NOTE: Ideally, Alt1 and Alt2 should be identical.
- Sun Azm
-
Solar azimuth calculated using PZS triangle (measure clockwise, from
due north in the horizontal plane).
- Wall Azm
-
The wall azimuth calculated using the shadow coordinates and the length of the
gnomon.
- Wall Decl
-
The wall's declination: positive values are to the west; negative to the east.
Bailey Points / Seasonal Markers
These postions represent locations, standing at which, an observer can sight along the
appropriate date (from the gnomon position) and determine the direction to sunrise
(or sunset) for that date. (Note that this also assumes a perfectly horizontal horizon.)
Looking in the opposite direction (i.e. 180°) gives the time of sunrise (or sunset).
It is important to note that the position is not exact and actually varies
slightly with solar declination. This variation, however, is relatively small compared
to the overall dial size,
and is represented on the dial's graphic output by the width of the box defining
the location.
Using an analemmatic sundial for this purpose was first described by dialist
Roger Bailey (Walking Shadow Designs).
Longitude
Longitude values must lie between 180° and -180° (inclusive).
If you live west of Greenwich, enter positive values for longitude (this also includes
your time zone meridian longitude).
If you live east of Greenwich, enter negative values for longitude (this also includes
your time zone meridian longitude).