Rcpp Version 0.9.10
rnchisq.h
Go to the documentation of this file.
00001 // -*- mode: C++; c-indent-level: 4; c-basic-offset: 4; tab-width: 4 -*-
00002 //
00003 // rnchisq.h: Rcpp R/C++ interface class library -- 
00004 //
00005 // Copyright (C) 2010 - 2011 Douglas Bates, Dirk Eddelbuettel and Romain Francois
00006 //
00007 // This file is part of Rcpp.
00008 //
00009 // Rcpp is free software: you can redistribute it and/or modify it
00010 // under the terms of the GNU General Public License as published by
00011 // the Free Software Foundation, either version 2 of the License, or
00012 // (at your option) any later version.
00013 //
00014 // Rcpp is distributed in the hope that it will be useful, but
00015 // WITHOUT ANY WARRANTY; without even the implied warranty of
00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00017 // GNU General Public License for more details.
00018 //
00019 // You should have received a copy of the GNU General Public License
00020 // along with Rcpp.  If not, see <http://www.gnu.org/licenses/>.
00021 
00022 #ifndef Rcpp__stats__random_rnchisq_h
00023 #define Rcpp__stats__random_rnchisq_h
00024 
00025 namespace Rcpp {
00026         namespace stats {
00027 
00028                 class NChisqGenerator : public ::Rcpp::Generator<false,double> {
00029                 public:
00030         
00031                         NChisqGenerator( double df_, double lambda_ ) : 
00032                                 df(df_), df_2(df_ / 2.0), lambda_2(lambda_ / 2.0 ) {}
00033         
00034                         inline double operator()() const {
00035                                 double r = ::Rf_rpois( lambda_2 ) ;
00036                                 // if( r > 0.0 ) r = Rf_rchisq( 2. * r ) ;
00037                                 // replace by so that we can skip the tests in rchisq
00038                                 // because there is no point in doing them as we know the 
00039                                 // outcome for sure
00040                                 if( r > 0.0 ) r = ::Rf_rgamma( r, 2. ) ;
00041                                 if (df > 0.) r += ::Rf_rgamma( df_2, 2.);
00042                                 return r;
00043                         }
00044         
00045                 private:
00046                         double df ;
00047                         double df_2 ;
00048                         double lambda_2 ;
00049                 } ;
00050         } // stats
00051 
00052         // Please make sure you to read Section 6.3 of "Writing R Extensions"
00053         // about the need to call GetRNGstate() and PutRNGstate() when using 
00054         // the random number generators provided by R.
00055         inline NumericVector rnchisq( int n, double df, double lambda ){
00056                 if (!R_FINITE(df) || !R_FINITE(lambda) || df < 0. || lambda < 0.) 
00057                         return NumericVector(n, R_NaN) ;
00058                 if( lambda == 0.0 ){
00059                         // using the central generator, see rchisq.h
00060                         return NumericVector( n, stats::ChisqGenerator( df ) ) ;
00061                 }
00062                 return NumericVector( n, stats::NChisqGenerator( df, lambda ) ) ;
00063         }
00064 
00065         // Please make sure you to read Section 6.3 of "Writing R Extensions"
00066         // about the need to call GetRNGstate() and PutRNGstate() when using 
00067         // the random number generators provided by R.
00068         inline NumericVector rnchisq( int n, double df /*, double lambda = 0.0 */ ){
00069                 if (!R_FINITE(df) || df < 0. ) 
00070                         return NumericVector(n, R_NaN) ;
00071                 return NumericVector( n, stats::ChisqGenerator( df ) ) ;
00072         }
00073 
00074 } // Rcpp
00075 
00076 #endif
 All Classes Namespaces Files Functions Variables Typedefs Enumerator Friends Defines