<?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>’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<u.h>
#include<libc.h>
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->sec += sec;
if(t->sec >= 60) t->sec -= 60, t->min++;
if(t->sec < 0) t->sec += 60, t->min--;
t->min += min;
if(t->min >= 60) t->min -= 60, t->hour++;
if(t->min < 0) t->min += 60, t->hour--;
t->hour += hours;
if(t->hour >= 24) t->hour -= 24;
if(t->hour < 0) t->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->args, Tm *);
time = 0.5+(float)0x10000 * ((float)t->hour + (float)t->min / 60.0 + (float)t->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->args, Tm*);
return fmtprint(f, "%02d:%02d:%02d", t->hour, t->min, t->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->yday + 10); // angular orbital distance from solstice (10 days befor jan 1)
b = a + (360 / PI) * eccentricity * dsin(w * (t->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->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>