作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试使用给定的算法计算太阳的赤纬角。
我已经移植了在 so 上找到的 Java 代码到 C#,它给了我正确的结果:大约 -22,89
我的问题是我想执行 this算法,但我得到了错误的结果(大约 -11.65)。
我创建了一个 WinForm 应用程序来测试它:
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private int DayNumber
{
get
{
return DateTime.Now.DayOfYear;
}
}
private double CalculateDeclinationAngleJAVA()
{
return 23.45 * Math.Sin((DegreeToRadian(360.0 / 365.25)) * (DayNumber - 81));
}
private double CalculateDeclinationAngle()
{
var tmp = (2 * Math.PI) * ((284 + DayNumber) / 36.25);
return 23.45 * (Math.PI / 180.0) * Math.Sin(tmp);
}
private double DegreeToRadian(double angle)
{
return Math.PI * angle / 180.0;
}
private double RadianToDegree(double angle)
{
return angle * (180.0 / Math.PI);
}
private void Form1_Load(object sender, EventArgs e)
{
textBox1.Text = "C#: " + RadianToDegree( CalculateDeclinationAngle()).ToString();
textBox2.Text = "JAVA: " + CalculateDeclinationAngleJAVA().ToString();
}
}
最佳答案
我会将您的 CalculateDeclinationAngle()
重写为
private double CalculateDeclinationAngle()
{
var tmp = (2 * Math.PI) * ((284 + DayNumber) / 365.25);
return 23.45 * (Math.PI / 180.0) * Math.Sin(tmp);
}
这只是一个小错误,不是36.25而是365.25
在这里查看我的实验:http://rextester.com/QSLE14863
关于c# - 偏角的计算,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34577053/
我是一名优秀的程序员,十分优秀!