zoukankan      html  css  js  c++  java
  • 太阳方位角

    #include "math.h"

    int GetDayOfYear(int Year,int Month,int Day)
    {
            //功能:给定年月日得到此日在一年中的天数,1月1日为第1天,分闰年和平年 
        //作者:汪帮主 2009-6-6 wzj08@mails.jlu.edu.cn    
        
        int DayOfYear;
        int FebDays;    
            
        if ((Year%4==0 && Year%100!=0) || (Year%400==0))
        {
            FebDays = 29;
        }
        else 
        {
            FebDays = 28;
        }
        
        DayOfYear = Day;
        if (Month > 1) DayOfYear = DayOfYear + 31; 
        if (Month > 2) DayOfYear = DayOfYear + FebDays;
        if (Month > 3) DayOfYear = DayOfYear + 31 ;
        if (Month > 4) DayOfYear = DayOfYear + 30 ;
        if (Month > 5) DayOfYear = DayOfYear + 31 ;
        if (Month > 6) DayOfYear = DayOfYear + 30 ;
        if (Month > 7) DayOfYear = DayOfYear + 31 ;
        if (Month > 8) DayOfYear = DayOfYear + 31 ;
        if (Month > 9) DayOfYear = DayOfYear + 30 ;
        if (Month > 10) DayOfYear = DayOfYear + 31 ;
        if (Month > 11) DayOfYear = DayOfYear + 30 ;
        return DayOfYear;
    }

    void GetSolarAngle(int year,int month,int day,int hour,int min,double sec,double lat,double lon,int TimeZone,int N ,double& AzimuthAngle,double& ZenithAngle)
    {
            //功能:计算太阳天顶角和太阳方位角 
        //作者:汪帮主 2009-6-6 wzj08@mails.jlu.edu.cn    
        double N0, sitar, ED, dLon, Et, Ho, viewAng;
        const double PI = 3.14159265;
        double dTimeAngle, gtdt, latitudeArc, latitude, HeightAngleArc;
        double AzimuthAngleArc, HANoon, dTA, TimeNoon, CosAzimuthAngle, HeightAngle;                        
        
        N0 = 79.6764 + 0.2422*(year-1985) - floor((year-1985)/4.0);
     
        sitar = 2*PI*(N-N0)/365.2422;
        ED = 0.3723 + 23.2567*sin(sitar) + 0.1149*sin(2*sitar) - 0.1712*sin(3*sitar)- 0.758*cos(sitar) + 0.3656*cos(2*sitar) + 0.0201*cos(3*sitar);
        ED = ED*PI/180;           //ED本身有符号,无需判断正负。
        //ED = (m_northOrSouth==0)? ED:(-ED);   

        dLon = 0.0;
        //地球上某一点与其所在时区中心的经度差
        if (lon >= 0)   
        {
            if (TimeZone == -1)
            {
                    dLon = lon - (floor((lon*10-75)/150)+1)*15.0;
            }
            else
            {
                dLon = lon - TimeZone*15.0;
            }
        }
        else 
        {   if (TimeZone == -1)
            {
                dLon =  (floor((lon*10-75)/150)+1)*15.0- lon;
            }
            else
            {
                dLon =  TimeZone*15.0- lon;
            }
        }

        Et = 0.0028 - 1.9857*sin(sitar) + 9.9059*sin(2*sitar) - 7.0924*cos(sitar)- 0.6882*cos(2*sitar); //视差
        
        gtdt = hour + min/60.0 + sec/3600.0 + dLon/15; //地方时
        gtdt = gtdt + Et/60.0;
        dTimeAngle = 15.0*(gtdt-12);
        dTimeAngle = dTimeAngle*PI/180; 
        latitudeArc = lat*PI/180;
         
        HeightAngleArc = asin(sin(latitudeArc)*sin(ED)+cos(latitudeArc)*cos(ED)*cos(dTimeAngle));

        CosAzimuthAngle = (sin(HeightAngleArc)*sin(latitudeArc)-sin(ED))/cos(HeightAngleArc)/cos(latitudeArc);
        AzimuthAngleArc = acos(CosAzimuthAngle);
        HeightAngle = HeightAngleArc*180/PI;
        AzimuthAngle = AzimuthAngleArc *180/PI;
        
        if( dTimeAngle < 0 )
        {   
            AzimuthAngle = 180 - AzimuthAngle;
        }
        else
        {
            AzimuthAngle = 180 + AzimuthAngle;
        }
        ZenithAngle = 90-HeightAngle;
    }
  • 相关阅读:
    BZOJ_2460_[BeiJing2011]元素_线性基
    BZOJ_4448_[Scoi2015]情报传递_主席树
    BZOJ_4004_[JLOI2015]装备购买_线性基
    BZOJ_3110_[Zjoi2013]K大数查询_整体二分+树状数组
    BZOJ_4128_Matrix_矩阵乘法+哈希+BSGS
    BZOJ_4378_[POI2015]Logistyka_树状数组
    BZOJ_2527_[Poi2011]Meteors_整体二分
    BZOJ_2738_矩阵乘法_整体二分
    BZOJ_3687_简单题_bitset
    HDU 4501
  • 原文地址:https://www.cnblogs.com/zany-hui/p/15490416.html
Copyright © 2011-2022 走看看