<?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:webmaster@plan9.bell-labs.com">webmaster@plan9.bell-labs.com</a>.</span>
</font></center>
</body>
</html>