Blame view

maglib/src/caldis.f 5.62 KB
eb2d6c5c   Hacene SI HADJ MOHAND   adding maglib
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
      subroutine caldis (ityp,isw,xgse,ygse,zgse,distby,ier)
c*
c***********************************************************************
c*
c*          "Copyright [c] CNES 98 - tous droits reserves"
c*          **********************************************
c*
c*PRO MAGLIB
c*
c*VER 99.03.31 - V 1.0
c*VER 01.06.01 - V 2.0
c*VER 03.01.06 - V 2.1
c*
c*AUT spec. CNES - JC KOSIK - juin 1995
c*AUT port. CISI
c*
c*ROL Theme : Frontieres et regions
c*ROL         Calcul de la distance d'un satellite a une frontiere :
c*ROL         magnetopause ou onde de choc.
c*
c*PAR ityp   (I) : parametre permettant de fixer le choix de frontiere
c*PAR            :    --> 1 magnetopause
c*PAR            :    --> 2 onde de choc
c*
c*PAR isw    (I) : valeur de l'indice de variabilite du vent solaire
c*
c*PAR xgse   (I) : coordonnee solaire ecliptique x (rayons terrestres)
c*PAR ygse   (I) : coordonnee solaire ecliptique y (rayons terrestres)
c*PAR zgse   (I) : coordonnee solaire ecliptique y (rayons terrestres)
c*
c*PAR distby (O) : distance satellite frontiere (rayons terrestres)
c*
c*PAR ier    (O) : code de retour
c*
c*NOT isw        : 1 a 5
c*NOT isw        : 1 : distance subsolaire = 12.6 rayons terrestres
c*NOT isw        : 2 : distance subsolaire = 11.7 rayons terrestres
c*NOT isw        : 3 : distance subsolaire = 11.  rayons terrestres
c*NOT isw        : 4 : distance subsolaire = 10.  rayons terrestres
c*NOT isw        : 5 : distance subsolaire = 8.8  rayons terrestres
c*
c*NOT ier        : sans objet
c*
c*INF utilise    : aberrm, inipbs, form, ptnew, boundy, disgb
c*
c*HST version 1.0 - 99.03.31 - creation de la maglib au CDPP
c*HST version 2.0 - 01.06.01 - correction de commentaires de code
c*HST version 2.1 - 03.01.06 - corrections en compilation avec g77
c*
c***********************************************************************
c*
      implicit none
c
c     ---------------------------------
c*FON Declaration identificateur rcs_id
c     ---------------------------------
c
      character rcs_id*100
c
c     --------------------------
c*FON Declaration des parametres
c     --------------------------
c
      integer ityp,isw 
      double precision xgse,ygse,zgse
      double precision distby
      integer ier 
c
c     ---------------------------------
c*FON Declaration des variables locales
c     ---------------------------------
c
      integer ier0,ier1,ier2,ier3,ier4,ier5
c*LOC ier1,ier2,ier3,ier4,ier5 : codes retour des modules appeles
c
      double precision xgsa,ygsa,zgsa
c*LOC xgsa,ygsa,zgsa : coordonnees solaires ecliptiques x, y et z corrigees
c
      double precision pa,pb,pc,pd,pe
c*LOC pa,pb,pc,pd,pe : parametres decrivant l'expression quadratique
c*LOC                : de la frontiere dans le repere solaire ecliptique
c
      double precision ga,gb,gc,gd,ge
c*LOC ga,gb,gc,gd,ge : parametres decrivant l'expression quadratique
c*LOC                : de la frontiere dans un repere annulant le terme xy
c
      double precision xss
c*LOC xss : parametre decrivant l'expression quadratique de la frontiere
c
      double precision posby
c*LOC posby : position par rapport a la magnetopause ou a l'onde de choc
c
      double precision tetby
c*LOC tetby : angle de rotation qui amene le repere solaire
c*LOC        : ecliptique dans le nouveau repere
c
      double precision rosnew
c*LOC rosnew : distance du satellite a l'axe de symetrie axiale
c
      double precision xsnew
c*LOC xsnew : coordonnee x du satellite dans le repere de symetrie axiale
c
      SAVE
c
c     ---------------------------------
c*FON Affectation identificateur rcs_id
c     ---------------------------------
c
      data rcs_id /"
     >$Id$"/
c
c     ******************
c     Debut de programme
c     ******************
c
      ier  = 0
      ier0 = 0
      ier1 = 0
      ier2 = 0
      ier3 = 0
      ier4 = 0
      ier5 = 0
c
c     -------------------------------------------------------------
c*FON Prise en compte de l'aberration du au deplacement de la terre
c*FON l'angle d'aberration est fixe a 4. degres 
c     -------------------------------------------------------------
c
      call aberrm(xgse,ygse,zgse,xgsa,ygsa,zgsa,ier0)
c
c     ----------------------------------------------------------
c*FON Initialisation des parametres du modele de magnetopause et
c*FON du modele d'onde de choc
c     ----------------------------------------------------------
c
      call inipbs(ityp,isw,pa,pb,pc,pd,pe,xss,ier1)
c
c     -------------------------------------------------------------
c*FON Calcul de l'equation de la frontiere dans un repere cartesien
c*FON lui donnant la symetrie axiale
c     -------------------------------------------------------------
c
      call form(pa,pb,pc,pd,pe,ga,gb,gc,gd,ge,tetby,ier2)
c
c     ------------------------------------------------------------------
c*FON Calcul des coordonnees d'un point du repere solaire ecliptique
c*FON dans le repere offrant la symetrie de revolution pour la frontiere
c    -------------------------------------------------------------------
c
      call ptnew(tetby,xgsa,ygsa,zgsa,xsnew,rosnew,ier3)
c
c     ----------------------------------------------------------------
c*FON Determination de la position du point par rapport a la frontiere
c     ----------------------------------------------------------------
c
      call boundy(ga,gd,ge,xsnew,rosnew,posby,ier4)
c
c     ----------------------------------------------------
c*FON Calcul de la distance du satellite a la frontiere en
c*FON conformite avec le standard trotignon
c     ----------------------------------------------------
c
      call disgb(ityp,xsnew,rosnew,ga,gd,ge,posby,distby,ier5)
c
c     ****************
c     Fin de programme
c     ****************
c
      return
      end