<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv=Content-Type content="text/html; charset=utf8">
<title>/usr/web/sources/contrib/bedo/solar.c - Plan 9 from Bell Labs</title>
<!-- THIS FILE IS AUTOMATICALLY GENERATED. -->
<!-- EDIT sources.tr INSTEAD. -->
</meta>
</head>
<body>
<p style="margin-top: 0; margin-bottom: 0.17in"></p>
<p style="line-height: 1.2em; margin-left: 1.00in; text-indent: 0.00in; margin-right: 1.00in; margin-top: 0; margin-bottom: 0; text-align: center;">
<span style="font-size: 10pt"><a href="/plan9/">Plan 9 from Bell Labs</a>&rsquo;s /usr/web/sources/contrib/bedo/solar.c</span></p>
<p style="margin-top: 0; margin-bottom: 0.17in"></p>
<p style="margin-top: 0; margin-bottom: 0.17in"></p>
<center><font size=-1>
Copyright © 2009 Alcatel-Lucent.<br />
Distributed under the
<a href="/plan9/license.html">Lucent Public License version 1.02</a>.
<br />
<a href="/plan9/download.html">Download the Plan 9 distribution.</a>
</font>
</center>
<p style="margin-top: 0; margin-bottom: 0.17in"></p>
<table width="100%" cellspacing=0 border=0><tr><td align="center">
<table cellspacing=0 cellpadding=5 bgcolor="#eeeeff"><tr><td align="left">
<pre>
<!-- END HEADER -->
#include&lt;u.h&gt;
#include&lt;libc.h&gt;

double longitude = 2.0 + 20.0 / 60.0;
const double eccentricity = 0.0167;
const double obliquity = 23.44;
const double deg2rad = 2 * PI / 360;

/* Adjusts a time structure by delta min */
void
correct(Tm *t, double delta)
{
       int hours, min, sec;

       hours = delta / 60;
       min = delta - hours * 60;
       sec = (delta - (int)delta) * 60;
       t-&gt;sec += sec;
       if(t-&gt;sec &gt;= 60) t-&gt;sec -= 60, t-&gt;min++;
       if(t-&gt;sec &lt; 0) t-&gt;sec += 60, t-&gt;min--;
       t-&gt;min += min;
       if(t-&gt;min &gt;= 60) t-&gt;min -= 60, t-&gt;hour++;
       if(t-&gt;min &lt; 0) t-&gt;min += 60, t-&gt;hour--;
       t-&gt;hour += hours;
       if(t-&gt;hour &gt;= 24) t-&gt;hour -= 24;
       if(t-&gt;hour &lt; 0) t-&gt;hour += 24;
}

double
dsin(double x)
{
       return sin(x * deg2rad);
}

double
dcos(double x)
{
       return cos(x * deg2rad);
}

double
dtan(double x)
{
       return tan(x * deg2rad);
}

double
datan(double x)
{
       return atan(x) / deg2rad;
}

/* Hex formatter */
#pragma varargck type "H" Tm*
int
hexfmt(Fmt *f)
{
       int hours, min, sec;
       uint time;
       Tm *t;

       t = va_arg(f-&gt;args, Tm *);
       time = 0.5+(float)0x10000 * ((float)t-&gt;hour + (float)t-&gt;min / 60.0 + (float)t-&gt;sec / (60.0 * 60.0)) / 24.0;
       hours = time / 0x1000;
       min = time % 0x1000 / 0x10;
       sec = time % 0x10;
       return fmtprint(f, "%01X_%02X_%01X", hours, min, sec);
}

/* Duodecimal formatter */
#pragma varargck type "D" Tm*
int
duofmt(Fmt *f)
{
       Tm *t;
       t = va_arg(f-&gt;args, Tm*);
       return fmtprint(f, "%02d:%02d:%02d", t-&gt;hour, t-&gt;min, t-&gt;sec);
}

void
usage(void)
{
       fprint(2, "%s: [-l longitude] [-x] [-f]", argv0);
       exits("usage");
}

void
main(int argc, char *argv[])
{
       Tm *t;
       int hex, follow;
       char *fmt;

       fmt = "%D\n";
       hex = 0;
       follow = 0;

       double w, a, b, c, eot;

       ARGBEGIN{
       case 'l':
               longitude = atof(EARGF(usage()));
               break;
       case 'x':
               fmt = "%H\n";
               hex++;
               break;
       case 'f':
               follow++;
               break;
       case 'h':
       default:
               usage();
       }ARGEND;

       if(argc != 0)
               usage();

       fmtinstall('H', hexfmt);
       fmtinstall('D', duofmt);

beginning:
       /* Get local mean time */
       t = gmtime(time(0));
       correct(t, longitude * 4.0);

       /* Calculate equation of time */
       w = 360 / 365.24; // Mean angular orbit velocity
       a = w * (t-&gt;yday + 10); // angular orbital distance from solstice (10 days befor jan 1)
       b = a + (360 / PI) * eccentricity * dsin(w * (t-&gt;yday - 2)); // angular deflection of earth
       c = (a - datan(dtan(b) / dcos(obliquity))) / 180; // Difference between mean and corrected angles
       eot = 720 * (c - floor(c + 0.5));

       /* Alternative formulation */
       /* w = 2 * PI * (t-&gt;yday - 1) / 365.242;
       eot = 0.258 * cos(w) - 7.416 * sin(w) - 3.648 * cos(2 * w) - 9.228 * sin(2 * w);*/

       //print("%f\n", eot);
       correct(t, -eot);
       print(fmt, t);

       if(follow){
               sleep(hex ? (1000 / 0.76) : 1000);
               goto beginning;
       }

       exits(0);
}
<!-- BEGIN TAIL -->
</pre>
</td></tr></table>
</td></tr></table>
<p style="margin-top: 0; margin-bottom: 0.17in"></p>
<p style="line-height: 1.2em; margin-left: 1.00in; text-indent: 0.00in; margin-right: 1.00in; margin-top: 0; margin-bottom: 0; text-align: center;">
<span style="font-size: 10pt"></span></p>
<p style="margin-top: 0; margin-bottom: 0.50in"></p>
<p style="margin-top: 0; margin-bottom: 0.33in"></p>
<center><table border="0"><tr>
<td valign="middle"><a href="http://www.alcatel-lucent.com/"><img border="0" src="/plan9/img/logo_ft.gif" alt="Bell Labs" />
</a></td>
<td valign="middle"><a href="http://www.opensource.org"><img border="0" alt="OSI certified" src="/plan9/img/osi-certified-60x50.gif" />
</a></td>
<td><img style="padding-right: 45px;" alt="Powered by Plan 9" src="/plan9/img/power36.gif" />
</td>
</tr></table></center>
<p style="margin-top: 0; margin-bottom: 0.17in"></p>
<center>
<span style="font-size: 10pt">(<a href="/plan9/">Return to Plan 9 Home Page</a>)</span>
</center>
<p style="margin-top: 0; margin-bottom: 0.17in"></p>
<center><font size=-1>
<span style="font-size: 10pt"><a href="http://www.lucent.com/copyright.html">Copyright</a></span>
<span style="font-size: 10pt">© 2009 Alcatel-Lucent.</span>
<span style="font-size: 10pt">All Rights Reserved.</span>
<br />
<span style="font-size: 10pt">Comments to</span>
<span style="font-size: 10pt"><a href="mailto:[email protected]">[email protected]</a>.</span>
</font></center>
</body>
</html>