from simplemc.models.LCDMCosmology import LCDMCosmology
from simplemc.cosmo.paramDefs import w_par, wa_par, Ok_par
import math as N
#TODO Add more DE EoS for comparison
[docs]class owa0CDMCosmology(LCDMCosmology):
    """
        This is CDM cosmology with w, wa and Ok.
        CPL parameterization with curvature.
        This class inherits LCDMCosmology class as the rest of the cosmological
        models already included in SimpleMC.
        :param varyw: variable w0 parameter
        :type varyw: Boolean
        :param varywa: variable wa parameter
        :type varywa: Boolean
        :param varyOk: variable Ok parameter
        :type varyOk: Boolean
    """
    def __init__(self, varyw=True, varywa=True, varyOk=True):
        self.varyw  = varyw
        self.varywa = varywa
        self.varyOk = varyOk
        self.Ok = Ok_par.value
        self.w0 = w_par.value
        self.wa = wa_par.value
        LCDMCosmology.__init__(self)
    # my free parameters. We add Ok on top of LCDM ones (we inherit LCDM)
    def freeParameters(self):
        l = LCDMCosmology.freeParameters(self)
        if (self.varyw):  l.append(w_par)
        if (self.varywa): l.append(wa_par)
        if (self.varyOk): l.append(Ok_par)
        return l
[docs]    def updateParams(self, pars):
        ok = LCDMCosmology.updateParams(self, pars)
        if not ok:
            return False
        for p in pars:
            if p.name == "w":
                self.w0 = p.value
            elif p.name == "wa":
                self.wa = p.value
            elif p.name == "Ok":
                self.Ok = p.value
                self.setCurvature(self.Ok)
                if (abs(self.Ok) > 1.0):
                    return False
        return True 
    # this is relative hsquared as a function of a
    ## i.e. H(z)^2/H(z=0)^2
[docs]    def RHSquared_a(self, a):
        NuContrib = self.NuDensity.rho(a)/self.h**2
        rhow = a**(-3*(1.0+self.w0+self.wa))*N.exp(-3*self.wa*(1-a))
        return (self.Ocb/a**3+self.Ok/a**2+self.Omrad/a**4+NuContrib+(1.0-self.Om-self.Ok)*rhow)