Run the disturbance model for a spacecraft with two rotating arrays.
Define the orbit a priori and call the disturbance model in batch. The sun vector is held constant. The spacecraft - body 1 - points at the sun while the arrays - bodies 2 and 3 - rotate to point at the sun.
Before the disturbances are calculated, the orientation is visualized in a loop using DrawSCPlanPlugIn. ------------------------------------------------------------------------ See also Disturbances, BuildTwoArraySC, Q2Mat, QLVLH, Date2JD, Period, RVFromKepler, SunV1 ------------------------------------------------------------------------
Contents
%------------------------------------------------------------------------------- % Copyright (c) 1998-2003 Princeton Satellite Systems, Inc. % All rights reserved. %------------------------------------------------------------------------------- % Since version 5.5 (2003) % 2016.1 Add visualization of Earth and Sun vectors with DrawSCPlanPlugIn to % verify correct solar panel pointing %-------------------------------------------------------------------------------
Load the CAD model of the demo spacecraft
%----------------------- g = load('TwoArraySC')
g = struct with fields: body: [1×3 struct] component: [1×34 struct] mass: [1×1 struct] name: 'Demo Spacecraft' omega: [3×1 double] q: [4×1 double] qLVLH: [4×1 double] rECI: [3×1 double] radius: 3.735 subsystem: [1×6 struct] units: 'mks' vECI: [3×1 double]
Ephemeris
%---------- jD = Date2JD([3 22 2001 0 0 0]); % Equinox [uSun, rSun] = SunV1( jD );
Disturbances
%------------- d = Disturbances('defaults'); solarFlux = 1367; % Watts/m^2 d.s = solarFlux*uSun; d.shadow = false; d.units = 'm'; d.planet = 'earth';
Initialize the disturbance model
%--------------------------------- hD = Disturbances( 'init', g, d );
data:image/s3,"s3://crabby-images/c6229/c6229f973b056df99228b620d8113424cc5e1558" alt=""
Do 100 samples in a circular orbit
%----------------------------------
nSamp = 100;
rOrbit = 7000;
period = Period(rOrbit);
d.tSamp = period/nSamp;
theta = linspace(0,2*pi,nSamp);
c = cos(theta);
s = sin(theta);
A circular orbit with LVLH pointing
%------------------------------------- [d.r,d.v] = RVFromKepler([rOrbit 0.5 0 0 0 0],linspace(0,period,nSamp)); qLVLH = QLVLH( d.r, d.v ); % Create the transformation matrix arrays. % In this case we are using angles and % axes. Visualize the result. %---------------------------------------- gD = g; gD.subsystem = []; for k = 1:nSamp g.body(1).bHinge(k).b = Q2Mat( qLVLH(:,k) )'; g.body(2).bHinge(k).angle = theta(k); g.body(2).bHinge(k).axis = 2; g.body(3).bHinge(k).angle = theta(k); g.body(3).bHinge(k).axis = 2; % Display gD.body(1).bHinge = g.body(1).bHinge(k); gD.body(2).bHinge = g.body(2).bHinge(k); gD.body(3).bHinge = g.body(3).bHinge(k); gD.rECI = d.r(:,k); gD.vECI = d.v(:,k); if k == 1 tag = DrawSCPlanPlugIn(gD); view(45,25) end DrawSCPlanPlugIn( 'vectors', tag, gD, uSun ); drawnow; end
data:image/s3,"s3://crabby-images/dad5d/dad5d1166899a1bd475d58a0755921a9f556842b" alt=""
Run
%----- Disturbances( 'run', g, d, hD ); Figui; %-------------------------------------- % PSS internal file version information %--------------------------------------
data:image/s3,"s3://crabby-images/9df97/9df9785e45b07d75dbdda7d074ec3f5ea432722a" alt=""
data:image/s3,"s3://crabby-images/84f63/84f638fa8d0f9adf415dc7471ffe8979e6a18ef4" alt=""
data:image/s3,"s3://crabby-images/c3d25/c3d2571e73acfbb446667d03472855ad6a2c2f28" alt=""
data:image/s3,"s3://crabby-images/71ae5/71ae5c75f2250acee7f1d2f0f3a380e5e0fb686e" alt=""
data:image/s3,"s3://crabby-images/cd5b5/cd5b5e0effc7c4997d630ac04ed44c1138a3be9c" alt=""
data:image/s3,"s3://crabby-images/1a8d2/1a8d223ce58939d523b844de2a06faa03e281014" alt=""
data:image/s3,"s3://crabby-images/c76d2/c76d26c81d4cc3ab8947e844d1de1277bd368172" alt=""
data:image/s3,"s3://crabby-images/6b564/6b5646c69fba5e755bbb02e57bbfa0695d2fbd53" alt=""
data:image/s3,"s3://crabby-images/8e1e7/8e1e744ff0777ec26b958b3b3147af2b1ffad3a9" alt=""
data:image/s3,"s3://crabby-images/9d863/9d863777016ab02a1bc56ac0403edf414c753912" alt=""
data:image/s3,"s3://crabby-images/bb862/bb8629c3e82e2995ce0cde7c45e79b8b0d874bf8" alt=""
data:image/s3,"s3://crabby-images/6c252/6c2525878108c90f000e1a548caa78f35a6c3a6d" alt=""
data:image/s3,"s3://crabby-images/4ac40/4ac4072d741c386c00be7a776e6e2f559343d2ca" alt=""
data:image/s3,"s3://crabby-images/c9414/c9414bea4a893f7783b95bb4881968426fc9130e" alt=""
data:image/s3,"s3://crabby-images/878ba/878ba1dbed4e56e0593965e62746bb1dd1b3ce06" alt=""
data:image/s3,"s3://crabby-images/8fd6f/8fd6f5bc494e30971bc03f49b0cdf63b57ae16e6" alt=""
data:image/s3,"s3://crabby-images/9b3c6/9b3c61adb0a80e6aef8a2c34e7964ceaeed979bf" alt=""
data:image/s3,"s3://crabby-images/e5758/e5758c1decd3793b6ebb3e2d419317dd7f609b3b" alt=""
data:image/s3,"s3://crabby-images/00054/00054846e36536c6eaa257be467f8b503b11b8ec" alt=""
data:image/s3,"s3://crabby-images/a2a96/a2a96dd211f2008c136f45f615f8033d37d3ed3d" alt=""