Broncode voor kerapu.Kerapu

import csv
from typing import Dict, List

from kerapu import clean_str, clean_int, clean_bool, clean_date
from kerapu.boom.attribuut import maak_attribuut, Attribuut
from kerapu.boom.AttribuutGroep import AttribuutGroep
from kerapu.boom.attribuut_groep_koppeling import maak_attribuut_groep_koppeling, AttribuutGroepKoppeling
from kerapu.boom.BeslisRegel import BeslisRegel
from kerapu.boom.ZorgProductGroep import ZorgProductGroep
from kerapu.boom.ZorgProductGroepVersie import ZorgProductGroepVersie
from kerapu.lbz.Diagnose import Diagnose
from kerapu.lbz.Specialisme import Specialisme
from kerapu.lbz.Subtraject import Subtraject
from kerapu.lbz.ZorgActiviteit import ZorgActiviteit
from kerapu.lbz.ZorgType import ZorgType
from kerapu.lbz.ZorgVraag import ZorgVraag


[documentatie]class Kerapu: """ Een implementatie van de grouper in Python. """ # ------------------------------------------------------------------------------------------------------------------ def __init__(self): """ Object constructor. """ self.__zorgproductgroep_boom: Dict[str, ZorgProductGroep] = {} """ De zorgproductgroepboom. Sleutel is zorgproductgroepcode. """ self.__beslisregels: Dict[int, BeslisRegel] = {} """ Alle beslisregels. Sleutel is het ID van de beslisregel. """ self.__attribuutgroepen: Dict[int, AttribuutGroep] = {} """ Alle attribuutgroepen. Sleutel is het ID van de attribuutgroep. """ self.__attribuut_groep_koppelingen: Dict[int, List[AttribuutGroepKoppeling]] = {} """ Alle attribuutgroepkoppelingen. Sleutel is het ID van de attribuutgroep. """ self.__attributen: Dict[int, Attribuut] = {} """ Alle attributen. Sleutel is het ID van het attribuut. """ # ------------------------------------------------------------------------------------------------------------------
[documentatie] def init_static(self, folder: str) -> None: """ Initialiseert alle statistische data. :param str folder: De folder met alle goupertabellen. """ self.__lees_attribuut_tabel(folder) self.__lees_attribuut_groep_koppeling_tabel(folder) self.__lees_attribuut_groepen_tabel(folder) self.__lees_beslis_regel_tabel(folder) self.__lees_zorg_product_groepen(folder) Diagnose.init_static(folder) Specialisme.init_static(folder) ZorgActiviteit.init_static(folder) ZorgType.init_static(folder) ZorgVraag.init_static(folder)
# ------------------------------------------------------------------------------------------------------------------ def __lees_attribuut_tabel(self, folder: str) -> None: """ Leest de attribuuttabel (opgeslagen in CSV). :param str folder: De folder met alle groupertabellen in CSV-formaat. """ with open(folder + '/Attributen.csv', 'r', encoding='utf-8') as csv_file: reader = csv.reader(csv_file) regel_nummer = 0 for regel in reader: regel_nummer += 1 # Sla de eerste regel met koppen over. if regel_nummer == 1: continue attribuut_id = int(regel[0]) boom_parameter_nummer = int(regel[2]) filter_toets_wijze = int(regel[3]) filter_waarde_type = int(regel[4]) onder_filter_waarde = clean_str(regel[5]) boven_filter_waarde = clean_str(regel[6]) self.__attributen[attribuut_id] = maak_attribuut(attribuut_id, boom_parameter_nummer, filter_toets_wijze, filter_waarde_type, onder_filter_waarde, boven_filter_waarde) print("Aantal attributen: %d" % (regel_nummer - 1)) # ------------------------------------------------------------------------------------------------------------------ def __lees_attribuut_groep_koppeling_tabel(self, folder: str) -> None: """ Leest de attribuutgroepkoppelingen (opgeslagen in CSV). :param str folder: De folder met alle groupertabellen in CSV-formaat. """ with open(folder + '/AttribuutGroepKoppelingen.csv', 'r', encoding='utf-8') as csv_file: reader = csv.reader(csv_file) regel_nummer = 0 for regel in reader: regel_nummer += 1 # Sla de eerste regel met koppen over. if regel_nummer == 1: continue attribuut_groep_id = int(regel[1]) attribuut_id = int(regel[2]) attribuut_toets_wijze = int(regel[3]) onder_toets_waarde = clean_int(regel[4]) boven_toets_waarde = clean_int(regel[5]) if attribuut_groep_id not in self.__attribuut_groep_koppelingen: self.__attribuut_groep_koppelingen[attribuut_groep_id] = [] if attribuut_id not in self.__attributen: raise RuntimeError("Onbekend attribuut: '%d'" % attribuut_id) koppeling = maak_attribuut_groep_koppeling(attribuut_groep_id, self.__attributen[attribuut_id], attribuut_toets_wijze, onder_toets_waarde, boven_toets_waarde) self.__attribuut_groep_koppelingen[attribuut_groep_id].append(koppeling) print("Aantal attribuutgroepkoppelingen: %d" % (regel_nummer - 1)) # ------------------------------------------------------------------------------------------------------------------ def __lees_attribuut_groepen_tabel(self, folder: str) -> None: """ Leest de attribuutgroepen (opgeslagen in CSV). :param str folder: De folder met alle groupertabellen in CSV-formaat. """ with open(folder + '/AttribuutGroepen.csv', 'r', encoding='utf-8') as csv_file: reader = csv.reader(csv_file) regel_nummer = 0 for regel in reader: regel_nummer += 1 # Sla de eerste regel met koppen over. if regel_nummer == 1: continue attribuut_groep_id = int(regel[0]) aantal_voorwaarden_voor_true = int(regel[2]) if attribuut_groep_id not in self.__attribuut_groep_koppelingen: raise RuntimeError("Onbekende koppeling: '%d'" % attribuut_groep_id) self.__attribuutgroepen[attribuut_groep_id] = AttribuutGroep(attribuut_groep_id, aantal_voorwaarden_voor_true, self.__attribuut_groep_koppelingen[ attribuut_groep_id]) print("Aantal attributen: %d" % (regel_nummer - 1)) # ------------------------------------------------------------------------------------------------------------------ def __lees_beslis_regel_tabel(self, folder: str) -> None: """ Leest de beslisregels (opgeslagen in CSV). :param str folder: De folder met alle groupertabellen in CSV-formaat. """ verrijkingen = {} with open(folder + '/BeslisRegels.csv', 'r', encoding='utf-8') as csv_file: reader = csv.reader(csv_file) regel_nummer = 0 for regel in reader: regel_nummer += 1 # Sla de eerste regel met koppen over. if regel_nummer == 1: continue beslis_regel_id = int(regel[0]) attribuut_groep_id = int(regel[1]) beslist_regel_id_true = clean_int(regel[2]) beslist_regel_id_false = clean_int(regel[3]) label_true = clean_str(regel[4]) label_false = clean_str(regel[5]) indicatie_aanspraakbeperking = clean_bool(regel[6]) if attribuut_groep_id not in self.__attribuutgroepen: raise RuntimeError("Onbekende attribuutgroep: '%d'" % attribuut_groep_id) verrijkingen[beslis_regel_id] = (beslist_regel_id_true, beslist_regel_id_false) self.__beslisregels[beslis_regel_id] = BeslisRegel(beslis_regel_id, self.__attribuutgroepen[attribuut_groep_id], label_true, label_false, indicatie_aanspraakbeperking) # Verrijk alle beslisregels met beslisregels voor true en false. for beslis_regel_id, (beslist_regel_id_true, beslist_regel_id_false) in verrijkingen.items(): beslist_regel_true = self.__beslisregels.get(beslist_regel_id_true, None) beslist_regel_false = self.__beslisregels.get(beslist_regel_id_false, None) self.__beslisregels[beslis_regel_id].verrijk(beslist_regel_true, beslist_regel_false) print("Aantal beslisregels: %d" % (regel_nummer - 1)) # ------------------------------------------------------------------------------------------------------------------ def __lees_zorg_product_groepen(self, folder: str) -> None: """ Leest de zorgproductgroepen (opgeslagen in CSV). :param str folder: De folder met alle groupertabellen in CSV-formaat. """ with open(folder + '/ZorgProductGroepen.csv', 'r', encoding='utf-8') as csv_file: reader = csv.reader(csv_file) regel_nummer = 0 for regel in reader: regel_nummer += 1 # Sla de eerste regel met koppen over. if regel_nummer == 1: continue zorg_product_groep_code = clean_str(regel[0]) beslist_regel_id_start = int(regel[2]) begin_datum = clean_date(regel[3]) eind_datum = clean_date(regel[4]) if zorg_product_groep_code not in self.__zorgproductgroep_boom: self.__zorgproductgroep_boom[zorg_product_groep_code] = ZorgProductGroep(zorg_product_groep_code) versie = ZorgProductGroepVersie(zorg_product_groep_code, self.__beslisregels[beslist_regel_id_start], begin_datum, eind_datum) self.__zorgproductgroep_boom[zorg_product_groep_code].versie_toevoegen(versie) print("Aantal zorgproductgroep versies: %d" % (regel_nummer - 1)) # ------------------------------------------------------------------------------------------------------------------
[documentatie] def bepaal_zorg_product_groep(self, subtraject: Subtraject) -> str: """ Bepaalt de zorgproductgroep van een subtraject. :param Subtraject subtraject: Het subtraject waarvoor de zorgproductgroep moet worden bepaalt. :rtype: str """ top_boom = self.__zorgproductgroep_boom['0'] subtraject.zorg_product_groep_code = top_boom.klim(subtraject) return subtraject.zorg_product_groep_code
# ------------------------------------------------------------------------------------------------------------------
[documentatie] def bepaal_zorg_product(self, subtraject: Subtraject) -> str: """ Bepaalt de zorgproduct van een subtraject. :param Subtraject subtraject: Het subtraject waarvoor de zorgproductcode moet worden bepaalt. :rtype: str """ zorg_product_groep_code = self.bepaal_zorg_product_groep(subtraject) if zorg_product_groep_code is not None: top_boom = self.__zorgproductgroep_boom[zorg_product_groep_code] subtraject.zorg_product_code = top_boom.klim(subtraject) else: subtraject.zorg_product_code = None return subtraject.zorg_product_code
# ----------------------------------------------------------------------------------------------------------------------