CALL FARMASIM   (series, d <*>, phi <*>, theta <*>, mu <*>, sigma <*>, n <*>, p <*>, q <*>, initial <*>, seed )   ; 
            
The FARMASIM subroutine generates an ARFIMA( ) process. The input arguments to the FARMASIM subroutine are as follows:
) process. The input arguments to the FARMASIM subroutine are as follows: 
         
specifies a fractional differencing order. This argument is required; the value of  should be in the open interval
 should be in the open interval  excluding zero.
 excluding zero. 
                  
specifies an  -dimensional vector that contains the autoregressive coefficients, where
-dimensional vector that contains the autoregressive coefficients, where  is the number of the elements in the subset of the AR order. The default is zero.
 is the number of the elements in the subset of the AR order. The default is zero. 
                  
specifies an  -dimensional vector that contains the moving average coefficients, where
-dimensional vector that contains the moving average coefficients, where  is the number of the elements in the subset of the MA order. The default is zero.
 is the number of the elements in the subset of the MA order. The default is zero. 
                  
specifies a mean value. The default is zero.
specifies a variance of the innovation series. The default is one.
specifies the length of the series. The value of  should be greater than or equal to the AR order. The default is
 should be greater than or equal to the AR order. The default is  is used.
 is used. 
                  
specifies the subset of the AR order. See the FARMACOV subroutine for additional details.
specifies the subset of the MA order. See the FARMACOV subroutine for additional details.
specifies the initial values of random variables. The initial value is used for the nonstationary process. If initial , then
, then  take the same value
 take the same value  . If the initial option is not specified, the initial values are set to zero.
. If the initial option is not specified, the initial values are set to zero. 
                  
is a scalar that contains the random number seed. At the first execution of the subroutine, the seed variable is used as follows:
If seed > 0, the input seed is used for generating the series.
If seed = 0, the system clock is used to generate the seed.
If seed < 0, the value ( )
) (seed) is used for generating the series.
(seed) is used for generating the series. 
                  
If the seed is not supplied, the system clock is used to generate the seed.
On subsequent calls of the subroutine in the DO-loop-like environment, the seed variable is used as follows: If seed > 0, the seed remains unchanged. In other cases, after each execution of the subroutine, the current seed is updated internally.
The FARMASIM subroutine returns the following value:
is an  vector that contains the generated ARFIMA(
 vector that contains the generated ARFIMA( ) process.
) process. 
                  
As an example, consider the following ARFIMA( ) process:
) process: 
         
![\[  (1-0.5B)(1-B)^{0.3}(y_ t-10) = (1+0.1B){\epsilon }_ t  \]](images/imlug_langref0381.png)
 In this process,  . The following statements generate this process:
. The following statements generate this process: 
         
d = 0.3; phi = 0.5; theta = -0.1; mu = 10; sigma = 1.2; call farmasim(yt, d, phi, theta, mu, sigma, 10) seed=1234; print yt;
Figure 24.131: Data Simulated from a ARFIMA Process
| yt | 
|---|
| 12.17358 | 
| 13.954495 | 
| 15.817231 | 
| 15.94882 | 
| 12.25926 | 
| 13.641022 | 
| 13.399623 | 
| 11.930759 | 
| 10.049435 | 
| 9.1445036 | 
The FARMASIM subroutine generates a time series of length  from an ARFIMA(
 from an ARFIMA( ) model. If the process is stationary and invertible, the initial values
) model. If the process is stationary and invertible, the initial values  are produced by using covariance matrices obtained from FARMACOV. If the process is nonstationary, the time series is recursively
            generated by using the user-defined initial value or the zero initial value.
 are produced by using covariance matrices obtained from FARMACOV. If the process is nonstationary, the time series is recursively
            generated by using the user-defined initial value or the zero initial value. 
         
To generate an ARFIMA( ) process with
) process with  ,
,  is first generated for
 is first generated for  , where
, where  and then
 and then  is generated by
 is generated by  .
. 
         
To generate an ARFIMA( ) process with
) process with ![$d\in (-1,-0.5]$](images/imlug_langref0387.png) , a two-step approximation based on a truncation of the expansion
, a two-step approximation based on a truncation of the expansion  is used; the first step is to generate an ARFIMA(
 is used; the first step is to generate an ARFIMA( ) process
) process  , with truncated moving average weights; the second step is to generate
, with truncated moving average weights; the second step is to generate  .
.