在进行仿真任务时,我们经常会用到太阳同步轨道、地球同步轨道、闪电轨道等一系列特殊的轨道。在设计这些轨道时,参数往往都有内在相关性或一定的约束,所以轨道参数并不是随意设置。在过去博文中,设置卫星参数都很随意,并不能满足我们平时的分析设计任务。STK中提供了快速插入上述特殊轨道的方式,即Orbit Wizard。本文先介绍手动操作,再介绍用STK与MATLAB互联操作。
(一)手动操作如下:
(1)新建卫星对象
(2)选中卫星对象,右键“satellite”→Orbit Wizard
(3)点击Orbit Wizard出现以下界面
(4)选择插入太阳同步轨道。选择如下参数进行设置,则将新建的卫星对象设置为太阳同步轨道。大家可以尝试试一下其他的轨道类型。
(二)互联操作,利用MATLAB代码实现
上代码:
uiap = actxserver(‘STK11.application’);
root = uiap.Personality2;
root.NewScenario(‘specialorbit’);
sc = root.CurrentScenario;
sat = sc.Children.New(18,‘mysat’);
%生成高度500km的太阳同步轨道
root.ExecuteCommand(‘OrbitWizard */Satellite/mysat SunSynchronous Altitude 500000’);
sat1 = sat.CopyObject(‘mysat1’);
%生成倾角10°、定点100°E的地球同步轨道root.ExecuteCommand(‘OrbitWizard */Satellite/mysat1 Geosynchronous Inclination 10 SubsatellitePoint 100 Color Green’);
sat2 = sat.CopyObject(‘mysat2’);
%生成高度500km,倾角50°的圆轨道,升交点赤经为0
root.ExecuteCommand('OrbitWizard */Satellite/mysat2 Circular Inclination 50 Altitude 500 RAAN 0 ');
sat3 = sat.CopyObject(‘mysat3’);
%利用Orbitdesigner生成轨道,这补充了之前轨道生成的另一种方式
root.ExecuteCommand(‘OrbitWizard */Satellite/mysat3 OrbitDesigner SemimajorAxis 7000000 Eccentricity 0 Inclination 5 ArgumentOfPerigee 0 RAAN 0 TrueAnomaly 0’);
sat4 = sat.CopyObject(‘mysat4’);
%生成冻结轨道(critically inclined orbit)
root.ExecuteCommand(‘OrbitWizard */Satellite/mysat4 CriticallyInclined Direction Posigrade ApogeeAltitude 3000000 PerigeeAltitude 500000 LAN 20’);
%Posigrade:顺行轨道,Retrograde:逆行轨道。这两种轨道的定义,可以自行搜索。
%LAN: value for longitude of ascending node in degrees,升交点地理经度
sat5 = sat.CopyObject(‘mysat5’);
%生成Molniya轨道(闪电轨道,具体含义请自行搜索)
root.ExecuteCommand(‘OrbitWizard */Satellite/mysat5 Molniya ApogeeLongitude 120 PerigeeAltitude 500000 ArgumentOfPerigee 0’);
sat6 = sat.CopyObject(‘mysat6’);
%生成太阳同步冻结轨道(CriticallyInclinedSunSync)
root.ExecuteCommand(‘OrbitWizard */Satellite/mysat6 CriticallyInclinedSunSync PerigeeAltitude 500000 LAN 0’);
本文介绍了在STK中如何生成特殊轨道的方法。这个要比自己编公式,按照原理生成要快速、简单。如果大家还有其他应用场景,我们可以一起讨论、研究。