Muf Luf Program

Download as pdf or txt
Download as pdf or txt
You are on page 1of 51

Naval Research Laboratory

Washington, DC 20375-5000

NRL Memorandum Report 6645

EINMUF: An HF MUF, FOT, LUF Prediction Program


MARK DAEHLER

Ionospheric Effects Branch

LnE..

Space Science Division Hulburt Centerfor Space Research

Ln

May 18, 1990

-Apeo

Approved for public release; distribution unlimited.

UNCLASSIFIED
SECURITY CLASSIFICATION OF THIS PAGE

REPORT DOCUMENTATION PAGE


la REPORT SECURITY CLASSIFICATION lb RESTRICTIVE MARKINGS 3 DISTRIBUTION /AVAILABILITY Approved OF REPORT

Form Approved

OMB No 074-0188

UNCLASSIFIED
2a SECURITY CLASSIFICATION AUTHORITY Zb DECLASSIFICATION/DOWNGRADING SCHEDULE

for public release; distribution unlimited.

4. PERFORMING ORGANIZATION REPORT NUMBER(S)

5 MONITORING ORGANIZATION REPORT NUMBER(S)

NRL Memorandum Report 6645


6a NAME OF PERFORMING ORGANIZATION 6b OFFICE SYMBOL

Naval Research Laboratory


6c. ADDRESS (City, State, and ZIP Code)

(If applicable)

7a. NAME OF MONITORING ORGANIZATION

4181
7b ADDRESS (City, State, and ZIP Code)

Washington, DC 20375-5000
8a. NAME OF FUNDING/SPONSORING ORGANIZATION 8b OFFICE SYMBOL 9 PROCUREMENT INSTRUMENT IDENTIFICATION NUMBER

Electromagnetic

(if applicable)

Compatibility Analysis Ctr.


8c. ADDRESS (City, State, and ZIP Code)

MIPR

89-CS-8084 of 10 February 1989


PROJECT I NO TASK NO WORK UNIT ACCESSION NO

10 SOURCE OF FUNDING NUMBERS PROGRAM ELEMENT NO

185 Admiral Cochrane Drive Annapolis, MD 21401


11 TITLE (Include Security Classification)

"EINMUF:

AN HF MUF, FOT, LUF PREDICTION PROGRAM"

12. PERSONAL AUTHOR(S)

Mark Daehler
13a TYPE OF REPORT 13b TIME COVERED FROM _$89 TO 14 DATE OF REPORT (Year, Month, Day) 15 PAGE COUNT

Final
16 SUPPLEMENTARY NOTATION

12/8

1990 May 18
"
-

52

17 FIELD

COSATI CODES GROUP SUB-GROUP

1 . SUBJECT TERMS (Continue on reverse if necessary and identify by block number)

High Freqenuy_(HF)
Clonospheric Propagation

Propagation Prediction
Sounder Updating

19 ABSTRACT (Continue on reverse if Aecessary and identify by block number)

This work describes a

ORTRAN algorithm, called Subroutine EINMUF, which

predicts the Maximum Usa e Frequency (MUF), the Frequency of Optimum Transmission (FOT), and th Lpowest Usable Frequency (LUF) on a specified HF communications path. A single ca-l_.to EINMUF produces up to 24 predictions at hourly intervals starting with a specifled day-time group DTG. MOF calculations

are made with the NOSC MINIMUF85 MUF-prediction program using the first
available sunspot number SSN from the following list: a) an effective SSN derived from current oblique-incidence sounder data; b) a 5-day running average

of SSNs derived from solar 10.7 cm flux measurements or direct SSN measurements;
c) an effective SSN determined from old sounder data; d) SSN extrapolated from previous SSN measurements by the McNish-Lincoln method; e) SSN derived from a

mean-value representation of the 11-year solar sunspnt number cycle.


20 DISTRIBUTION/AVAILABILITY OF ABSTRACT UNCLASSIFIED/UNLIMITED 0 SAME AS RPT 22a NAME OF RESPO INDIVIDUAL IBE 21 0l DTIC USERS 22 ABSTRACT SECURITY CLASSIFICATION

UNCLASSIFIED
Area Code)
22 OFFCE11 MBO

Dr. Mark Daeher DD Form 1473, JUN 86

2216-2
Previous editions are obsolete

418
SECURITY CLASSIFICATION OF THIS PAGE

S/N 0102-LF-014-6603

CONTENTS FORWARD ............................................................................................... 1. GENERAL DESCRIPTION ........................................................................... II. Ill. CALLING PARAMETERS ............................................................................ CALCULATIONAL METHODS ..................................................................... A. MUF Calculations ................................................................................ Al. Updating Method of MUF Prediction .................................................. A2. Measured 10.7 CM Flux Method of MUF Prediction .............................. A3. Average Sunspot Number Method of MUF Prediction ............................. A4. Updating With Imperfect Sounder Data ................................................ A5. MUF Prediction Based on McNish-Lincoln SSN Extrapolation ................... A6. MUF Prediction Based on Mean I1-Year Sunspot Cycle .......................... B. FOT Calculations ................................................................................. C. LUF Calculations ................................................................................. D. MINIMUF ....................................................................................... E. Triangular Interpolation ......................................................................... iv 1 3 6 6 6 7 8 9 9 10 10 1I II 12

IV.

SUBPROGRAM DETAILS ........................................................................... 13 A. Subroutine EFFSSN ........................................................................ 13 B. Subroutine DHOUR ......................................................................... 16 C. Subroutine INCDTG ........................................................................ 17 D. Subroutine NISHLINC, and Data File NISHDAT.DAT ............................. 18 E. Subroutine MEANSSN ..................................................................... 18 F. Function AVSSN and Data File SSNFILE.DAT ....................................... 19 REFERENCES .......................................................................................... PROGRAM LISTINGS .............................................. Aoession For
NTIS GRA&I DTIC TAB

V. VI.

21 23

Unannounced
Justification

f]

ID:t..

..

i00
.ilr

FOREWORD This work describes a FORTRAN algorithm, called Subroutine EINMUF, which provides a prediction, over a specified HF path, of the Maximum Usable Frequency (MUF), the Frequency of Optimum Transmission (FOT), and the Lowest Usable Frequency (LUF). A single call to EINMUF produces a sequence of up to 24 predictions, the first for a specified day-time group DTG, and each of the others for a time one hour following the time of the previous prediction. MUF calculations are made in any one of a number of methods, depending upon the type and age of solar and HF propagation data available at the time of prediction. The calculational heirarchy starts with the use of near-real-time ionospheric oblique-incidence-sounder data (the Maximum Observable Frequency, or MOF) from the specified HF path (or a nearby one), from which an effective sunspot number is calculated and used as a paramexer in the NOSC MINIMUF85 MUF-prediction program. This is the Updating technique, and is the preferred method for MUF prediction. If no sounder data is available, but a recent measurement of solar 10.7-cm flux is available, that value will be converted to an equivalent sunspot number and used with MINIMUF85. Lacking a 10.7-cm flux value, a recent sunspot number measurement will be used. If there is inadequate data for a MUF prediction by the previous methods, but there does exist some sounder data (even though it failed to satisfy the requirements of the first attempt at Updating), If a second attempt at Updating using the imperfect sounder data will be made. this is not possible, then a table will be searched for an applicable sunspot number prediction based on measured sunspot numbers from previous years, extrapolated by the McNish-Lincoln method. In the absence of McNish-Lincoln extrapolated data, a sunspot number is derived from a mean-value representation of the 11-year solar sunspot number cycle. The algorithm was designed to provide usable propagation predictions without extensive expertise from the operator. Decisions regarding suitability of propagation and solar data are therefore made as transparent as possible to the operator. This work has been funded by the DoD Electromagnetic Compatibility irocurement document MIPR 89-CSAnalysis Center (ECAC) of Annapolis, MD, undoThe subroutine is *nteaded for incorporation in the 8084 of 10 February 1989. Frequency Assignment System - HF (FAS-HF), an - frequency-management system being developed under contract to ECAC by the IIT Research Institute of Annapolis,MD.

iv

EINMUF: AN HF MUF, FOT, LUF PREDICTION PROGRAM

I. GENERAL DESCRIPTION Subroutine EINMUF is an algorithm designed primarily to provide the HF frequency manager with the best possible estimate of MUF on a specified path, for times up to 24 hours in advance. The method for calculating MUF depends on the propagation information available. The MUF forecasts are derived from the NOSC MINIMUF85 model, in which solar effects on the ionosphere are incorporated via the sunspot number variable. The sunspot number can be determined in various ways, depending on the type of solar or HF propagation information available. Subroutine EINMUF uses the first sunspot number from the following list for which the required data is available: 1. The effective SSN determined from recent sounder measurements of MOF on an appropriate HF path; 2. The sunspot number SSN derived from a current measured value of solar 10.7-cm flux, as reported by the Space Environment Services Center or other agency; 3. A sunspot number SSN which is a five-day running average of daily sunspot numbers, each determined from the 10.7-cm flux, if available, or from the sunspot number reported by the Space Environment Services Center or other agency; 4. SSN predicted by the McNish-Lincoln extrapolation method; 5. SSN determined from mean 11-year sunspot cycle data. In addition, subroutine EINMUF delivers values of lowest usable frequency (LIF) and frequency of optimum transmission. Values of LUF are determined by the NOSC QLOF program as published in report NOSC TR1189 (August 1987) by D. B. Sailors and W. K. Moision, with modifications as of July 1989 (private communication). Values of FOT are currently set to 85 percent of the MUF. The package identified as EINMUF comprises the following FORTRAN subroutines and functions:
NEW PROGRAM ELEMENTS EINMUF1 EFFSSN NISHLINC MINMIMUF PROGRAM ELEMENTS MUF85MD FOF2 PATH QLOF PROGRAM ELEMENTS QLOF ABSORB CH

NISHDAT DHOUR INCDTG MEANSSN AVSSN TRINTERP SSNFILE


Manuscript approved April 25. 1990.

RAZGC SYGN GCRAZ

CHIPINT SUBSOL

The first column above lists subroutines written specially for ECAC/IITRI. The second column lists the subroutines and functions which calculate MINIMUF MUF predictions, and the third column lists subroutines and functions which calculate QLOF LUF predictions. Figure 1 shows the paths by which the subroutines are called. The subprograms have the following functions: EINMUF is a subroutine in which the available solar information is inspected to determine which method of MUF determination is appropriate. Its calling parameters include information about the path, available information about the ionosphere, and the variables LUF, MUF, and FOT to be returned. EFFSSN is a subroutine which calculates the effective sunspot number corresponding to a measured value of MOF. NISHLINC is a subroutine which returns, for a specified month and year, a sunspot number prediction which is an extrapolation of measured sunspot numbers calculated by the McNish-Lincoln method. NISHDAT.DAT is a data file containing McNish-Lincoln predicted sunspot numbers. These data are included as a separate file so that new values can be inserted as they become available, without having to re-compile the EINMUF program. Data file NISHDAT.DAT can be regenerated with newer data using program NISHDAT.FOR. DHOUR is a subroutine which translates a day-time group DTG into year, day of year, month, day, hour, and a quantity called REFHOUR, which is the number of hours elapsed since 010000ZJAN85. The variable REFHOUR is used to determine the time interval between two values of DTG. INCDTG is a subroutine which returns a day-time group DTG2 which is exactly one hour later than a specified day-time group DTGl. This subprogram is used to set up the list of times for which MUF, LUF, FOT values are required. MEANSSN is a subroutine which, for a specified month and year, returns a sunspot number based on the mean 11-year sunspot cycle, starting with a minimum value in September 1986. AVSSN is a subroutine which manages a file of sunspot number data and calculates a 5-day average sunspot number from the data for the current and four previous days. The data file SSNFILE.DAT is updated everytime EINMUF is called and a previously-unreported sunspot number is included in the variables SSN, DTG2. MUF85MD is the NOSC MINIMUF routine MUF85, which uses the associated subprograms FOF2,PATH, RAZGC, SYGN, and GCRAZ, with a few minor modifications made for convenience in calling by EINMUF. QLOF, with the associated subprograms ABSORB, CH, CHPINT, and SUBSOL are NOSC routines for calculating the Lowest Usable Frequency.

TRINTERP is a subroutine which calculates an effective flux by triangular interpolation of effective fluxes determined by sounder measurements on up to three paths, the midpoints of which are "close" to the midpoint of the path for which the MUF prediction is being made. The FORTRAN listing for the subroutine is included with EINMUF, but it's operation has not yet been implemented.

II. CALLING PARAMETERS The calling statement for subroutine EINMUF is: CALL EINMUF (TLAT, TLONG, RLAT, RLONG, DTG, NUMHRS, CMFLUX, SSN, DTG2, LUF, FOT, MUF, HOUR, METHOD, ERRCOD) Input parameters are: Variable TLAT TLONG RLAT RLONG DTG Type Real Real Real Real Character*12 Description Transmitter latitude [radians]
Limits: -PI/2 =< TLAT =< PI/2

Transmitter West longitude [radians]


Limits: 0 =< TLONG =< 2*PI

Receiver latitude [radians]


Limits: -PI/2 =< RLAT =< P1/2

Receiver West longitude (radians]


Limits: 0 =< RLONG =< 2*PI

Day-time group for which first MUF is being requested Limits: 010000ZJAN85 - 312359ZDEC84 ( = OOOOZ 1 Jan 1985 - 2359Z 31 Dec 2084) Number of successive hours, starting with DTG, for which MUFs are being requested
Limits: 1 =< NUMHRS =< 24

NUMHRS

Integer

CMFLUX

Real

Current 10.7-cm flux value. If no current value is available, enter CMFLUX=0.0.


Limits: 43 =< CMFLUX =< 275

SSN

Real

Most recent measurement of sunspot number If no current value is available, enter SSN=-300.0
Limits: -27.31 =< SSN =< 250

DTG2 METHOD(24)

Character*12 Character*l

Day-time group of CMFLUX or SSN measurement Limits: Same as for DTG (Optional) A lower-case letter entered in the CALL will force a particular method (if data is available); otherwise successive methods from this list will be used: 'im' => updating (Method 1) 'c' => 10.7 cm flux (Method 2) 's' => Measured SSN (Method 3) 'q' => Updating with imperfect sounder data (Method 4) '1' => McNish-Lincoln SSN (Method 5) 'e' => SSN from mean SSN cycle (Method 6)

Common Block variables used by EINMUF: Variable UPMOF(96,3) Type Real

Common Block /UPMOF/ UPMOF,UPDTG Description

Array containing 96 measured MOF values [MHz] for each of 3 paths. UPMOF(l,I) is the most recent value for path I; UPMOF(2,I), UPMOF(3,I), etc., are values for successively earlier times. Limits: UPMOF(I) > 0 Array containing 96 day-time groups for each of 3 paths, corresponding to the MOF values of array UPMOF(96,3). UPDTG(l,I) is the time of the most recent measurement for path I; UPDTG(2,I), UPDTG(3,I), etc. are DTGs corresponding to successively earlier times. Limits: Same as for DTG

UPDTG(96,3)

Real

OUTPUT PARAMETERS: Variable MUF(24) Type Real Description First NUMHRS elements contain MUF [Mhz] for successive hours starting with DTG
Limits: 2.0 <= MUF(I) <= 50.0

FOT(24)

Real

First NUMHRS elements contain FOT [Mhz] for successive hours starting with DTG
Limits: 1.7 <= FOT(I) <= 42.5

LUF(24)

Real

First NUMHRS elements contain LUF [Mhz] for successive hours starting with DTG
Limits: 1.5 <= LUF(I) <= 50.0

HOUR(24)

Integer

For first NUMHRS elements, HOUR(I) contains integer hour of the MUF(I) prediction
Limits: 0 <= HOUR <- 23

METHOD(24)

Character*l

For first NUMHRS elements, METHOD(I) contains the code letter of method used to obtain prediction MUF(I): M => Updating (Method 1) C -> 10.7 cm flux measurement (Method 2) S => SSN measurement (Method 3) Q => Updating with imperfect sounder data (Method 4) L => McNish-Lincoln SSN prediction (Method 5) E => SSN from mean 11-year solar cycle (Method 6)

III. A. Al.

CALCULATIONAL METHODS MUF CALCULATIONS UPDATING METHOD OF MUF PREDICTION

The Updating method is based on the assumption that the MUF on an HF path for times in the near future can be predicted more accurately by taking into account recent MUF measurements on that path (or on a nearby path) than by using a statistical MUF model alone. The value of this technique has been established in a number of studies. See, for example, Reilly and Daehler (1986), Goodman et al. (1984), and Daehler (1984). Subroutine EINMUF therefore attempts, as a first choice, to find Updating data (in the COMMON block /UPMOF/) which are sufficiently recent to provide an adequate ionospheric assessment. These quantities are contained in the arrays UPMOF(I,J), UPDTG(I,J) which contain, respectively, the MOF measurpment and the day-time group DTG of that measurement for paths J - 1 to 3 and measurements I = 1 to 96. At a rate of one sounder measurement per path every 15 minutes, these arrays permit storage of a full 24-hours accumulation of sounder data for each of the three paths. It is assumed that UPDTG(Il) is the DTG of the most recent measurement on path I, and that other elements of the array, UPDTG(I,2), UPDTG(I,3), etc., are at successively earlier times. A substantial part of the Updating process is a determination of which of the available measurements are sufficiently close to the time for which a prediction is required to be useful. The comparison of two times is somewhat complicated because times are specified by day-time group, and the two times may correspond to different days, months, or even years. The occurrence of a leap day in the year may also have an effect. For this reason, each day-time group which has to be compared is converted in EINMUF to a reference time, which is defined as the number of hours since 010000ZJAN85. The conversion from DTG to REFHOUR is a part of Subroutine DHOUR. Subroutine EINMUF is able to predict MUFs for NUMPTS times, starting with the day-time DTG. For the Kth prediction, for which the reference time is REFHOUR(K), the following values are considered acceptable MUF values for Updated predictions: 1. Average of all UPMOFs whose times fall between REFHOUR(K) REFHOUR(K), if there is at least one value; 2.1 and

2. Average of all UPMOFs whose times fall between REFHOUR(K) - 3.1 and REFHOUR(K), if there is at least one value; 3. Average of all UPMOFs whose times fall between REFHOUR(K) - 4.1 and REFHOUR(K), if there is at least one value; 4. Average of all UPMOFs whose times fall between REFHOUR(K) - 5.1 and REFHOUR(K), if there is at least one value;

5.

Average of all UPMOFb whose times fall between REFHOUR(K) ":FHOUR(K), if there is at least one value; Average of all UPMOFs whose times fall between REFHOUR(K) REFHOUR(K), if there is at least one value; Average of all UPMOFs whose times fall between REFHOUR(K) REFHOUR(K) - 18.9, if there is at least one value.

6.1 and

6.

7.1 and

7.

25.1 and

These criteria are based on data collected on three paths in eastern USA (Daehler, 1984). In this work, it was shown that MUFs predicted by Updating were more accurate than MINIMUF3.5 predictions if the updating data was obtained 7 hours or less previous to the time for which the predictions were made. The advantage is also realized if the Update prediction is made with data collected between 19 and 24 hours earlier, even though Updating with data aged between roughly 8 and 18 hours gives results less accurate than those of MINIMUF3.5. These conclusions are taken from Figure 2. If the data cannot satisfy any of the above criteria, the Updating method can't be used, and MUF determination by the next method (use of a measured 10.7 cm flux) is attempted. Assuming that Updating data sufficient to satisfy one of the above conditions does exist, the following steps are then taken: 1. The average value of the updating times (PDHR values) is taken;

2. The effective sunspot number SSNEFF corresponding to the average UPMOF value and the average updating time is calculated; 3. SSNEFF is used in MINIMUF85 to calculate the Updated MUF for the required time.

A2.

MEASURED 10.7 CM FLUX METHOD OF MUF PREDICTION

In the absence of adequate Updating data, the MUF is calculated using a measured value of solar 10.7 cm flux, if the EINMUF calling statement contains a non-zero value of the parameter CMFLUX. This quantity expresses the measured value of solar 10.7 cm flux in units of 10-22 W m- 2 Hz -1 . For use in MINIMUF85, CMFLUX is converted into an equivalent sunspot number according to the relationship between sunspot number according to the relationship between sunspot number and 10.7 cm flux determined by Steward and Leftin (1972) and recommended by Sailors et al. (1986):
2 CMFLUX = 63.7 + 0.728 * SSN + 0.00089 * SSN

Solving this equation for SSN yields SSN - 561.8 * [SQRT(O.303 + 0.00356 * CMFLUX) - 0.728).

The limits to the variable CMFLUX correspond to the range SSN[-27.31, 250] of sunspot number values which are meaningful for MINIMUF85. The corresponding range of meaningful 10.7 cm flux values is CMFLUX[42.2, 275.1]. Current values of 10.7 cm flux, updated approximately every three hours, can be obtained from the answering telephone service of the Space Environment Services Center, Boulder, Colorado. Phone number is (303) 497-3235.

A3.

AVERAGE SUNSPOT NUMBER METHOD OF MUF PREDICTION

If a MUF calculation by the previous methods has been unsuccessful, or if the use of a specific sunspot number is required by specification of 's' in the METHOD calling parameter, then EINMUF calculates the MUF using MINIMUF85 with a five-day running-average sunspot number SSN. Function AVSSN manages a file SSNFILE.DAT of daily sunspot numbers, and uses data from this file to calculate five-day average values. The daily values are determined from measurements of CMFLUX, if available (see section A2); otherwise, they are reported measurements of sunspot number. The average value for a given day is calculated as the average of all the SSN values existing in SSNFILE.DAT for that day and the preceding four days, a total of up to five values. If there are no SSN values in SSNFILE.DAT for the appropriate days, Function AVSSN returns the value -300.0. A smoothed sunspot number is generally appropriate in frequency-management applications because the decreased fluctuations in the smoothed value are considered more characteristic of the ionospheric propagation medium than the typically large fluctions in the daily sunspot number. There is no definitive information on the best averaging time, although it is typically taken to be three to five days. The value used in AVSSN is five days. The number of days over which SSN is averaged can be easily changed by resetting the value of the variable NUMDAYS in function AVSSN. Details on doing this are contained in the section on Function AVSSN and in the FORTRAN listings. Whenever subroutine EINMUF is called, the daily sunspot is determined either from CMFLTUX or SSN, and Subroutine AVSSN the values SSN2, DTG2 in file SSNFILE.DAT. Only one value of each day. If EINMUF is called with a DTG2 corresponding to a there already is a stored value of sunspot number, the stored with the new value. number value SSN2 is called to store SSN is stored for day for which value is updated

The sunspot number averaging feature is also contained in Function AVSSN(DTG,DTG2,SSN). Function AVSSN is called every time EINMUF is entered, so that any available DTG2,SSN2 will be entered into the data file SSNFILE.DAT, even if the MUFs requested in the call do not require calculation by the parameters CMFLUX or SSN. This procedure assures that any sunspot number data present in any call to EINMUF will be entered into SSNFILE.DAT, and will be available for future calls to EINMUF.

The amount of data stored in the file SSNFILE.DAT is limited to thirty DTG2,SSN data pairs. This was considered to be large enough to handle any forseen exercise, without permitting the file to grow to unlimited size. If this amount of data should prove to be inadequate (or unnecessarily large), the quantity of data saved may of course be increased without difficulty.

n4.

UPDATING WITH IMPERFECT SOUNDER DATA

If the first three methods fail for lack of adequate sounder and ionospheric data, it is still possible that there is available sounder data which did not meet the specifications for the Updating attempt, but which can be used in a second Updating attempt. Even though the sounder data may be old, it is reasonable to expect that Updating with this data may yield more reliable results than the methods based on extrapolation of historical SSN mean values. In this procedure, an effective SSN is calculated from every measured value of MOF in the UPMOF array, regardless of the times at which the measurements were made. These effective fluxes are then averaged, and the resulting value is used in MINIMUF85 to determine the MUF.

AS.

MUF PREDICTION BASED ON MCNISH-LINCOLN SSN EXTRAPOLATION

Sunspot numbers predicted by the NcNish-Lincoln method (McNish and Lincoln 1949) are published monthly in the Solar-Geophysical Data Prompt Reports Part I (NOAA, Boulder, Colorado). Values for times up to two or three years in advance are published, although beyond one year the predicted SSN values rapidly approach those of the mean values of the thirteen solar cycles (cycles 7 through 20) used in the extrapolation technique. McNish-Lincoln sunspot number prediction data are maintained in a separate file named NISHDAT.DAT. This permits data to be revised, as new data become available, simply by revising the small file NISHDAT.DAT, without requiring that the entire system be recompiled and/or linked. The program NISHDAT.FOR is provided as a convenient way to generate the data file. The quantities required are: (a) a list of consecutive predicted values for any number of consecutive months; (b) the number of months; and (c) the month number (JAN = 1, etc.) and year (e.g., 1989) of PRED(1), the first predicted value in the array. Instructions are included in the source listing. Subroutine NISHLINC(DTG,SSN) returns a sunspot number SSN for the time specified by the day-time group DTG. The subroutine extracts the month and year from DTG and determines if there is a value in the data array PRED (which contains data taken from NISHDAT.DAT) for that month and year. If so, the variable SSN returns that value. If there is no predicted value for that month and year, the returned value is SSN=-999.0.

A6.

MUF PREDICTION BASED ON MEAN Il-YEAR SUNSPOT CYCLE

This subroutine is included so that a plausible estimate of SSN, including th,- effect of the 11-year sunspot cycle variation, will be available to EINMUF even for times in the distant future. The result cannot be considered to have great accuracy because sunspot cycles vary substantially in their maximum SSN values, in their rates of SSN rise and fall, and in the times between maxima and minima. The capability may nevertheless be useful for planning and demonstration purposes. From tabulated dates of sunspot minima in cycles 1-18 (McNish and Lincoln 1949) the mean time between minima is 11.082 years, or very nearly 133 months. Mean SSN values for cycles 8-20 have been presented in graphical from (e.g., Solar Geophysical Data Prompt Reports, February 1989, Number 534, Part I, page 15). These data have been combined to provide the model used in subroutine MEANSSN. The mean sunspot number values were scaled from the curve in the latter reference. This curve extended for only 128 months, apparently because of the low statistical certainty in determining the mean cycle duration, so the last five values for the 133-month period had to be determined by extrapolation. This results in a discontinuity in our model (the cycle starts with SSN=5 and ends with SSN=9), but this should not be serious because the values are very low and the disparity is not excessive when compared with the overall accuracy of the mean-value approximation. The model is illustrated in Figure 3. Subroutine MEANSSN references time to September 1986, the time of the most recent sunspot minimum, with successive minima being assumed to occur every 133 months. The sunspot number for any given time is determined by the length of time since the preceding minimum, according to Table 1. Sunspot numbers in the current sunspot cycle (starting September 1986) have been unusually high, as illustrated in Figure 3. Although the maximum has not yet been reached, it can be estimated from the rate of rise that the maximum will be on the order of twice the mean-cycle maximum. Thus for times in the current cycle (that is, through September 1997) subroutine MEANSSN returns an SSN value which is twice the quantity tabulated in Table 1. Subroutine MEANSSN( MONTH, MYEAR, SSN) is valid for the months September 1986 through December 2085 (MONTH=9, MYEAR=86 through MONTH=12, MYEAR=185). If the subroutine is called for times outside this range, the value SSN=0.0 is returned. Within the range of validity the value 0.0 never occurs, so testing the returned SSN for a zero value can serve as an out-of-range indication, if desired.

B.

FOT CALCULATIONS

The frequency of optimum transmission (FOT) can be defined in several different ways. For many purposes it is adequate to define it as a fraction of
the MUF, usually between .75 and .90. the MUF calculated by MINIMUF. In EINMUF, the FOT is taken to be 85Z of

10

Alternatively, the FOT can be defined in terms of the highest frequency at which the signal/noise ratio exceeds a minimum required value for a stated Such a definition requires fraction of the time during a month (typically 90Z). that the system performance properties be known, which in turn requires that information about transmitter power, antenna gains, and noise levels be known. The use of this FOT definition in the current implementation of EINMUF was not considered because of the unavailability of this information.

C.

LUF CALCULATIONS The lowest usable frequency (LUF) for an HF circuit is calculated with the

NOSC QLOF 2.0 program (Sailors and Moision 1987). The subprograms required along with QLOF are subroutines ABSORB, SUBSOL, and DHOUR and functions CH and CHPINT. Of these, listings for QLOF, ABSORB, CH, and CHPINT were taken from the NOSC QLOF 2.0 reference. Subroutine SUBSOL, which is required for calculation of the sub-solar point coordinates, was obtained from NOSC by private communication. In EINMUF, time is passed to QLOF with the day-time group DTG variable, rather than the array ITIME; thus the NRL subroutine DHOUR is used to decompose DTG into hours, minutes, and seconds, etc. The QLUF implementation in EINMUF does not include a feature of QLOF 2.0 in which the LUF is adjusted to take into account such system parameters as transmitter power, antenna gains, and required S/N ratio. This adjustment is contained in Subroutine ADJUST (and associated program elements GTABLE, GCRAZ, ANTFAC, SYSDAT, IDANT, and ANTNAM). This omission is due in part to the incomplete documentation in the QLOF 2.0 report, and in part to the fact that inclusion of system parameters was not intended in the EINMUF concept.

D. MINIMUF The MUF-prediction program MINIMUF was created by NOSC to provide a useful frequency-management tool with small computer demands. It incorporates an ionosphere which models the statistical mean ionosphere at all positions on the earth. MINIMUF has been extremely successful, and has undergone a number of revisions as the data base upon which the model is based has become larger. The most current published version is MINIMUF85 (Sailors et al., 1986), the FORTRAN listing of which bears the name Subroutine MUF85. The associated subroutines and functions FOF2, PATH, RAZGC, and SYGN are taken from the same reference. Subroutine GCRAZ, which is CALLed by Subroutine PATH, was taken from Sailors and Moision (1987).

11

Subroutine EINMUF incorporates MINIMUF85 with only a few modifications which make it more convenient for use by EINMUF, and three changes recommended by NOSC. The modifications are: 1. A change in the calling parameter list to include the day-time group DTG instead of the 6-element array ITIME; 2. A change in the calling parameter list to make the program return the value of GO, the effective zenith angle, for use by EINMUF in calculating the effective sunspot number; 3. Removal of the logical variable V and of statements which are included if V = .TRUE.; according to NOSC (private communication), the V = .TRUE. condition is used only when MINIMUF85 is being called for ray-tracing routines in the PROPHET system. 4. Implementation of three modifications to Subroutine MUF85 and Function FOF2 recommended by NOSC (private communication). Referenced to the FORTRAN listings in Sailors et al (1986), these are: a. In MUF85, page 95, between statements "K9=0.0" and "GO TO 140" (the two lines preceeding statement 100), add the statement "A4=1.0"; b. In FOF2, page 98, change the fifth line from the bottom of the page from U=COS(T*T) to U=COS(T+T); c. In FOF2, page 99, change the fifth statement from the end to read: PLR=(2.5+SSN/50.0+U*(0.5+(1.3+0.002*SSN)*YS4) +(1.3+0.005*SSN)*COS(PHI-PI*(1.0+B))) *(1.0+0.4*(1.0-V*V))*EXP(-V*YS4)

E. TRIANGULAR INTERPOLATION A communications network established in a region in which sounders are operated on two or more paths can in some cases take advantage of the additional sounder information. It has been shown (Reilly and Daehler, 1986) that MOF predictions of increased accuracy can be produced by Updating with MOFs from three sounder paths whose midpoints form a triangle enclosing the midpoint of the path for which the predictions are being made. The use of multiple sounders for acquiring Updating data decreases statistical uncertainties and allows for ionospheric tilts. It also adds a measure of redundancy, since the prediction algorithm can always fall back to a smaller number of Updating paths if data from one sounder should become unavailable. Since a capability for triangular interpolation is considered useful for the EINMUF prediction algorithm, provision has been made for its incorporation. Subroutine TRINTERP has been included in the EINMUF source listings, and the appropriate UPMOF and UPDTG data arrays have been included. However, the coding in which EINMUF determines the applicability of multiple-sounder interpolation and calls subroutine TRINTERP has not yet been written.

12

IV.

SUBPROGRAM DETAILS

A. SUBROUTINE EFFSSN, A subroutine for calculating the effective sunspot number. The calling statement for subroutine EFFSSN is CALL EFFSSN(TLAT, TLONG, RLAT, RLONG, DTG, OBSMUF, SSNEFF) Given a path (specified by transmitter coordinates TLAT, TLONG and receiver coordinates RLAT, RLONG), the month, year, and time of day (specified by DTG), and OBSMUF (a measured value of MUF for those conditions), subroutine EFFSSN returns an effective sunspot number SSNEFF. The effective sunspot number SSNEFF is the sunspot number which makes MINIMUF85 produce the MUF value OBSMUF under the stated path and time conditions. The MUF predicted by the MINIMUF85 model for the given path is proportional to a factor G(SSN,GO):
G(SSN,GO) - (SQRT(6 + [.814 SSN + 22.23] SQRT(GO))) (1.3022 - .00156 SSN)

(Equation 1) The first factor on the right-hand side represents the dependence of the critical frequency foF2 on sunspot number, as determined by fitting the constants of the factor to vertical-incidence sounder data. (The factor GO is the cosine of the effective zenith angle, the angle between the vertical and the direction of the sun.) The second factor, a part of the "obliquity"- or *M"factor, represents the saturation of MUF for very large SSN values. Combined, these two factors describe a non-linear dependence of the MUF on sunspot number. This representation differs from that of MINIMUF 3.5, in which the linear dependence made calculation of effective sunspot number very simple. Using Equation 1, the relationship between a measured value OBSMUF (and the corresponding effective SSNEFF) and the quantity MUF(SSN) corresponding to an arbitrary sunspot number SSN is OBSMUF
R=

(1.3022-.00156 SSNEFF) (SQRT(6+[.814 SSNEFF +22.23] SQRT(GO)))


=.. ----------------------------................................

--------MUF(SSN)

(1.3022-.00156 SSN)

(SQRT(6+[.814 SSN + 22.23] SQRT(GO))) (Equation 2)

After substituting any value of SSN and calculating MUF(SSN) from MINIMUF85, the above equation can be solved for the effective sunspot number SSNEFF. Before calculating EFFSSN, however, the limits to OBSMUF and SSNEFF will be discussed.

13

Figure 4 illustrates the quantity G(SSN,GO) as a function of SSN for various values of GO. For typical conditions of SSN between 0 and 250, and GO greater than 0.1, the function G is a generally monitonically increasing function of SSN. Outside of the typical conditions, however, G doesn't behave the same way. For large values of SSN, G becomes a decreasing function of SSN, which is physically unrealistic. This means that the MUF is double-valued, in that two values of SSN can result in the same MUF value. The effect is more pronounced for lower values of GO; for GO = .0001, function G is a monitonically decreasing function of SSN over the entire range of SSN between 0 and 250. In addition, very low values of SSN cause the function GO to become negative, which should imply a negative MUF value. This is again a physically unrealistic condition. While the behavior of the function G over non-typical regions of its parameters is not a hinderance in application of the MINIMUF model, care must be taken in calculating the effective flux corresponding to a measured MUF value, since it can easily happen that extreme ionospheric conditions will yield MUF values well outside the normal range. It is therefore necessary to define limits to the range of the MUF used for updating, and thereby the limits to the effective flux which will be returned. The value of sunspot number which gives the maximum value of MUF can be found by differentiating Equation 1 and setting the result equal to zero. The resulting extreme value (which turns out indeed to be a maximum) is
SSNHI
=

260.04 - 4.914 / SQRT(GO)

(Equation 3)

To calculate SSNHI for a specified path, we first adopt a sunspot number value SSNTST (we use the value SSNTST=100) and calculate from MINIMUF85 the corresponding value CMUFTST = MUF(SSNTST). At the same time, the value GO for the path is calculated. Then SSNHI is calculated from Equation 3, and the MUF corresponding to SSNHI, called CMUFHI, is calculated from Equation 1: CMUFHI = MUFTST ( G(SSNHI,GO) I G(SSNTST,GO) ). It is also appropriate to specify a minimum value of effective sunspot number which will be returned by the subroutine. This value has arbitrarily been set to SSNLO=-27.31, a sunspot number which happens to result in a value for G(SSN,GO) which is independent of GO: for SSN= -27.31 and any value of GO, G = 3.294. (There is no objection to a negative value of effective SSN, since the effective SSN is not a physical reality, but simply a parameter by which MUFs are calculated.) This minimum value of effective sunspot number should be low enough to provide an adequate range in effective sunspot number even under extreme solar conditions, and there is no possibility of the effective flux being so low that the quantity 6 + [.814 SSN + 22.23] SQRT(GO) in Equation (1) would become negative, resulting in an imaginary value for G.

14

The minimum sunspot number SSNLO corresponds to a lower MUF limit, called CHUFLO, which can be calculated from Equation 1: CMUFLO CMUFTST G(SSNLO,GO) G(SSNTST,GO) G (-27.31,GO) G(100,GO) 3.294 G(100,GO)

The factor G(100,GO) is calculated from Equation 1 and the value GO returned when calculating CMUFTST:
G(100,GO) = 1.146 * SQRT(6.0 + 103.6*SQRT(GO)).

When calculating an effective flux corresponding to the value OBSMUF, first the value SSNHI (the SSN value which gives the maximum MUF, called CMUFHI) is calculated. In the (unusual) case that SSNHI =< -27.31, there is no meaningful range of SSN over which MINIMUF yields a monitonically-increasing MUF value, and it is not possible to determine an effective flux for the value OBSMUF. In this case the subroutine returns a value SSNEFF = -100.0, in response to which Subroutine EINMUF rejects Updating for this MUF determination and proceeds to the next method. If SSNHI > -27.31, then Updating can be used for sunspot numbers in the range -27.31 < SSN -< SSNHI, corresponding to MUF values in the range
CMUFLO < MUF <= CMUFHI. If OBSMUF >- CMUFHI, then Subroutine EFFSSN returns an

effective sunspot number EFFSSN - SSNHI. If OBSMUF <- -27.31, then Subroutine EFFSSN returns an effective sunspot number EFFSSN= SSNHI. Assuming that the measured value OBSMUF is within the range [MUFLO,MUFHI] (the usual case), then SSNEFF is calculated according to the following procedure: Using the substitutions
A - 1.3022 B = -0.00156 C = 6.0 D = 0.814 E = 22.23 F - SQRT(GO) G = (A + B SSNTST) ((SQRT(C + DF SSNLO + EF)) R H = C + EF

A1 - (B2H + 2 ABDF)/(B 2 DF)


A 2 = (2 ABH + A 2 DF)/(B 2 DF) A 3 = (A2 H - G2 )I(B2 DF)

equation (2) takes the form


SSNEFF 3 + A1 SSNEFF 2 + A2 SSNEFF + A 3 = 0,

15

which is simply a cubic equation to be solved for SSNEFF. An efficient computer solution to this equation may be sound in standard texts. (For example, see W. H. Press, et al., 1986). The number of roots to the cubic equation is determined from the quantities
Q - (A1 2 - 3 A2 ) / 9 R = (2 A 1 3
-

9 A1 A 2 + 27 A 3 ) / 54

If Q3 - R2 >=0, then there are three real roots; T = ARCCOS (R / SQRT(Q 3 ) ), they are
X1 = -2 SQRT(Q) COS( (T/3) - AI/3 X2 = -2 SQRT(Q) COS( (T+2 PI)/3 ) - AI/3 X3 = -2 SQRT(Q) COS( (T+4 PI)/3 ) - AI/3. If Y = R 2
-

in terms of the quantity

Q3

0, then there is only one real root, given by

X 4 = -SGN(R) [Y + Q/Y] - AI/3,

where
Y = SQRT(R 2 _ Q 3 ) +

1R1 1 /3 .

Because the function G(SSN,GO) is continuous and monotonic within the interval SSN - (-27.31, SSNHI), the proper solution to the cubic equation, in the case where there are three real solutions, can be determined simply by looking for a solution lying inside the interval (-27.31, SSNHI). In all situations so far investigated, solution X1 has yielded the appropriate solution.

B. SUBROUTINE DHOUR, a subroutine for decomposing the day-time group DTG This subroutine decodes information from the character string DTG (example: 251200ZDEC89) into the following quantities required in EINMUF:
MONTH: MYEAR: An integer representing the month. 1 -< MONTH =< 12 0 =< MYEAR =< 184

An integer representing the year minus 1900.

MDOY:

An integer representing the day of year.

1 =< MDOY =< 366

16

MDAY: MHOUR:

An integer representing the day of month.

1 =< MDAY =< 31

An integer representing the integral number of hours.


0 =< MHOUR =< 23

FHOUR:

A floating-point number representing the hour. 0.0 =< FHOUR < 24.0

REFHOUR: A floating-point number representing the number of hours elapsed since 010000ZJAN85. Any legitimate DTG between 1 January 1985 and 31 December 2084 may be decoded with DHOUR. Years-characters (characters 11-12) between 85 and 99 are assumed to correspond to the years between 1985 and 1999, and yield values MYEAR=85 to 99. Years-characters between 00 and 84 are assumed to correspond to the years 2000-2084, and yield values MYEAR=100 to 184. Subroutine DHOUR contains tests to verify that the DTG passed to it ;is legitimate. If any of these tests fails, the returned valued of REFHOUR is -1. The following tests are performed: a. DTG must be a string of 12 characters; b. Character 7 must be an upper or lower case 'Z';

c. Characters 8-10 must correspond to one of the months JAN, FEB, ... DEC. Any combination of upper and lower case letters is permissible. d. Each of the characters 1-6 and 11-12 must be one of the integers 0,l.... 9. e. Characters 1-2 must evaluate to a number between 1 and the number of days in the month defined by characters 8-10. (Leap year is taken into account.) Characters 3-4 must evaluate to a number between 0 and 23. Characters 5-6 must evaluate to a number between 0 and 59.

C. SUBROUTINE INCDTG, a subroutine for incrementing the day-time group DTG by one hour Subroutine EINMUF is typically called with a request for a number of MUF values for a series of times separated by one hour, with the first time specified by the day-time group DTG. Since the MUF-calculating routine requires a DTG for each MUF request, the subroutine INCDTG is useful for calculating a series of DTGs, each of which corresponds to a time exactly one hour later than the previous DTG. This seemingly simple process is complicated by the possible change in day, month, or year when moving one hour ahead. An additional complication is involved in accounting for leap years.

17

D. SUBROUTINE NISHLINC and DATA FILE NISHDAT.DAT, a subprogram and data file to provide acce-i to McNish-Lincoln sunspot number predictions, and Program NISHDAT.FOR, a program for generating the data file NISHDAT.FOR Forecasts of SSN produced by the McNish-Lincoln method are published monthly in Solar-Geophysical Data Prompt Reports Part I. Current predictions are stored in a data file NISHDAT.DAT; changes can thus be made as they become available, without having to recompile the entire EINMUF (and FAS-HF) routines. To make generation of the data file NISHDAT.DAT as consistant and reliable as possible, the program NISHDAT.FOR is provided. After program NISHDAT.FOR is edited to include new data, a new NISHDAT.DAT file is generated by running NISHDAT.FOR. The information required for editing NISHDAT.FOR is: (a) the predicted monthly SSN values, assumed to refer to a consecutive series of months; (b) the number of months for which predictions are provided; and (c) the month and year of the first prediction.

E. SUBROUTINEMEANSSN, a subroutine for estimating the sunspot number based on the mean 11-year sunspot cycle. The monthly mean sunspot numbers for the average solar cycle of 133 mcnths are contained in the 133-element array SMEAN(0:132). Taking Sept 1986 as the start of cycle 22, sunspot numbers are assigned as follows:

Month, Year Sept Oct Jan Jan Sept Oct Oct Nov 1986 1986 1987 1988 1997 1997 2008 2008

SSN SMEAN(O) SHEAN(1) SMEAN(4) SMEAN(16) SMEAN(132) SMEAN(O) SMEAN(132) SMEAN(O)

18

In subroutine MEANSSN the variable FMUNCE is set to the number of months since Sept 1986, modulo 133, and the corresponding sunspot number, SSN = SMEAN(FMUNCE), is returned. Since sunspot numbers currently (September 1989) are running about twice as high as the mean values, the MEANSSN values returned for months during the remainder of cycle 22 (through September 1997) are multiplied by a factor of 2.0 to make them more realistic.

F. FUNCTION AVSSN and DATA FILE SSNFILE.DAT The purpose of Function AVSSN(DTG,DTG2,SSN2) is to return a sunspot number AVSSN which is the running average of sunspot numbers for the (up to) five consecutive days ending with the day of DTG. To store data for previous days, Function AVSSN maintains a data file SSNFILE.DAT, to which new data is added with each call to AVSSN. The five-day running average is used to provide a smoothed sunspot number which will exhibit fluctuations in amplitude lower than those typical of the daily sunspot number values. While it is generally recognized that use of a smoothed sunspot number is appropriate in frequency-management applications, there is no definitive information on the best averaging time, although it is typically taken to be three to five days. The value used in AVSSN is five days. A different averaging time may be selected by changing the variable NUMDAYS, which is the number of consecutive days immediately preceding DTG2 which will be included in the average. Thus the three-day and five-day averages correspond, respectively, to NUMDAYS values of 2 and 4. The data file SSNFILE.DAT contains a list of up to thirty DTG2,SSN2 pairs, each pair representing a measurement SSN2 at A time DTG2. Whenever AVSSN is called, the values DTG2,SSN2 are added to file SSNFILE.DAT (assuming SSN2 is not equal to -300). Only one DTG2,SSN2 pair is stored for any given day. If AVSSN is called with a DTG2 corresponding to a day for which data already exists in SSNFILE.DAT, then the new DTG2,SSN2 is assumed to represent more accurate data and is stored in SSNFILE.DAT in place of the existing data for that day. If SSNFILE.DAT is already filled with thirty SSN2 vaiues when AVSSN is called, the data corresponding to the oldest DTG2 is removed, and the new DTG2,SSN2 added in its place. The size of data file SSNFILE.DAT is limited to thirty DTG2,SSN2 pairs so that is should be able to handle any anticipated operation, yet not grow endlessly with continued use. In calling AVSSN, the value SSN2=-300 is used as a signal that no measured sunspot number is available, and that no change is to be made in SSNFILE.DAT. (The value SSN2=0 is not used for this purpose because it is a legitimate sunspot number value.) Caution should be taken that AVSSN is not called with an undefined value for SSN2, because a zero value will most likely be passed to AVSSN, and that value will be stored in SSNFILE.DAT. The five-day running average is determined by whatever sunspot number values exist in file SSNFILE.DAT for the day DTG2 and the four previous days (but there must be at

19

least one entry). This could result in the use of a single SSN measurement entered four days before the day of DTG2. If the data file is empty and AVSSN is called with SSN2=-300, the value AVSSN=-300 will be returned. A call to AVSSN requires that the file SSNFILE.DAT be searched for the presence of data for DTGs corresponding to one to four days previous to the day of DTG2. This is facilitated by calculating a reference-day value (REFDAY) for DTG2, which is the number of days between 01 Jan 1985 and the day of DTG2. Similar values REFD(K) are calculated for each DTG in SSNFILE.DAT.

20

REFERENCES 1. M. Daehler: An HF Communications Frequency-Management Procedure for Forecasting the Frequency of Optimum Transmission. NRL Memorandum Report 5506, 31 December 1984. 2. J. M. Goodman, M. Daehler, M. H. Reilly, and A. J. Martin: A Commentary on the Utilization of Real-Time Channel Evaluation Systems in HF Spectrum Management. NRL Memorandum Report 5454, 28 November 1984. 3. A. G. McNish and J. V. Lincoln: Prediction of Sunspot Numbers. Transactions, American Geophysical Union, Volume 30, Number 5, pp. 673-685, October 1949. 4. W. H. Press, B. P. Flannery, S. A. Teukolsky, and W. T. Vetterling, Numerical Recipes: The Art of Scientific Computing, Cambridge University Press, p. 146, 1986. 5. Michael H. Reilly and Mark Daehler: Sounder updates for Statistical Model Predictions of Maximum Usable Frequencies on HF Sky Wave Paths. Radio Science, Volume 21, Number 6, Pages 1001-1008, November-December 1986. 6. D. B. Sailors and W. K. Moision: Quiet time lowest observable frequency model uncertainty assessment, NOSC Technical Report TR 1187, August 1987 7. D. B. Sailors, R. A. Sprague, and W. H. Rix: MINIMUF-85: An Improved HF MUF Prediction Algorithm: NOSC Technical Report TR 1121, July 1986. 8. F. G. Stewart and M. Leftin: Relationship between Ottawa 10.7-cm Solar Radio Noise Flux and Zurich Sunspot Number, Telecommunications Journal, Volume 39, pages 159-169, 1972.

21

Program Listings
A C C C C C C C C C C C SUBROUTINE EIINMUF(LTTLTONG.RLATRLONGDTG.NUMHRS.CMFLUX.SSNIN. DTG2. LUF.FOT,MUF.HOUR.METHOD.ERRCOD) THIS SUBROUTINE CALCULATES THE MUF WITH THE NOSC MINIMUF 85 PROGRAM USING A SOLAR FLUX INDEX (SUNSPOT NUMBER OR 10.7 CM FLUX) DETERMINED BY THE FIRST AVAILABLE METHOD IN THE FOLLOWING LIST: 1) EFFECTIVE SSN DETERMINED FROM RECENT MOF MEASUREMENTS ON A NEARBY SOUNDED PATH; 2) CURRENT REPORTED 10.7 CM FLUX; 3) CURRENT REPORTED SSN; 4) MCNISH-LINCOLN PREDICTED SSN; 5) ESTIMATE OF SSN FROM MEAN SUNSPOT CYCLE RECORDS. REAL LUF(24),FOT(24),MUF(24).UPHOUR(96),CPNT(8),UPMUF(96) INTEGER HOUR(24) .ERRCOD CHARACTER-12 DTG,PDTG,UPDTG,DTG2,OLDPDTG,AVUPDTGMETHOD(24)-1 COMMvON /UPMOF/ UPMOF(96.3),UPDTG(96,3) COMMON /GEOD/ CPNT DATA DTR/O.017453293/, RTD/57.2957795/ ERRCOD-0 SSN=SSN IN Diagnostics are outputted when EII'LUF Is called with MUF(1)=-100.O S ING-O .0 IF (MUF(1) .EQ. -100.0) SING-1.0 If (CMFLUX .NE. 0.0) set SSN2 - sunspot number equivalent of CMFLUX; else set SSN2--300. else If (SSN .NE. -300) set SSN2 - SSN; SSN2-SSN IF (CMFLUX .NE. 0.0)SSN2-561.8-(SQRT(O.303+O.OO356*CMFLUX)-0.728) Make sure DTG2 Is a legitimate day-time group CALL DHOUR(DTG2 ,MYEAR,MDOY,MONTH,MDAY.MHOUR, FHOUR,REFHOUR) IF(REFHOUR .EQ. -1.0) SSN2--300.O Call Function AVSSN to store DTG2,SSN2 (if SSN2 .NE. -300) In file SSNFILE.DAT, and calculate the average of sunspot numbers for days of DTG and the four previous days. If there Is no data for this 5-day perlod, the result AVSSN = -300 Is returned. Replace original SSN value with AVSSN for use In EIr'1VUF. TYPE*,' SSN-',SSN,' DTG-',DTG,' DTG2-',DTG2,' SSN2-',SSN2 SSN=AVSSN(DTG, DTG2 , 5N2) TYPE*.' SSN-',SSN,* DTG=' .DTG,' DTG2= *DTG2.* SSN2-' ,SSN2 CALL DHOUR(DTG.MYEAR,MDOY,MONTH.MDAY .MHOUR ,FHOUR ,REFHOUR) DIG Is Illegal (REFHOUR=-1), RETURN with error message IF (REFHOUR .EQ. -1.0) THEN DO 90 K=I .NUM~HRS LUF(K).0. FOT(K)-0.O 90 MUF(K)-0.O ERRCOD- 1 GOTO 2000 END IF Set up the HOURs for which MUFs are requested. DO 100 K=1,NUM~HRS HOUR(K)-MHOUR-1+K IF (HOUR(K) .GT. 23) HOUR(K)-HOUR(K)-24 100 CONTINUE PDTG-present DTG-DTG of 1st MUF request PDTG-DTG If

C C C C C C C C C C C C C C C C C C

C C C C C

Diagnostics are outputted when EINMUF is called with MUF(1)=-100.O IF (SING .NE. 1.0) GOTO 105 DO 15 K=1,96 IF (UPDTG(K,1) .LE. ')GOTO 17 CALL DHOUR(UPDTG(K,1) .MYEAR.MDOY,MONTH,MDAYMHOUR,FHOUR,

23

A UPHOUR(K)) 15 TYPE 16, K.UPDTG(K,1),UPHOUR(K).UPMOF(K.1) UPHOUR-' ,F9.3,' UPDTG-',A12,' 16 FORMAT(' K-' .12.' F6.2) A 17 TYPE*.' NUM~UPS- *K-1 C C C

UPMOF-'

C C C C C C

Foillowing starts DO loop for the NLRMHRS required MUFs


105 DO 1000 K=1,NUMHRS

Determine PDTG for this MUF request (if not the first one) IF(K .GT. 1) CALL iNCDTG(OLDPDTG,PDTG) OLDPOTG=PDTG

Start Updating procedure Muit. updating MOFs by .75 to make them comparable with MINiMUF MUFs Determine reference hour (UPHOUR) for each updating datum DO 110 LK=1,96 IF (UPDTG(LK,1).LE.' ) GOTO III CALL DHOUR(UPDTG(LK, 1) .MYEAR,MDOY,MONTH,MDAY,MHOUR .FHOUR A ,UPHOUR(LK)) C 110 UPMUF(LK)-0.75*UPMOF(LK,1) 110 UPMUF(LK)-UPMOF(LK,1) C FACTOR OF 0.75 REMOVED 15 FEB 90, BY MD. 111 NUMdUPS-LK-1 C C If directed by METHOD value, start with requested method IF (METHOD(K) .EQ. Win) GOTO 301 IF (METHOD(K) .EQ. 'c') GOTO 401 IF (METHOD(K) .EQ. 's') GOTO 501 IF (METHOD(K) .EQ. 'I-) GOTO 601 IF (METHOD(K) .EQ. 'e') GOTO 701 IF (METHOD(K) .EQ. 'q') GOTO 550 C 301 IF (NUMUPS .EQ. 0) GOTO 401 C Search for acceptable Updating data CALL DHOUR(PDTG,MYEAR,MDOY,MONTH,MDAY,MHOURFHOUR,PDHR) AVUPMUF=0 .0 TIMED IF=0 .0 NPTS=0 DO 220 L1-1,NLNAUPS C Ignore update value If update time comes before time of requested MUF C To permit Updating with UPMOF measurements made AFTER the time for C which the MUF Is being predicted, remove statement 205. 205 IF (PDHR-UPHOUR(Ll) .LT. 0.0) GOTO 220 C Sum measured MUF and time values If time Is within limits C NPTS Is number of data points which meet specs IF (PDHR-UPHOUR(L1) .GT. 2.1) GOTO 230
AVUPMUF-AVUPMUF+UPMUF (Li) TIMEOIF-TIMEDIF+PDHR-UPHOUR(Ll)

220 230

240
250

260 270

NPTS-NPTS. 1 CONTINUE CONTINUE IF (NPTS .GE. 1) GOTO 399 DO 240 L2=L1 .NUMUPS IF (PDHR-UPHOUR(L2) .GT. 3.1) GOTO 250 AVUPMUF-AVUPMUF+UPMUF (L2) TIMED IF-TIMED IF+PDHR-UPHOUR( L2) NPTS-NPTS+1 GOTO 399 IF (NPTS .GE. 1) GOTO 399 DO 260 L3-L2,NUMUPS IF (PDHR-UPHOUR(L3) .GT. 4.1) GOTO 270 AVUPMUF-AVUPMUF+UPMUF (L3) T IMEDI F=TIMEDI F+PDHR-UPHOUR(L3) NPTS-NPTS+1 GOTO 399 IF(NPTS .GE. 1) GOTO 399 DO 280 L4.=L3,NUMUPS IF (PDHR-UPHOUR(L4) .GT. 5.1) GOTO 290

24

280 290

300 310

320 330

375 C C C

AVUPMUF-AVUPMUF.UPMUF (L4) T IMEDI F-TIMEDIF+PDHR-UPHOUR(L4) NPTS-NPTS+1 GOTO 399 IF (NPTS .GE. 1) GOTO 399 DO 300 L5-L4.NUMUPS IF (PDHR-UPHOUR(L5) .GT. 6.1) GOTO 310 AVUPMUF-AVUPMUF+UPMUF (L5) TIMEDIF=TIMEDIF+PDHR-UPHOUR(L5) NPTS=NPTS+1 GOTO 3e9 IF (NPTS .GE. 1) GOTO 399 DO 320 L6-L5,NUMUPS IF (PDHR-UPHOUR(L6) .GT. 7.1) GOTO 330 AVUPMUF-AVUPMUF.UPMUF (L6) TIMEDiF-TIMEDIF+PDHR-UPHOUR(L6) NPTS-NPTS+1 GOTO 399 IF (NPTS .GE. 1) GOTO 399 DO 375 L7-L6,NUMUPS IF (PDHR-UPHOUR(L7) .GT. 25.1) GOTO 375 IF (PDHR-UPHOUR(L7) .LT. 18.9) GOTO 375 AVUPMUF-AVUPMUF+UPMUF (L7) TIMED IF-TIMED IF+PDHR-UPHOUR(L7) NPTS-NPTS. 1 CONTINUE IF (NPTS .EQ. 0) GOTO 401

UPDATING CRITERIA MET. CALCULATE UPDATED MUF 399 AVUPMUF-AVUPMUF /NPTS AVUPHR-FHOUR-T IMED IF/NPTS DO 289 KL=1,2 289 IF(AVUPHR .LT. 0.0) AVUPHR-AVUPHR+24.O IR-AVUPHR IM-(AVUPHR-I R)-60.O Note: AVUPDTG (-average DTG of Updating values) Is defined by the average HOUR of the updating values and the DAY for which the MUF Is being requested. This avoids the possibility of calculating the MUF In one month with an effective flux calculated for the previous month. AVUPDTG-PDTG(1:2)//CHAR(48.IR/10)//CHAR(48+IR-10*(lR/10)) A //CHAR(48.IM/10)//CHAR(48+IM-10*(IM/10))//PDTG(7:12) OBSMUF =AVUPMUF CALL EFFSSN(TLAT,TLONG,RLAT,RLONG,AVUPDTG.OBSMUF,SSNEFF) On return from EFFSSN, GZERO Is returned In OBSMUF, as diagnostic EFFGZERO=OBSMUF

C C C C C "

C C C

C
C Diagnostics are outputted when EINM~UF Is called with MUF(1)--100.0 IF (SING .NE. 1.0) GOTO 393 TYPE 371 .K,PDTG,PDHR,NPTSTIMEDIF/NPTS TYPE 372,* AVUPDTG ,AVUPMUF ,SSNEFF *EFFGZERO 371 FORMAT(' Km-,12,' PDTG=',A12,' PDHR-',F9.2.' NPTSm-,12. A .AVTIMEDIF-',F6.3) 372 FORMAT(' AVUPDTG-',Al2,' AVUPMUF-'.F8.4.' SSNEFF-*.F9.3, A .GO-*,F12.9) 393 CONTINUE

C C C

If effective SSN couldn't be calculated, don't Update IF(SSNEFF .EQ. -100.0) THEN ERRCOO- 2 GOTO 401 END IF CALL MUFB5MD(TLAT,TLONG,RLAT,RLONG,PDTG,SSNEFF,MUF(K) ,GZERO) METHOD(K)_'M'

25

GOTO 900 391 C C DETERMINE MUF FROM CURRENT REPORTED 10.7-CM FLUX 401 IF (CMFLUX .EQ. 0.0) GOTO 501 SSN-561 .8*(SQRT(O.3O3+O.O0356*CMFLUX)-O.728) IF (SSN .GT. 250) SSN-250 IF (SSN .LT. -27.31) SSN--27.31 CALL MUFB5MD(TLAT.TLONG.RLAT.RLONGPDTG.SSN.MUF(K) ,GZERO) METHOD(K)-'C' GOTO 900 C C DETERMINE MUF FROM CURRENT REPORTED SSN Diagnostic outputted when EI!NMUF Is called with MUF(1)--100.0 C 501 IF (NPTS .EQ. 0 .AND. SING .EQ. 1.0) TYPE 379,KSSN.PDTG 'SSN--, F8.3,' PDTG-',Al2) 379 FORMAT( -K-',12, IF (SSN .EQ. -300.0) GOTO 550 IF (SSN .GT. 250.0) SSN=250.0 IF (SSN .LT. -27.31) SSN--27.31 CALL MUF85MD(TLAT,TLONGRLAT,RLONG.PDTG,SSNMUF(K) ,GZERO) METHOD(K)= S' GOTO 900 C C MUF determinations from Updating, CMFLUX, and SSN methods have Now try Updating using any sounder data C been unsuccessful. Each UPMUF vaiue will be used to C whatsoever from array UPMUF. C calculate and effective SSN, and the average of these SSNs will used in a call to MINIMUF to calculate the MUF C 550 IF(NMvUPS .EQ. 0) GOTO 601 AVSSNEFF=O .0 DO 560 JK=1,NUMUPS CALL EFFSSN(TLAT,TLONG,RLAT,RLONG.UPDTG(JK. 1) ,UPMUF(JK) ,SSNEFF) AVSSNEFF-AVSSNEFF+SSNEFF 560 AVSSNEFF-AVSSNEFF /NUMUPS If effective SSN couldn't be calculated, don't Update C iF(AVSSNEFF .EQ. -100.0) GOTO 601 CALL MUF85MD(TLAT.*TLONG, RLAT. RLONG, PDTG, AVSSNEFF ,MUF(K) ,GZERO) METHOD(K)-Q' GOTO 900 C C DETERMINE MUF FROM MCNISH-LINCOLN PREDICTED SSN 601 CALL NISHLINC(PDTG,SSN,KERR) IF (KERR .NE. 0) GOTO 701 CALL MUF85MD(TLAT,TLONGRLAT,RLONG,PDTG,SSN,MUF(K) ,GZERO) METHOD(K)- L' GOTO 900 C C DETERMINE MUF FROM MEAN SUNSPOT CYCLE SSN VALUES 701 CALL MEANSSN( MONTH, MYEAR, SSNMLN) CALL MUF85MD(TLAT.TLONG,RLATRLONG,PDTG,SSNMLN,MUF(K) ,GZERO) METHOD(K)a.'E' GOTO 900 C C DETERMINE LUF AND FOT 900 CALL OLOF(CPNT,PDTG,LUF(K)) LUF(K)-AMiN1 (LUF(K) .48.0) LUF(K)-AMAX1 (LUF(K),1.5) FOT(K)=0.85*MUF(K) 1000 CONTINUE 2000 RETURN END C C C C C SUBROUTINE EFFSSN(TLAT,TLONG.RLAT,RLONG.DTG,OBSMUF,SSNEFF) THIS SUBROUTINE CALCULATES THE EFFECTIVE SUNSPOT NUMiBER SSNEFF C C WHICH CORRESPONDS TO THE MEASURED MUF VALUE OBSMUF C INTEGER ITIME(6)

26

CHARACTER*36 MONS, MNS"9, DTG-12 REAL CMUFTST ,GZERO ,CPNT( 8) DATA A/i .3022/,B/-0.00156/,C/6.0/.D/0.814/,E/22.23/, A MN$/' 123456789'/I,MONS/'JANFEBMARAPRMAYJUNJULAUGSEPOCTNOVDEC' I, P1/3.1415926536/ B SSNTST= 100.0 CALL MUF85MD(TLAT.TLONG,RLATRLONG.DTG,SSNTST,CMUFTST.GZERO) F-SORT (GZERO) H-C+E*F RAT IO-OBSMUF /CMUFTST

GG-( A+B* SSNTST ) *SORT (C+( 0 SSNT ST+E )*


G=RAT I0GG CMUFL0= (3
.294*CMUFTST)

/GG

C C C

Calculate maximum SSN and MUF allowed by MINIMUF85 for this path SSNHI =260.0415-4 .914/SORT(GZERO) CMUFHI=CMUFTST*(A+B*SSNHI )*(SORT(C+(D*SSNH+E)SQRT(GZER0)))/GG SSNEFF can't be calculated If SSNHI<c--27.31 IF (SSNHI .LE. -27.31) THEN SSNEFF-- 100.0 GOTO 100 END IF

C C

Limit SSNEFF to the range E-27.3l.SSNHIJ IF (OBSMUF.GE.CMUFHI) THEN SSNEFF-SSNH I GO TO 100 ELSE IF (OBSMUF .LE. CMUFLO)THEN SSNEFF--27 .31 GO TO 100 END IF C Solve cubic equation for SSNEFF Al=H/(F*D)+2 .0*A/B A2-(2.O*A*H) /(BDF)+(A*A)/(B*B) A3-(A*A*H-G*G) / (*B*D*F) Q=(Al*Al-3.0*A2) /9.0 RRr2.0*(A/54.0)*Al*Al-9.0*Al*(A2/54.0)+27.0*(A3/54.0) IF (00QOOOO-RRRR.GE. 0.0) THEN NLUIVROOTS-3 THETA-ACOS(RR/( (SORT(00))**3 01 E-SORT(OQ) Xlm-2.0QIECOS(THETA/3.0)-A1/3.0 X2--2.0*QIECOS((THETA+2.0Pl)/3.0)-Al/3.0 X3--2.0*QlE*C0S((THETA.4.0*Pl)/3.0)-Al/3.0 ELSE NLIVIROOTS- 1 Xl=(SORT(RR*RR-OOQ*OO*)+ABS(RR))**(1.0/3.0) A .e.O/(SRT(RRRR-0000*00)+ABS(RR))**(1.0/3.0) X1WSIGN( 1.0,RR)*X1-A1/3.0 END IF SSNEFF=X 1 C GZERO value Is returned In variable OBSMUF (a diagnostic) 100 OBSMUF-GZERO RETURN END C C C SUBROUTINE N ISHL INC(DTG,SSNKERR) C This subroutine accepts day-time group DTG and returns a sunspot C number prediction for the month and year corresponding to DTG as C extrapolated from recent data by the McNISH-Lincoin method. C Data are taken from the file NISHDAT.DAT. If file NISHDAT.DAT C doesn't contain an entry for the spcif led DTG, the value c SSN--999.0 Is returned. C CHARACTER* 12, DTG ,MN$-36 INTEGER PRED( 100) .DAT1MONTH,DATlYEAR.NLt4vONTHS OPEN(UNIT-1,FILE-'NISHDAT.DAT' ,STATUS='OLD') READ( 1 200)NUMMONTHS.DATlM0NTH.DATIYEAR

27

200 FORMVAT( 1015) KERR =0

C C

READ (l1,200 ) (PRED(J) ,J-1, NLUMMONTHS) CLOSE(UNIT-1) DATA MNS/' 123456789*/ CALL DHOUR(DTGMYEAR,MDOY,MONTH,MDAY,MHOUR,FHOUR,REFH0UR) YEAR-1O*INDEX (MNS ,DTG( 11: 11) )+ INDEX (MN$,DTG( 12: 12) )+1900 IF (YEAR .LT. 1985) YEAR=YEAR+100 MONTHDIFF= time Interval In months between 1st data month and month for which SSN is required. MONTHDIFF=12*(YEAR-DATlYEAR)+MONTH-DATlMONTH IF(MONTHDIFF .LT. 0.0 .OR. MONTHOIFF .GT. NLUMMO NTHS-1) THEN KERR-2 ELSE SSN-PRED(MONTHDIFF+1)
END IF

RETURN END C C C SUBROUTINE DHOUR(DTG,MYEAR,MDOY,MONTH,MDAY,MHOUR,FHOUR,REFHOUR) C


C C C

INPUT:

DTG (EXAMPLE: 251200ZDEC89).

RETURNS MYEAR (-YEAR-1900),

MDOY (-DAY OF YEAR), MONTH. MDAY(_DAY OF MONTH), MHOUR (_ INTEGRAL PART OF HOUR). FHOUR(HOUR, INCLUDING DECIMAL PORTION), AND REFHOUR(- * OF HOURS SINCE OI0000ZJAN85)

C CHARACTER-12 DTG, MONS*36,NS*10


INTEGER IDYS(13)

C C
C

IDVS(MONTH)-number of days In current year preceding the first day of MONTH, assuming no leap year DATA IDYS/0,31 .59,90,120,151,181,212,243,273,304,334,365/,
A N$/'0123456789'/, MONS/ 'JANFEBMARAPRMAYJUNJULAUGSEPOCTNOVDEC'/ A return with REFHOUR=-- means an Illegal DTG was found REFHOUR--1.0

C C

DTG must have 12 characters IF (LEN(DTG) .NE. 12) GOTO 100 Change alpha characters to upper case DO 10 K-7,10 IF(ICHAR(DTG(K:K)) .GT. 90) DTG-DTG(1:K-1)// A CHAR(ICHAR(DTG(K:K))-32)//DTG(K+1:12) 10 CONTINUE Make sure 1st 6 and last 2 characters are digits, 0-9 DO 20 K-1,6
20 IF (INDEX(NSDTG(K:K)) .EQ. 0) GOTO 100

C C

DO 30 K-11,12 30 IF (INDEX(NSDTG(K:K)) .EQ. 0) GOTO 100 End of check for legal DTG MONTHa,(INDEX(MONS,DTG(8:10))+2)/3 MDAY_ 1O*( INDEX(N$,DTG(1 :1))-1)+INDEX(NS,DTG(2:2))-1 MDOY IDYS (MONTH) +MDAY MHOUR..l0m (INDEX(N$,DTG(3:3))-1)+INDEX(NS,DTG(4:4))-1 MIN10( INDEX(NS,DTG(5:5))-1).iNDEX(N$,DTG(6:6))-1 FHOUR=MHOUR+M IN/60 .0 MYEAR-1*(INDEX(N,DTG(11:11))-1)+INDEX(N$,DTG(12:12))-1 MYEAR.LT.85 _> year Is between 2000 and 2084 IF(MYEAR .LT .85) MYEAR-MYEAR. 100 Count * of leap hours since OIOOOOZJAN85 LEAPHRS-24*( (MYEAR-85)/4) DAYSINMIDYS(MNTH+1 )-IDYS(MONTH) IF(MYEAR-4*(MYEAR/4) .EQ. 0.) THEN IF(MONTH .GE. 3) MDOY-MDOY+1
IF(MONTH IF(MONTH END IF .GE. 3) LEAPHRS-LEAPHRS+24 .EQ. 2) DAYSINMtv-29

Declare DTG Illegal If mins, hours, or days are unreal IF (MIN .GT. 59 .OR. FHOUR .GE. 24.0 .OR. MDAY .GT. DAYSI'IM A .OR. DTG(7:7) .NE. 'Z') GOTO 100 REFHOUR=8760-(MYEAR-85)+24*( IDYS(MONTH)+MDAY-1 ).FHOUR+LEAPHRS

28

100

RETURN
END

C C C SUBROUTINE C C INCDTG(DTG1 .DTG2) Input: DTG1. Returns DTG2, which Is 1 hour later than DTG1. CHARACTER*12 DTG1 ,DTG2,MN$*9,MON$*36 INTEGER MDYS(12) DATA MNS/' 123456789'/,MDYS/31,28,31,3O,31,3O,31 .31,30,31.30.31/, A MONS/ JANFEBMARAPRMAYJUNJULAUGSEPOCTNOVDEC'/ MHOUR- 10t INDEX (MNS ,DTG1(3:3) )+ INDEX (MN , DTG1(4 :4))+ MDYS(2 )-28 IF (MHOUR .EQ. 24) THEN MHOUR -O MDAY-1Ot INDEX(MNS,DTG1( 1:1) )+INDEX(MNS.DTG1(2:2) ),1 MYEAR-l1t INDEX (MN , DTG1( 11: 11) )+ INDEX (MNS *DTG 1( 12: 12)) MONTH=(INDEX(MONS,DTG1(8:1O))+2)/3 IF (MYEAR-4*(MYEAR/4) .EQ. 0) MDYS(2)u.29 IF (MDAV .GT. MDVS(MONTH)) THEN MDAY-1 MONTH=MONTH+ 1 IF (MONTH .EQ. 13) THEN MONTH-i MVEAR-MYEAR+ I IF (MYEAR .EQ. 100) MYEAR-O END IF END IF DTG2-CHAR(48.MDAY/1O)//CHAR(48.MDAY-1O*(MDAY/1O)) A //CHAR(48+MHOUR/10)//CHAR(48+MHOUR-10*(MHOUR/10)) B //DTG1 (5:7)//MON$(3*MONTH-2:3*M0NTH) C //CHAR(48+MYEAR/1O)//CHAR(48+MYEAR-10*(MYEAR/10)) ELSE DTG2-DTG1 (1 :2)//CHAR(48+MFIOUR/10)//CHAR(48+MHOUR-10* A (MHOUR/10))//DTG1(5:12) END IF RETURN END

C C C C C C C C C C SUBROUTINE MEANSSN(MONTH,MYEAR ,SSN) Accepts MONTH (.1 to 12) and MYEAR (-YEAR-1900). Returns SSN based on mean 11-year sunspot cycle with minimum on Sep 1986. Valid for months Sep 1986 through Dec 2085 (MONTH-9,MYEAR-86 through MONTHw12,MYEAR-185) DIMENSION SMEAN(O: 132) Array SMEAN contains the 133 SSN values for the 133-month cycle. Array values go from 0 to 132 to facilitate calculation of months since beginning of cycle mnodulo 133. DATA SMEAN /5.55.5.6,6.5,7,8,9,10,11,12,14,16,20,21,24,26.5,31, A 34,38,42,45,48,53 .5,57,60,63,67.5,70,74 .5,78,80,83.5,85.5,88,92, B 94,96.5,97.5,100,101, 102,103,103.5,104,104.5, 104.5,105,105, 105. C 104.5,104.5,104,104,103.5, 103,102,101.5,.100.5,99.5,98.5,98,97, D 96,95,93.91.5,89,87,85,83,81 ,78.5,76.74,70.5,68.5.66.5,65,62,60, E 59,56.5,55,53,52,51,.49,48,47.8,45,44,43,41.5,40,38,37,35.5,34, F 33,32,30.5,29.5,28.5,27,26,25,24,23.5,22.5,22,20.5,20,19,18, G 17.5,17,16,15.14,13.5,13,12.5,12,11,11.10,10.9.8,9.6.9.4,9.2,9/ FMONATS-3 .0+12.0*(MYEAR-87 .0)+MONTH SSN-0. 0 IF(FMONATS .LT. 0.0 .OR. FMONATS .GT. 1191.0) GOTO 100 FMUNCE=AMOD(FMONATS, 133.0) SSN-SMEAN (FMUNCE) SSNs In current cycle are running about twice the mean values IF(FMONATS .LE. 132) SSN-2.O*SSN 100 RETURN END

cc C

29

C FUNCT ION AVSSN(DTG,*DTG2 C C C C C C C C C C C C C C C


,SSN2)

This function manages a file SSNFILE.DAT which contains a list of up to 30 day-time groups DTGF(K) and corresponding sunspot numbers SSNF(K) (no more than one pair of vaiues per day) and returns a value which is the average of aii SSNFs for the day of DTG and NLLIDAYS Is typicaily either 2 or 4, the previous NUMDAYS days. corresponding respectiveiy to a "3-day average" or a "5-day average" When called. function AVSSN adds DTG2, SSN2 to file sunspot number. SSNFILE.DAT uniess SSN2_-300 (which Is a signal that DTG2, SSN2 are not valid data), or unless there are already 30 values stored In It Is assumed that SSNFILE.DAT with times more recent than DTG2. either DTG2. SSN2 represent a valid sounder measurement, or that SSN2---300.O. Function AVSSN calls subroutine DHOUR.
,DTGF (30) CHARACTER-*12 DTG ,DTG2 DIMENSION SSNF(30) INTEGER REFDAY, REFD2, REFD(30) NLAADAYS..4

C C

Read In SSN data from SSNFILE.DAT OPEN(UNIT-2,FILE-'SSNFILE.DAT' ,STATUS-'UNKNOWN') ((DTGF(J),SSNF(J)),J_1,30) READ(2,100,END=101) 100 FORMAT( 1X,A12,F8.3) 101 CONTINUE TYPE 120,(DTGF(KJ).KJ-1,30) C TYPE 121,(SSNF(KJ),KJ-1,30) C 120 FORMAT(1X,6A13) 121 FORMAT(1X.6F13.3) 150 NLUiMDTGS-J-1 IF (NUMDTGS .LT. 0) NUM~DTGS-0 C Establish REFDAY-number of days between 1 Jan 1985 and DTG C CALL DHOUR(DTG ,MYEAR ,MDOY ,MONTH ,MDAY ,MHOUR ,FHOUR,, REFHOUR) REFDAY-35(MYEAR-85 ) MDOY+ (MYEAR-85) /4 C Establish REFD(K)-number of days between 1 Jan 1985 and DTGF(K) DO 270 K-i ,NUMvDTGS CALL DHOUR(DTGF(K) ,MYEARMDOY,MONTH.MDAY,MHOUR,FHOUR,REFHOUR) REFD(K)..365*(MYEAR-85).MDOY+(MYEAR-85)/4 270 C If inputted SSN2,DTG2 aren't valid, don't enter them Into SSNFILE.DAT C IF (SSN2 .EQ. -300.0) GOTO 595 C C Since DTG2, SSN2 represent valid data, store them In SSNFILE.DAT C C Find reference day (REFD2) for OTG2 CALL DHOUR( DTG2 .MYEAR ,MDOY ,MONTH ,MDAY .MHOUR. FHOUR, REFHOUR) REFD2-365* (MYEAR-85 )+MDOY+ (MYEAR-85) /4 C C If data file was empty, It now will have one entry IF (NUMDTGS .EQ. 0) THEN DTGF( 1)-DTG2 SSNF( 1)-SSN2 REFD(l1)-REFD2 NLUMDTGS. 1 GOTO 500 END IF C C SSNFILE.DAT wasn't empty. C If SSNFILE.OAT already has a value for current day, change value to also change DTGF(K), C curent value, If different from earlier value; C since time of day might be different, even If day Is the same. DO 285 K-1,NLAdiDTGS IF (REFD2 ,EQ. REFD(K)) THEN SSNF(K)-SSN2 DTGF(K)-D1G2 REFD(K )-REFD2

30

GOTO 500 END IF 285 CONTINUE C C C C SSNFILE.DAT doesn't have an entry for the day of DTG2, SSN2

If SSNFILE.DAT isn't full, simply add new entry IF (NUMDTGS .LT. 30) THEN DTGF (NLRADTGS+ 1) =DTG2 SSNF (N~UMDTGS+ 1)-SSN2 REFD (NUM~DTGS+ 1)-REFD2 NUM~DTGS-NLUMDTGS+ 1 GOTO 500 END IF List was full; find oldest data and replace It with DTG2, SSN2 MINDAY-10000 DO 287 K-1.30 IF (MINDAY .GT. REFD(K)) THEN MI NDAYftREFD(K) KM IN-K END IF 287 CONTINUE DTGF (KM IN) -DTG2 SSNF(KIVIN) SSN2 REFD(KMIN)-REFD2 Rewrite SSN data to file SSNFILE.DAT 500 REWIND 2 WRITE(2.100) ((DTGF(J),SSNF(J)),J.1,NJADTGS) TYPE 120.(DTGF(KJ).KJ-1.30) TYPE 12I.(SSNF(KJ),KJ-l,3o) TYPE 122,(REFD(KJ),KJ-1,30) 122 FORMAT(1X, 1017) TYPE-.' REFDAY-',REFDAY,' REFD2-',REFD2,' 595 CONTINUE If there's no SSN data, RETURN an AVSSN--300.0 IF (NLJMDTGS .EQ. 0) GOTO 1000

C C

C C C C C C C C C C C C

NLUMDTGS-',NUMvDTGS

Invalid sunspot number

Calculate average of SSNs for which the respective DTGs are between zero and NUMVDAYS In advance of REFDAY, the reference day corresponding to DTG. SLl-0 .0 NPTSw0 DO 600 K-i ,NUMDTGS IF (REFDAY-REFD(K) .GE. 0 .AND. REFDAY-REFD(K) .LE. NUMDAYS) THEN SUM,-SLP1SSNF (K) NPTS-NPTS+ 1 END IF 600 CONTINUE IF (NPTS .EQ. 0) GOTO 1000 AVSSN-SUMv/NPTS
I

*C

1000 CLOSE(2,STATUSm*KEEP') C TYPE 1001,NLRVDTGSKMINDTGF(KMIN).MINDAY 1001 FORMAT(' NUMDTGS-',13,' KMIN-',13,' DTGF(KMIN)-',A12 A ' MINDAY-*,16) RETURN END C C C SUBROUTINE TRINTERP(TLAT .TLON,RLAT,RLON.DTG,UPM0F A .UPDTG,UPLAT,UPTLONUPRLAT.UPRLONTMUFTSSNEFF) C This subroutine C A) accepts Updating data UPMOF from three sounder paths; C B) calculates an effective solar 10.7-cm flux for each sounder

31

C C C C C C C C C C C A

midpath point; produces an Interpolated effective flux for the communications path (the center of which is assumed to I le Inside the triangle defined by the three sounder path midpoints); D) converts the effective flux to an effective sunspot number TSSNEFF for the communications path; E) Uses MINIMUF85 to calculate TMUF, the MUF on the communications path; F) RETURNs both TMUF and TSSNEFF. C) DIMENSION LMOF(3)UPTLAT(3),UPTLON(3),UPRLAT(3),UPRLON(3) ,SPATH(8),CPLAT(3),CPLON(3),FLUX(3) CHARACTER-12 DTG, UPDTG(3)

C C C

Calculate sounder path midpoints CPLAT, CPLON - latitude and west longitude of control path (I. e., sounder path) midpoints DO 120 J=1,3 CALL PATH(UPTLAT(J),UPTLON(J),UPRLAT(J),UPRLON(J),SPATH) CPLAT(J)=SPATH(2) CPLON(J)=SPATH(3) 120 CONTINUE Calculate effective 10.7-cm fluxes corresponding to sounder MUF measurements DO 130 J-1,3 CALL EFFSSN(UPTLAT(J),UPTLON(J),UPRLAT(J).UPRLON(J),UPDTG, A UMOF(J),SSNEFF) FLUX(J)-63.7+0.728*SSNEFF+8.gE-4*SSNEFF*SSNEFF 130 CONTINUE Calculate communications path midpoint CALL PATH(TLAT,TLON,RLAT,RLONSPATH) COMMLAT=SPATH(2) COMMLONSPATH(3) Calculate the 3 coefficients of the linear Interpolation formula B(FLUX(2)-FLUX(3))*(CPLAT(1)-CPLAT(2)) B-B-(FLUX(1)-FLUX(2))-(CPLAT(2)-CPLAT(3)) BDIV(CPLON(2)-CPLON(3))*(CPLAT(1)-CPLAT(2)) BDIV-BDIV-(CPLON(1)-CPLON(2))*(CPLAT(2)-CPLAT(3)) B-B/BDIV A-(FLUX(2)-FLUX(3)-B*(CPLON(2)-CPLON(3)))/(CPLAT(2)-CPLAT(3)) D=FLUX(1)-A*CPLAT(1)-B-CPLON(1) Calculate effective flux for the communications path midpoint, convert to an effective sunspot number EFFLUX-A*COMMLAT+BCOMMLON+D TEFFSSN-561.8*(SQRT(O.303+O.OO356*EFFLUX)-0.728) Calculate MUF for the communications path, uSING eff. sunspot CALL MUF85MD(TLAT,TLONRLATRLON.DTGTEFFSSNTMUF,GZERO) RETURN END and

C C C

C C

C C

C C C C C

number

C C

SUBROUTINE MUF85MD(TLATTLONRLAT,RLON,DTG,SSN,CMUF.GZERO) This Version written as a slightly-condensed Version of MUF85. INTEGER ITIME(6) REAL CPNT(8),K5.LO,LMT,K8,K9,M9.MLAT,SN(6),CN(6) CHARACTER*12,DTG COMMON /SUN/ SLATSLON COMMON /GEOD/ CPNT

C
DATA
*

DATA

PI/3.14159265/, TWOPI/6.2831853/, HALFPI/1.57079632/, DTR/O.017453293/. RTD/57.2957795/, RO/6371./ S8/250.0/. FMI/O.728/, FMS/0.52998/

32

*FM2/0.00356/.

FM3/63.75/, FM4/0.00178/

C CALL DHOUR(DTGMYEARMDOY.iTiME(1).ITIME(2),iTIME(3),HOURREFHOUR) ITIME(4)-6O.O*(HOUR-ITIME(3)) T5- HOUR CMUF - 100.0 YM - 100.0 C C A3 order Fourier expansion In terms of Month DO 500 N - 1.6 ARG.PI*FLOAT(2sJ)*iTIME( 1)/12.0 SN(N)=SIN(ARG) CN(N)-COS(ARG) 500 CONTINUE A3 - .9925+.Oll*SN(1)..087*CN(l)-.043*SN(2)+.003*CN(2)-.013*SN(3) -.O22*CN(3)..003*SN(4)..005*SN(5)+.018*CN(6) A
=6th

C C A1,A2 are iinear functions of SSN Al - .814*SSN.22.23 A2 - 1.3022-.00156*SSN C C *OF HOPS: 1 HOP FOR RANGE <m 4000 KM (.6278 RADIANS), 2 HOPS OTHERWISE CALL PATH (TLATTLON.RLAT,RLONCPNT) -' 01 - CPNT(1) AZiM -CPNT(8) AK6 -1.59*CPNT(l) IF (AK6 .LT. 1.0)AK6-1.0 K5 - 1.0/AK6 IF (K5 .NE. 1.0)K5-.5 KHOP -INT(CPNT(1)/.62784)+l KKHOP =KHOP IF (CPNT(1) .GT. 0.94174)KKHOP=2*KHOP-1 C C Loop through all hops DO 160 K1 - 1.KKHOP C C PL - Range (in radians) to Control Point (CP) C CP - Midpoint for 1-hop; 2000Km from each end for 2-hops IF (KHOP .EQ. 1)PL-G1/2.0 IF (KHOP .EQ. 2 .AND. K1 .EQ. 1)PL-0.31392 IF (KHOP .EQ. 2 .AND. K1 .EQ. 2)PL=G1-O.31392 IF (CPNT(l) .GT. .94174) THEN XK1 - K1 AKi - XK1/(2.O*KHOP) ELSE AKI - 1.0/(2.0*AK6)+FLOAT(K1-1)*(.9999-1.0/AK6) END IF PL -G1*AK1 C and West Longitude of Control Point C LO.WO -Latitude 600 CALL RAZGC(RLATRLON,PL.AZIM,L0,WO) C C LMVT - Local mean time at Control Point, In hours IF (WO .GE. 0.0) THEN LMVT - WO ELSE LMVT - WO+TWOPI END IF LMVT w T5-LMT*RTD/15.0 IF (LMT .LT. 0.0) THEN LMVT - LMT+24.0 ELSE IF (LMVT .GE. 24.0) THEN LMVT - LMT-24.0 END IF C C MLAT m Geomagnetic Latitude at Control Point SMG m 0.9792*SIN(L0)+0.2028*C0S(L0)*COS(W0-1.2O43) SMG - AMAX1(AMIN1(SMG,1.0),-1.0) MLAT - ASIN(SMG) C

33

C GYRO - Gyro Frequency (=0 for LAT-:.55 degrees) IF (ABS(MLAT) .LT. 0.95993) THEN GYRO - 0.0 ELSE GYRO - 0.3789*SQRT(1 .0+3.O*SMG*SMG)-0.5 END IF C k8=Tlme of local noon C Y1=2*P1DATE/365.25; Y2--Solar Declination; Y1 - 0.0172*(10.0+FLOAT( lTIME(1)-l)*30.4+lTIME(2)) Y2 - 0.4O9*COS(YI) K<8 - 3.82*W0+12.0+0.13*(SIN(Yl)+1.2*SIN(2.0*Y1)) IF (K<8 .GT. 24.0) THEN K<8 - K<8 -24.0 ELSE IF (K<8 .LE. 0.0) THEN K8 - K8+24.0 END IF C C M9 - M-Factor - MUF/FOF2C M9 - AMIN1(2.5*Gl*K5. HALFPI) M9 - SIN(MS) M9 - 1.O.2.5M9SQRT(MS) C t4=tlme of sunset t-tlme of sunrise; C K9-Iength of daylight; IF (COS(LO+Y2) .GT. -0.26) GOTO 100 C NO DAYLIGHT on PATH at ANY TIME DURING the DAY GO - 0.0 KS - 0.0 A4-1 .0 GOTO 140 100 CONTINUE C K9 - (-0.26+SIN(Y2)*SIN(LO))/(C0S(Y2)*COS(L0)+1 .OE-3) KS - AMAX1(AMIN1(KS,1.0),-1.0) KS - 12.0-ASIN(K9)*7.8394 T - 1<8-19/2.0 IF (T .LT. 0.0)T-T+24.0 T4 - KB+KS/2.O IF (T4 .GT. 24.O)T4-T4-24.O CO - ABS(COS(LO+Y2)) T9 - S.7*(AMAX1(CO.1))**9.6 T9 - AMAX1(TS,0.1) T6 -T5 IF ((T4 .LT. T .AND. (T5-T4)*(T-TS) .GT. 0.0) .OR. (T4 .GE. T .AND. (T6-T)*(T4-T5) .LE. 0.0)) GOTO 120 C C DAY TIME at CONTROL POINT IF (T -GT. T5)T6-T6+24.0 C C LOCAL TIME CONVERSION C T5 Is LOCAL TIME; WO Is LONGITUDE In RADIANS Z - W0*(180.O/3.14159265) C C LOCAL TIME DEPENDENT FACTOR for M-FACTOR HRLCL - T5-Z/15.O IF (HRLCL .GE. 24.O)HRLCL-HRLCL-24.0 IF (HRLCL .LT. 0.O)HRLCL-HRLCL+24.0 A4 w 1.11-.O1*HRLCL G9 - PI*(T6-T)/K9 G8 - PI*T9/KS U - (T-T6)/Tg U - AMIN1(AMAX1(U,-87.0),+87.O) Ul - -K9/T9 Ul - AMIN1(AMAX1(U1.-87.0)..87.O) GO - CO*(SIN(G9),G8*(EXP(U)-COS(G9)))/(1.O.G8*G8) G3 = C0*(G8*(EXP(Ul)+1.0)) A -EXP((K9-24.0)/2.0)/(1.0+G8*G8) GO - AMAX1(GOG3) GOTO 140 120 CONTINUE C

34

C
C C C C

NIGHT TIME at CONTROL PCINT 6th Order Fourier series night time factor based on hours after sunset, T2 IF Ti T2 AG AG1 AG2 AG3 AG4 AG5 AG6 A14 A24 A34 A44 for M-factor,

~A4
C

(T4 .GT. T5)T6-T6+24.O - T6-T4 - 14.O t Tl/(24.O-K9) - PI*(T2+1.0)/15.0 - 2.0*AG - 4.0*AG = 6.0*AG - 8.O*AG - 1O.O*AG - 12.0*AG - 1.0195-.06*SIN(AG1)-.037*COS(AG1)+.O18*SIN(AG2) - -. 003*COS(AG2)..025*SIN(AG3)+.018*COS(AG3) .O07*SIN(AG4)-.005*COS(AG4)+.Oo6*SIN(AG5) .017*COS(AG5)-..009*SIN(AG6)-.0O4*COS(AG6) - A14+A24+A34+A44

140 C

G8 - PI*T9/K9 U - (T4-T6)/2.O U - AMIN1(AMAX1(U,-75.O)..75.O) Ul - -K9/T9 Ul - AMIN1(AMAX1(U1.-75.O),+75.O) GO - CO*(G8*(EXP(Ul)+1.O))*EXP(U)/(1.o+G8*G8) CONTINUE G2 - SQRT(6.O+Al*SQRT(GO)).GYRO G2 - G2*(1 .O-O.1*EXP((K9-24.O)/3.O)) G2 - G2*(1.O+(1.O-SYGN(TLAT)*SYGN(RLAT))*O.1) G2 - G2*(i.O-O.1*(1 .+SYGN(ABS(SIN(LO)) -COS(LO))))

C IF (ABS(MLAT) C C C C .GE. 0.95993) THEN Is G2 If FOF2 corrects for polar region FOF2. The result not In polar region G2 - M9*FOF2(G2,LMT. ITIME,LOWO,MLAT.SSN) ELSE G2 - G2*M9 END IF G2 - G2*A2*A3*A4 CMUF - AMIN1(CMUF,G2) 160 CONTINUE GZERO-GO CMUF - AMINI(AMAX1(CZMUF,2.O),50.0) S'-AT-Y2 SLON-Vi C RETURN END

FUNCTION FOF2(FF2,LMT, ITIME,LAT,LON,MLAT,SsN)


0 * * * * * * * * *

FUNCTION FOF2

FOF2(FF2,LMT,ITIME,LATLON,MLAT,SSN)

This FUNCTION Corrects the F2-Layer Critical Frequency Computed by MUF35 for Polar Latitude uSING the CHIUI Model. Reference to be Supplied when AVailable. INPUT:

35

FF2 LMVT *ITIME LAT LON MLAT SSN OUTPUT: *FOF2

Critical Frequency from MUF35 In MHz Local Mean Time at LAT. LON In Hours Integer Array containing Month. Day Hour, Minute, Julian Day, and Year Radians in Geographic Latitude Geographic West Longitude In RadiansIn Radians Latitude Magnetic Sunspot Number The F2-Iayer Critical Freq. In MHz
-

REAL REAL INTEGER REAL REAL REAL REAL REAL

CALLed by SUBROUTINE or FUNCTION: SUBROUTINES and FUNCTIONs CALLed: COMMt~ON BLOCKS Referenced: None ITIME(6) INTEGER LAT ,LMT, LON ,MLAT ,MLON REAL DATA P1/3.1415926/

MUF35 None

PHI - LMT*Pi/12.0 TMO - ITIME(l1)-+( ITIME(2)+ITIME(3)/24.0+iTiME(4)/1440.0)/30.0-0.5 CMVLAT -COS(MLAT) MLON -COS(LAT)*SlN(LON-1.2O43)/CMLAT MLON -AMAX1(AlVIN1(MLON,1.0).-1.O) MLON -ASIN(MLON) X - (2.2+(O.2+SSN/1OOO.O)*SIN(MLAT))*CMLAT IFF - EXP(-(X**6)) GG - 1.O-FF T - PI*TMO/12.O V - SIN(T) IF (MLAT .GE. 0.0) THEN W - EXP(-1.2*(COS(MLAT-O.41015*COS(PHt))-CMLAT)) PLR - (2.O+O.012SSN)*W(1.0+O.3*V) ELSE U - COS(T+T) Y - SIN(MLON/2.O) YS - COS(MLON/2.O-Pi/20.0) Z - SIN(MLON) ZA - SQRT(ABS(Z)) AM - 1.0+V
B
-

V*(-)20Y*)A*U(/A*X(40YY

YS4 - YS**4 PLR - (2.5+SSN/50.0+U(O.5+(1.3+O.002SSN)*YS4) +(1 .3+O.005SSN)*COS(PHI-P*(1 .0+B))) * *(1 .O+.4*( 1.O-V*V) )EXP(-V*YS4) END IF FO172 - 2.85*SORT(GG*FF2*FF2/8.12.0.66FF*PLR) RETURN END

SUBROUTINE PATH(TLAT,TLON,RLAT ,RLONCPNT)


* * 0 * 0 0 0 * * * *

SUBROUTINE PATH

S********

CALL PATH(TLAT,TLON,RLAT,RLON,CPNT) * Control Point and Azimuth, Routine Computes the Range, This Method Assumes The Coordinates for a Given Propagation Path. The Required input a Sphericai Earth with a Radius of 6371 km. for this Moduie Is: TLAT - Transmitter Latitude In Radians * - Transmitter West Longitude In Radians *TLON RLAT - ReceiVer Latitude In Radians * * RLON - ReceiVer West Longitude In Radians This SUBROUTINE Returns the Foliowing Information In an 8 word

36

CPNT(1) CPNT(2) CPNT(3) CPNT(A) CPNT(5) CPNT(6) CPNT(7) CPNT(8)

Real Array (CPNT): Distance between the RCVR and XMTR in Radians Latitude of Midpoint In Radians West Longitude In Radians Latitude of Point 1000km from the RCVR In Radians West Longitude of Point 10O0km from RCVR In Radians Latitude of Point 100km from XMTR In Radians West Longitude of Point 100km from XMTR in Radians Azimuth from RCVR to XMTR In Radians Paths less than

CPNT(4) through CPNT(7) will not be Computed for 1000km (0.15696 Radians) in Length. SUBROUTINEs and FUNCTIONs Used: ! S ! GCRAZ RAZGC

COMMON BLOCKS Referenced: None DIMENSION CPNT(8) GET RANGE and AZIMUTH CALL GCRAZ(RLAT,RLON.TLAT,TLON,CPNT(1),CPNT(8)) GET MIDPOINT COORDINATES PL CPNT(1)/2.0

CALL RAZGC(RLAT,RLON,PLCPNT(8),CPNT(2),CPNT(3)) I = " IS the PATH LENGTH >= 1000km? IF (CPNT(1) .LT. 0.15696) GOTO 100

YES: GET COORDINATES of 1000km POINTS PL = 0.15696 CALL RAZGC(RLAT,RLONPLCPNT(8).CPNT(4),CPNT(5)) PL = CPNT(1)-0.15696 CALL RAZGC(RLAT,RLONPLCPNT(8),CPNT(6),CPNT(7)) 100 CONTINUE RETURN END

SUBROUTINE RAZGC(LAT1,LON1,RANGE,AZIM,LAT2,LON2)
S

**

* a *

SUBROUTINE RAZGC

CALL RAZGC(LAT1,LON1,RANGE,AZIM.LAT2,LON2) This Routine Computes the Latitude and West Longitude (LAT2,LON2) on the Earth's Specified Range from a GiVen Point of a Point. a Surface. Also Required for Input Is the Azimuth (AZIM) to the New and Earth Assumes a Spherical Method This In Radians. Point Point being at the the Degenerate Cases of the GiVen Recognizes For the Degenerate Cases, Azimuth Should be North or South pole. HoweVer, Azimuth Is not Checked or PI and LON2 Is Undefined. 0. This Routine Recogto LON1. LON2 Is Arbitrarily Set Equal and nizes the Degenerate Case when Range Is set to 0. All Coordinates are In Radians. SUBROUTINEs and FUNCTIONs Used:
aaa

None

asa

COMMON BLOCKS Referenced: None LAT1,LON1,LAT2,LON2 REAL PI/3.14159/.TWOPI/6.28318/,HALFPI/1.570796/ DATA RTD/57.295779/,DTR/0.017453/ DATA TEST for DEGENERATE CASES IF (ABS(LAT1-HALFPI) .GT. 1.OE-5) GOTO 100

sa-

THE GIVEN POINT Is the NORTH POLE LAT2 - HALFPI-RANGE LON2 f LON1 GOTO 200 100 CONTINUE

37

IF (ABS(LATI+HALFPI)
IaSTHE

.GT.

1.OE-5) GOTO 120

GIVEN POINT is the SOUTH POLE LAT2 - RANGE-HALFPI LON2 - LOWi GOTO 200 120 CONTINUE IF (RANGE .GT. 0.0) GOTO 130 POINT 2 COINCIDENT with POINT 1 LAT2 mLATI LON2 m LOWi GO TO 200 130 CONTINUE
**GENERAL

CASE SI - SIN(LAT1) C1 - COS(LAT1) C2 - COS(RANGE) CA - Sl*C2+Cl*SIN(RANGE)*COS(AZ IM) CA - AMIN1(AMAX1(CA,-1.O).+1.0) A - ACOS(CA)

TEST If DESTINATION ENDS UP on the POLES IF (ABS(A) .GT. 1.OE-5) GOTO 140 LAT2 - HALFPI LON2 - LONi GOTO 200 140 CONTINUE IF (ABS(A-PI) .GT. 1.OE-5) GOTO 150 LAT2 - -HALFPI LON2 w LONW GOTO 200 150 CONTINUE EVERYTHING SEEMS O.K. - GET DESTINATION COORDINATES CG - (C2-SI*CA)/(CI*SIN(A)) CG - AMIN1(AMAX1(CG,-1.0),+1.O) G - ACOS(CG) LAT2 - HALFPI-A SA - SIN(AZIM) IF (SA .GE. O.O)LON2-AMOD(LON1-G,TWOPI) IF (SA .LT. O.O)LON2-AMOD(LON1+GTWOPI) 200 CONTINUE RETURN END

FUNCTION SYGN(V)
** * *
8

**

REAL FUNCTION SYGN

**a*aaaSSSa

X-SYGN(Y) This FUNCTION Returns the Value of 0 If Y Is 0, -1. If Y Is Greater Than 0. Than 0 and a +1. SUBROUTINEs and FUNCTIONs Used:
asCOMMION

If Y Is Less

None

100 200 300 999

BLOCKS Referenced: IF (Y) 100,200,300 SYGN - -1.0 GOTO 999 SYGN - 0.0 GOTO 999 SYON - 1.0 RETURN END

None

SUBROUTINE GCRAZ(TLAT ,TLONRLAT,RLON,RANGE ,AZ IM)

38

c C C C C C C C C C C C C C C C C C C C C C C

This routine was copied from Fre-uency Model" by D. Ical Report 1189, Tec

"Quiet Time Lowest ObserVable K. Moislon, NOSC

B. Sailors and W. August 1987.

CALL GCRAZ(TLAT,TLON,RLAT,RLON,RANGE,AZIM) This routine computes the great circle range and azimuth between two points on the earth's surface. TLAT and TLON are the coordinates of point 1, RLAT and RLON are the coordinates of point 2. Both longitudes are west longitudes. The output Is RANGE, the distance between the two points In radians, and AZIM, the azimuth from one point to the other in radians. This method assumes a spherical earth and recognizes the degenerate cases of point 1 at the north or south pole or points 1 and 2 coincident. All coordinates are In radians. Subroutines and common blocks: functions used: none none

REAL TLAT,TLONRLATRLON DATA PI/3.14159/,TWOPI/6.28318/,HALFPI/1.570796/ & ,DTR/O.017453/, RTD/57.295779/ TEST FOR DEGENERATE CASES IF (ABS(TLAT-HALFPI).GT. 1.OE-5) GO TO 100 1 IS AT THE NORTH POLE

C C

C C
C POINT

C
RANGE-HALFPI-RLAT AZIM-PI GO TO 140 100 CONTINUE IF (ABS(TLAT+HALFPI)

.GT. 1.OE-5) GO TO 120

C
C POINT 1 IS AT THE SOUTH POLE

C
RANGE-HALFPI+RLAT AZIM-O.O GO TO 140 120 CONTINUE IF(ABS(TLAT-RLAT) & ABS(TLON-RLON)

.GT. 1.OE-5 .OR. .GT. 1.OE-5 ) GO TO 130

C
C

POINTS

1 AND 2 ARE COINCIDENT

RANGE-i.OE-8 AZIM-0.0 GO TO 140 130 CONTINUE

C
C GENERAL CASE S1-SIN(TLAT) C1-COS(TLAT) S2-SIN(RLAT) CR-SlS2+C1*COS(RLAT)*COS(TLON-RLON) CR-AMINI(AMAXI(CR. -1.0),+1.0) RANGE-ACOS(CR) CA-(S2-SI1CR)/(C*SIN(RANGE)) CA-AMIN1(AMAX1(CA, -1.0), +1.0) AZIM-ACOS(CA) IF(SIN(TLON-RLON) .LT. 0.0) AZIM-TWOPI-AZIM 140 CONTINUE RETURN END

39

C C C CP C C C C C C C C C CZ

SUBROUTINE OLOF SUBROUTINE OLOF CALL OLOF

(CPNTDTGLOF)

(CPNTDTG,LUF)

THIS ROUTINE COMPUTES THE LUF FOR SOLAR QUIET CONDITIONS (WHEN DETHE REQUIRED INPUT IS CPNT WHICH IS XRAY FLUX <1.85E-3). ELEMENT IS A SIX ITIME WHICH AND PATH FINED IN SUBROUTINE INTEGER ARRAY CONTAINING MONTH, DAY, HOUR, MINUTE, JULIAN DAY, THIS ROUTINE RETURNS LUFS. AND YEAR. SUBROUTINES AND FUNCTIONS USED: COMMON BLOCKS: NONE ABSORB

DIMENSION CPNT(8) LOF, K, V3 REAL ITIME(6) INTEGER CHARACTER*12 DTG D - CPNT(1)*6371.O LOF - 0.5 CALL DHOUR(DTGITIME(6),ITIME(5),ITIME(1),ITIME(2), ITIME(3),FHOUR,REFHOUR) A CALCULATE LUF FOR PATH < 2000 KM IF (D .GT. 2000.) GOTO 200 A = CPNT(1)/2. B - SIN(A) C = COS(A) CALL ABSORB (ITIME,CPNT(2),CPNT(3),AI,CHI) LOF - SQRT(AI/4O./SQRT(I.-O.9784/(I.+((C-0.985)/B)**2))) GOTO 1000 200 CALCULATE LUF FOR PATH < 3300 KM IF (D .GT. 3300.) GOTO 400 K - (4.O+1.875E-3*D)*O.045 CALL ABSORB (ITIME,CPNT(2),CPNT(3),AI,CHI) LOF - K*SQRT(AI) GOTO 1000

C C

CALCULATE LUF FOR PATH > 3300 KM 400 K - (7.5+O.001*D)*0.045 CALCULATE LUF FOR PATH > 6600 KM IF (D .LE. 6600.) GOTO 500 K3 - 1-O.3768*(CPNT(1)-1.0361) K = K3K 500 CALL ABSORB (ITIME,CPNT(2),CPNT(3),AB1,CHI) CALL ABSORB (ITIMECPNT(4),CPNT(5),AB2,CHI) CALL ABSORB (ITIME,CPNT(6),CPNT(7),AB3,CHI) LOF - K*SQRT((ABI*2.0+AB2+AB3)/4.0) 1000 CONTINUE LOF - AMIN1(AMAXI(LOF,0.5),50.O) RETURN END SUBROUTINE ABSORB (ITIME, LAT, LON, At, CHI)

CP C C C C C C C C

SUBROUTINE ABSORB INDEX AT ABSORPTION IONOSPHERIC COMPUTES THE THIS ROUTINE SIX ELEMENT INTEITIME IS A POSITION LAT AND LON AT ITIME. GER ARRAY FOR MONTH, DAY, HOUR, MINUTE, JULIAN DAY, AND YEAR. ARE THE RESULTS OF THIS ROUTINE LAT AND LON ARE IN RADIANS. AND CHI (SOLAR ZENITH ANGLE Al (ABSORPTION INDEX) STORED IN ARGO DR. PAUL BY WRITTEN WAS ROUTINE THIS IN RADIANS). WEST LONGITUDES. AND RADIANS LON ARE IN AND LAT (NOSC).

40

*C C C CZ

SUBROUTINES AND FUNCTIONS USED: COMMON BLOCKS: REAL INTEGER C C C PIDEGS SUN N, LAD

CH

LAT, LON, M, ITIME(6)

SLAT,SLON /SUN/ COMMON CALL SUBSOL( ITIME,SLAT,SLON) PIDEGS.INC INCLUDE RTD=57 .2957795 1 COMPUTE SOLAR ZENITH ANGLE W - 1.0 CH I - S IN(LAT)*S IN(SLAT) .. COS(LAT)COS(SLAT)*COS(LON-SLON) CHI - AMAX1(CHI,-1.) 1.) CHI -AMIN1(CHI, CHI - ACOS(CHI) CHINON - ABS(SLAT-LAT) IF (CHINON .LT. 1.57) GOTO 80 Al - 1.OE-13 RETURN 80 LAD - ABS(,LAT)*RTD TEST IF HIGH LATITUDE WINTER CORRECTION IS NEEDED IF (LAD .LT. 30.0) GOTO 100 IF ((ITIME(l) .EQ. 1 .OR. ITIME(1) .EQ. 12) .AND. LAT * GOTO 90 IF ((ITIME(l) .EQ. 6 .OR. ITIME(1) .EQ. 7) .AND. LAT * GOTO 90 GOTO 100 90 W - 1.0+O.0275*(30.O-ABS(60.0-LAD)) COMPUTE ABOSRPTION INDEX BASED ON LATITUDE 100 CONTINUE ALAT - ABS(LAT) IF (ALAT .LT. 0.45) N=1.4-ALAT*2.44 IF (ALAT .GE. 0.45 .AND. ALAT .LT. 1.0875) N-0.3 IF (ALAT .GE. 1.0875 .AND. ALAT .LT. 1.367)
aN--(ALAT-1.0875)*1.07.0.3

.GT. 0.0) .LT. 0.0)

IF (ALAT .GE. 1.387) N-0 CSXN - COS(CHINON)**N ABSP - 286.O*W*(1.0+O.5*ALAT)*CSXN IF (ABSP .LT. 1.OE-11) ABSP-1.OE-11 IF (LAD .GT. 18.0) GOTO 201 M - 0.5*(0.58.(LAD/18.O)*O.08) GOTO 300 201 CONTINUE IF (LAD .GT. 24.0) GOTO 202 M - 0. 5(O.66.22*(LAD.18.0)/6.0) GOTO 300 202 CONTINUE M - 0.44 ADJUST ACCORDING TO SOLAR ZENITH ANGLE IF DAYLIT 300 CONTINUE Al a ABSP*0.01 IF (CHI .GT. 1.8) RETURN C TYPE*.' ABSP-',ABSP,' CHI-',CHI,' CH(921.0,CHI)=', C A CH(921.0.CHI),' CH(921.0,CHINON)=',CH(921.O,CHINON), -. B6 C Al - ABSP*(CH(921 .0.CHI )/CH(921 .0,CHINON) )*(-2.0*M) RETURN END C

FUNCTION CH CID

(X,Y)

41

C
C C C C C C C CZ

REAL FUNCTION CH X - CH(X,Y)

THIS FUNCTION COMPUTES THE CHAPMAN'S GRAZING INCIDENCE INTEGRAL WHERE X IS THE PARAMETER RELATED TO THE ATMOSPHERIC DENSITY AND SCALE HEIGHT, AND V IS THE SOLAR ZENEITH IN RADIANS. THIS ROUTINE IS ACCURATE TO 0.1% WHEN X*(U-SIN(i))<1O OR COS(Y)>O. SUBROUTINES AND FUNCTIONS USED: COMM~vON BLOCKS: COMMvON CHPMN XC, G, VC CHPINT

/CHPMN/

XC = X YC - V CV - COS(Y) CYL - CY - 0.0174533 IF (350.*Y .GT. X*CYL**4) GOTO 10 CH - 1./CY RETURN 10 G - X*SIN(Y)/(X.ALOG(X)+20.O) G - ATAN(G/SQRT(1.0-G*G)) G - (G-V)/20.O IF (CYL .LT. 0.0) GOTO 30 IF (X*CVL .LT. 40.*Y)GOTO 20 CH - -X*SIN(Y)*G*(.14644866CHPINT(3.414214) + .8535534*CHPINT( .5857864)) RETURN 20 CH - -X*SIN(Y)*G*( .5392947E-3*CHPINT(9.395071) * + .03888791*CHP INT(4.536620) * .4+ .3574187*CHPINT(1.745761) + .6031541*CHPINT(.3225477)) RETURN 30 CH - -X*SIN(V)*G*(.4249314E-6*CHPINT(16.27926) * + .2825923E-4*CHPINT( 11.84379) * + .7530O84E-3*CHP INT(8.330153) * +4 .009501517*CHPINT(5.552496) a+ .06208746*CHPINT(3.401434) a+ .2180683*CHP1NT(l.808343) a+ .4011199*CHPINT(.7294545) a+ .3084411*CHPINT(.1377935)) RETURN END

FUNCTION CHPINT (Z) CP C C C C C CZ REAL FUNCTION CHPINT X - CHPINT(Z) THIS ROUTINE COMPUTES THE INTEGRAND OF NONE THE CHAPMAN INTEGRAL.

SUBROUTINES AND FUNCTIONS USED: COMMtvON BLOCKS: COMMvON CHPMN /CHPMN/ X, G, V

0 U

Z*G

SIN(Q+Y) - 0/2.0 CHPINT - EXP(2.0*X*SIN(Q)*COS(Y+Q)/U+Z),UU RETURN END

42

SUBROUT INE SUBSOL CP C C C C C C C C C Cz C SUBROUTINE SUBSOL CALL SUBSOL(ITIME)

(IT 'ME ,SLAT.SLON)

THIS ROUTINE COMPUTES THE COORDINATES OF THE SUB-SOLAR POINT FOR A GIVEN TIME. ITIME IS A SIX ELEMENT INTEGER ARRAY CONTAINING THE MONTH, DAY, HOUR, MINUTE, JULIAN DAY, AND YEAR. THE COORDINATES COMPUTED ARE STORED IN SLAT AND SLON IN COMMON SUN. SUBROUTINES AND FUNCTIONS USED: COMMON BLOCKS: INTEGER COMMON DATA DATA DATA DATA DATA DATA DATA SUN (TiME(6), /SUN/ YEAR SLAT, SLON NONE

AO/O.3798/.A1/-23.0009/ A2,A3,A4,A5,A6/-O.3802,-0. 1550,-O.0076,--0.0025.-O.0004/ B1,B2,B3,B4,B51 3.5354, 0.0302, 0.0728, 0.0032, 0.0020/ Cl,C2,C3,C4,C5/ 0.5965,-2.9502.-0.0663,-0.1248,-0.0103/ Dl ,D2.D3,D4,D5/-7.3435-9.4847,-0.383,...1747,-D.0159/ ONETWO/1.O,2.0/ TWOPI/6.2S319/,DTR/O.0174533/

IHOUR - ITIME(3) MINUTE wITIME(4) JDAY ITIME(5) YEAR - ITIME(6) DAY - JDAY+IHOUR/24.O+MINUTE/1440.0 K - MOD(YEAR,4) DATE - 365.O*FLOAT(K)+0. 0078*(FLOAT(YEAR)-68 .0) IF (K .NE. 0) DATE-DATE+1.O DATE - DATE+DAY X -DATE*TWOPI/365.25 SX -SIN(X) CX -CoS(X) TWOCX - TWO*CX C RECURSIVE CALCULATION FOR COS(N*X) C2X -TWOCX*CX-ONE S2X -TWOCX*SX C3X -TWOCX*C2X-CX S3X -TWOCX*S2X-SX C4X -TWOCX*C3X-C2X S4X -TWOCX*S3X-S2X C5X -TWOCX*C4X-C3X S5X -TWOCX*S4X-S3X C6X -TWOCX*C5X-C4X AND SIN (N-X),N-2,6

FOURIER EXPANSION FOR SOLAR DECLINATION AND EQUATION OF TIME DEC -AO+A1SCX+A2*C2X+A3*C3X+A4*C4X+A5*C5X+A6*C6X * +B1*SX+B2*S2X+B3*S3X+B4*S4X+B5*S5X EQNT - Cl*CX+C2*C2X+C3*C3X+C4*C4X+C5*C5X * ,D*SX+02*S2X.D3*S3X+04&S4XD5S5X GHA ftIHOUR-(12.0-EQNT/60.0)+MINUTE/60.0 SLAT - DEC*DTR SLON - 15.O*GHA*DTR IF (SLON .LT. 0.0) SLON-SLON+TWOPI RETURN END

43

TABLE I

Sunspot Number of the 133-Month Mean Sunspot Cycle Used In Subroutine MEANSSN

0N 0 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

5. 5.0 5.0 5.5 6.0 6.5 7.0 8.0 9.0 10.0 11.0 12.0 14.0 16.0 20.0 21.0 24.0 26.5 31.0 34.0 38.0 42.0 45.0 48.0 53.5 57.0 60.0 63.0 67.5 70.0 74.5 78.0 80.0 83.5 85.5 88.0 92.0 94.0 96.5 97.5 100.0 101.0 102.0 103.0 103.5 104.0

MONTH 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 89 88

1045 104.5 104.5 105.0 105.0 105.0 104.5 104.5 104.0 104.0 103.5 103.0 102.0 101.5 100.5 99.5 98.5 98.0 97.0 96.0 95.0 93.0 91.5 89.0 87.0 85.0 83.0 81.0 78.5 76.0 74.0 70.5 68.5 66.5 65.0 62.0 60.0 59.0 56.5 55.0 53.0 52.0 51.0 49.0 47.5 48'0

90 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

S5 45.0 44.0 43.0 41.5 40.0 38.0 37.0 35.5 34.0 33.0 32.0 30.5 29.5 28.5 27.0 26.0 25.0 24.0 23.5 22.5 22.0 20.5 20.0 19.0 18.0 17.5 17.0 16.0 15.0 14.0 13.5 13.0 12.5 12.0 11.0 11.0 10.0 10.0 (9.8) (9.6) (9.4) (9.2) (9.0)

44

UI

00
-

zz
00

zO

04

944

z
>N

45-

II

MINIMUF ALONE DAILY FLUX

MINIMUF UPDATED BY LEJEUNE-NORFOLK DATA

r-MINIMUF UPDATED BY DRIVER-FT. BRAGG DATA

MINIMUF ALONE 5-DAY AV. FLUX

MINIMUF UPDATED BY MacDILL-FT. BRAGG DATA

S3--

co

REPRESENTS A 24 HOUR CORRELATION IN IF CHANNEL PROPERTIES BEST CORRELATION


IS WITHIN A FEW

HOURS
1 1 1 1 1 1 1 1 1 1 I 1 I I I

2 3 4 5 6 7 8 9 1011 12 131415 16 17 18 19 20 2122 23 24 PREDICTION-MEASUREMENT DELAY (HOURS)

Figure 2.

Rms error between actual MOFs on the Lejeune-Norfolk path and MOFs predicted by a variety of techniques, as a function of time delay between prediction and measurement. Data include approximately 335 hourly predictions for each value of time delay. This figure taken from Daehler (1984).

46

N' So 0C4 " 4) 41 CO)


1 . I1~~~I * I.~~ I IU )4

000uC

Cc

c
4WD U) ) cc

0~~

*k

*O)

'

"c)

c N LSo

w W0)(

30. c
50') 00

00

0S0

.0

U)

4.

I~
Z4 cc Le

C.e4u

op,-

u 0)0-. W NU) -4

0)0

01.

0%

~~O)U
*0

aU
0

0.

0)

C)
hl

PB0fl03cwS

47

0~

>

cl,-

'iu

Mv

C 4

00
0
0

04
QU)

0
If

+, 0
a. 9)
.I4

(n o

ot z
000
fn

AJ

1446J

0
)w

00

H 0

00
a W

484

You might also like