STK++ 1.0
STK_Law_Cauchy.h
Go to the documentation of this file.
00001 /*--------------------------------------------------------------------*/
00002 /*     Copyright (C) 2004-2008  Serge Iovleff
00003 
00004     This program is free software; you can redistribute it and/or modify
00005     it under the terms of the GNU Lesser General Public License as
00006     published by the Free Software Foundation; either version 2 of the
00007     License, or (at your option) any later version.
00008 
00009     This program is distributed in the hope that it will be useful,
00010     but WITHOUT ANY WARRANTY; without even the implied warranty of
00011     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00012     GNU Lesser General Public License for more details.
00013 
00014     You should have received a copy of the GNU Lesser General Public
00015     License along with this program; if not, write to the
00016     Free Software Foundation, Inc.,
00017     59 Temple Place,
00018     Suite 330,
00019     Boston, MA 02111-1307
00020     USA
00021 
00022     Contact : Serge.Iovleff@stkpp.org
00023 */
00024 
00025 /*
00026  * Project:  Laws
00027  * Purpose:  Cauchy probability distribution.
00028  * Author:   Serge Iovleff, serge.iovleff@stkpp.org
00029  **/
00030 
00035 #ifndef STK_LAW_CAUCHY_H
00036 #define STK_LAW_CAUCHY_H
00037 
00038 #include "STK_Law_ITUnivariate.h"
00039 
00040 namespace STK
00041 {
00042 
00043 namespace Law
00044 {
00059 class Cauchy : public ITUnivariate<Real>
00060 {
00061   protected:
00063     Real location_;
00064     
00066     Real scale_;
00067     
00068   public:
00073     Cauchy( Real const& location=0, Real const& scale=1);
00074 
00076     virtual ~Cauchy();
00077 
00080     virtual Real rand() const;
00081     
00088     static Real rand( Real const& location, Real const& scale);
00089     
00094     virtual Real pdf( Real const& x) const;
00095     
00100     virtual Real lpdf( Real const& x) const;
00101 
00113     virtual Real cdf( Real const& t) const;
00114     
00124     virtual Real icdf( Real const& p) const;
00125 };
00126 
00127 } // namespace Law
00128 
00129 } // namespace STK
00130 
00131 #endif /*STK_LAWCAUCHY_H*/