太阳方向角/高度角/赤纬角/太阳时角/真平太阳时差/理论计算方法(matlab)

1. 理论学习

方向角,高度角计算公式


如图,直观地描述了方位角**(圆盘上红色夹角)** 与高度角**(黄色线与圆盘的夹角)**

赤纬角计算公式


地球赤道平面与太阳和地球中心的连线之间的夹角 如图所示,23度那个.

时角计算公式


太阳时角是指日面中心的时角,即从观测点天球子午圈沿天赤道量至太阳所在时圈的角距离。 太阳时角的正负表示太阳相对于观测点子午线的位置:正值表示太阳位于子午线西侧,负值则表示太阳位于子午线东侧。

真太阳时与平太阳时的时差公式


n0的计算公式为:

2.参考代码(时间支持向量运算)

Matlab 复制代码
clc;
clear;

%% 设置经纬度和当地日期(下面时间参数支持向量运算)
lat   = 30;       % 北纬(单位:度)
lon   = 120;      % 东经(单位:度)
year  = 2024;     % 年份(单位:年)
month = 6;        % 月份(单位:月)
day   = 1;        % 日期(单位:天)
hour  = 12;       % 小时(单位:24h)
minute= 0;        % 分钟(单位:分钟)

%% 输出结果规定
% 太阳高度角输出结果(单位:度)
% 地面0 --> 90天空

% 太阳方位角输出结果(单位:度)
%        南
%        ^
%       180
% 东<--90 270-->西
%        0
%        v
%        北


%% 计算今年的累积天数sumdays (单位:天)
date1_num = datenum(year, 1, 1);       % 第一个日期的datenum
date2_num = datenum(year, month, day); % 第二个日期的datenum
% 计算两个日期之间的差值
sumdays   = date2_num-date1_num;


%% 计算太阳赤纬角sun_declinatio(单位:度)
%lat_rad为所在地的维度(弧度制)
lat_rad = deg2rad(lat);
%Bourges太阳赤纬角算法
n0=78.801+(0.2422*(year-1969))-round(0.25*(year-1969));
%b为日角(单位:幅度)
b=2*pi*(double(sumdays)-n0-1)/365.2422;
% sun_declinatio为太阳赤纬角(角度制)
sun_declinatio =0.3723...
    +23.2567*sin(b)...
    +0.1149* sin(2.0*b)...
    -0.1712* sin(3.0*b)...
    -0.758*  cos(b)...
    +0.3656* cos(2.0*b)...
    +0.02010*cos(3.0*b);

%转为(弧度制)
sun_declinatio_rad =deg2rad(sun_declinatio);



%% 计算太阳太阳时角ts (单位:幅度)
%Ts真太阳时与平太阳时的时差
Ts=0.0028-1.9587.*sin(b)+9.9059.*sin(2.*b)-7.0924.*cos(b)-0.6882.*cos(2.*b);
%Sd为平太阳时,为当地时间(注意这里的当地时间修正)
Sd = hour  + (minute- (120.0 - lon) * 4.0 ) / 60.0;
%st为真太阳时=真太阳时时差+平太阳
st=Sd+Ts/60;
%ts为所在地的太阳时角
ts = (st - 12.0) * pi / 12.0;

%% 计算太阳高度角Sun_altitude_ra(单位:度)
Sun_altitude_rad = asin(sin(sun_declinatio_rad) .* sin(lat_rad) + cos(sun_declinatio_rad) .* cos(lat_rad) .* cos(ts));
%转为度
Sun_altitude_angle=rad2deg(Sun_altitude_rad);



%% 计算太阳方位角Sun_azimuth_deg(单位:度)
Sun_azimuth_rad = acos((sin(Sun_altitude_rad) .* sin(lat_rad) - sin(sun_declinatio_rad)) ./ (cos(Sun_altitude_rad) .* cos(lat_rad)));
%转为度
Sun_azimuth_deg=rad2deg(Sun_azimuth_rad);
% 此时方位角是以南为零方位角,转换为以北为零方位角
Sun_azimuth_deg=180-Sun_azimuth_deg;
%进行角度范围转换
if ts > 0
    Sun_azimuth_deg =360-Sun_azimuth_deg;
end


%% 输出结果
disp("太阳高度角:");
Sun_altitude_angle'
disp("太阳方位角:");
Sun_azimuth_deg'

3.参考论文

4.参考链接

【公式推导+matlab代码】太阳位置(太阳方位角和太阳高度角)计算_太阳方位角计算公式详解-CSDN博客

相关推荐
叁两6 小时前
用opencode打造全自动公众号写作流水线,AI 代笔太香了!
前端·人工智能·agent
golang学习记6 小时前
GitLens 十大神技:彻底改变你在 VS Code 中的 Git 工作流
前端·后端·visual studio code
SuperEugene6 小时前
后台权限与菜单渲染:基于路由和后端返回的几种实现方式
前端·javascript·vue.js
兆子龙6 小时前
WebSocket 入门:是什么、有什么用、脚本能帮你做什么
前端·架构
是一碗螺丝粉6 小时前
LangChain 链(Chains)完全指南:从线性流程到智能路由
前端·langchain·aigc
月弦笙音6 小时前
【浏览器】这几点必须懂
前端
青青家的小灰灰6 小时前
迈向全栈新时代:SSR/SSG 原理、Next.js 架构与 React Server Components (RSC) 实战
前端·javascript·react.js
SuperEugene6 小时前
弹窗与抽屉组件封装:如何做一个全局可控的 Dialog 服务
前端·javascript·vue.js
UrbanJazzerati6 小时前
事件传播机制详解(附直观比喻和代码示例)
前端
青青家的小灰灰6 小时前
透视 React 内核:Diff 算法、合成事件与并发特性的深度解析
前端·javascript·react.js