julienmalard/Tinamit

View on GitHub
tinamit0/pruebas/test_calib_valid_modelos.py

Summary

Maintainability
A
0 mins
Test Coverage
import os
import unittest

import numpy as np
from tinamit.calibs.geog_mod import SimuladorGeog, CalibradorGeog, ValidadorGeog
from tinamit.calibs.mod import CalibradorModSpotPy
from tinamit.calibs.valid import ValidadorMod
from tinamit.datos.bd import BD
from tinamit.datos.fuente import FuenteDic
from tinamit.envolt.mds import gen_mds
from tinamit.ejemplos import obt_ejemplo

dir_act = os.path.split(__file__)[0]
arch_mds = obt_ejemplo('enfermedad/mod_enferm.mdl')
arch_csv_geog = obt_ejemplo('geog_guate/geog_guate.csv')

líms_paráms = {
    'taza de contacto': (0, 100),
    'taza de infección': (0, 0.02),
    'número inicial infectado': (0, 50),
    'taza de recuperación': (0, 0.1)
}


class TestCalibModelo(unittest.TestCase):
    @classmethod
    def setUpClass(cls):
        cls.paráms = {
            'taza de contacto': 81.25,
            'taza de infección': 0.007,
            'número inicial infectado': 22.5,
            'taza de recuperación': 0.0375
        }
        cls.mod = gen_mds(arch_mds)

        simul = cls.mod.simular()
        datos = {ll: v[:, 0] for ll, v in simul.a_dic().items()}  # Para hacer: dimensiones múltiples,
        cls.datos = FuenteDic(
            datos, 'Datos', fechas=np.arange(101)
        )

    def test_calibrar_validar(símismo):
        calibs = CalibradorModSpotPy(símismo.mod).calibrar(
            líms_paráms=líms_paráms,
            datos=símismo.datos,
            n_iter=50
        )
        valid = ValidadorMod(símismo.mod).validar(
            t=100, datos=símismo.datos, paráms={prm: trz['mejor'] for prm, trz in calibs.items()}
        )
        símismo.assertGreater(valid['Individuos Suceptibles']['ens'], 0.95)


class TestCalibModeloEspacial(unittest.TestCase):
    @classmethod
    def setUpClass(cls):
        cls.paráms = {
            '708': {
                'taza de contacto': 81.25, 'taza de infección': 0.007, 'número inicial infectado': 22.5,
                'taza de recuperación': 0.0375
            },
            '1010': {
                'taza de contacto': 50, 'taza de infección': 0.005, 'número inicial infectado': 40,
                'taza de recuperación': 0.050
            }
        }
        cls.mod = gen_mds(arch_mds)
        simul = SimuladorGeog(cls.mod).simular()

        # Para hacer: dimensiones múltiples,
        datos = {
            lg: {ll: v[:, 0] for ll, v in simul[lg].a_dic().items()} for lg in cls.paráms
        }

        cls.datos = BD([
            FuenteDic(datos[lg], 'Datos geográficos', lugares=lg, fechas=np.arange(101)) for lg in cls.paráms
        ])

    def test_calib_valid_espacial(símismo):
        calib = CalibradorGeog(símismo.mod).calibrar(t=100, datos=símismo.datos, líms_paráms=líms_paráms, n_iter=50)
        valid = ValidadorGeog(símismo.mod).validar(
            t=100, datos=símismo.datos,
            paráms={lg: {prm: trz['mejor'] for prm, trz in calib[lg].items()} for lg in símismo.paráms}
        )

        for lg in símismo.paráms:
            símismo.assertTrue(valid[lg]['Individuos Suceptibles']['ens'], 0.95)