LCOV - code coverage report
Current view: top level - models/abm - household.h (source / functions) Hit Total Coverage
Test: coverage.info Lines: 26 29 89.7 %
Date: 2025-01-17 12:16:22 Functions: 9 10 90.0 %

          Line data    Source code
       1             : /*
       2             : * Copyright (C) 2020-2025 MEmilio
       3             : *
       4             : * Authors: Daniel Abele, Sascha Korf, Khoa Nguyen
       5             : *
       6             : * Contact: Martin J. Kuehn <Martin.Kuehn@DLR.de>
       7             : *
       8             : * Licensed under the Apache License, Version 2.0 (the "License");
       9             : * you may not use this file except in compliance with the License.
      10             : * You may obtain a copy of the License at
      11             : *
      12             : *     http://www.apache.org/licenses/LICENSE-2.0
      13             : *
      14             : * Unless required by applicable law or agreed to in writing, software
      15             : * distributed under the License is distributed on an "AS IS" BASIS,
      16             : * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
      17             : * See the License for the specific language governing permissions and
      18             : * limitations under the License.
      19             : */
      20             : 
      21             : #ifndef MIO_ABM_HOUSEHOLD_H
      22             : #define MIO_ABM_HOUSEHOLD_H
      23             : 
      24             : #include "abm/model.h"
      25             : #include "memilio/epidemiology/age_group.h"
      26             : #include "memilio/utils/custom_index_array.h"
      27             : #include <numeric>
      28             : #include <vector>
      29             : 
      30             : namespace mio
      31             : {
      32             : namespace abm
      33             : {
      34             : 
      35             : /**
      36             :  * @file
      37             :  * A HouseholdMember has a vector with weighted age distribution from which the age can be calculated.
      38             :  * A Household holds a vector with HouseholdMembers.
      39             :  * A HouseholdGroup holds a vector with a tuple of a Household and the amount of times the Household is in the group.
      40             :  * E.g. if 10 households hold a member of "child and parent" and that Household would be parentAndChildHousehold the
      41             :  * vector would contain <parentAndChildHousehold, 10>. parentAndChildHousehold would consist of a vector with the
      42             :  * HouseholdMembers parent and child and parent has, for example the age distribution {0,0,10,1,0,0} with respect to the 
      43             :  * AgeGroup class. The child would have, for example, {1,1,0,0,0}, meaning that the AgeGroups 0-4 and 5-14 are the only
      44             :  * possible ages and are both equally likely.
      45             :  */
      46             : 
      47             : /**
      48             :  * @brief A HouseholdMember represented by a weighted age distribution.
      49             :  * For every AgeGroup there is a weight which is used to calculate the age of the Person living in this Household.
      50             :  */
      51             : class HouseholdMember
      52             : {
      53             : public:
      54             :     /**
      55             :      * @brief Constructs a new HouseholdMember.
      56             :      * @param[in] agegroups the age groups in the model. 
      57             :      */
      58         324 :     HouseholdMember(size_t num_agegroups)
      59         324 :         : m_age_weights({AgeGroup(num_agegroups)}, 0)
      60             :     {
      61         324 :     }
      62             : 
      63             :     /**
      64             :      * @brief Sets the weight of an AgeGroup.
      65             :      * The weights correspond to the probability that a Person has the corresponding age.
      66             :      * @param[in] age_group The AgeGroup.
      67             :      * @param[in] weight The weight of the AgeGroup.
      68             :      */
      69          36 :     void set_age_weight(mio::AgeGroup age_group, int weight)
      70             :     {
      71          36 :         assert(age_group < m_age_weights.size<mio::AgeGroup>());
      72          36 :         m_age_weights[age_group] = weight;
      73          36 :     }
      74             : 
      75             :     /**
      76             :      * @brief Returns the CustomIndexArray with the weights of each AgeGroup.
      77             :      */
      78         936 :     const CustomIndexArray<int, mio::AgeGroup>& get_age_weights() const
      79             :     {
      80         936 :         return m_age_weights;
      81             :     }
      82             : 
      83             : private:
      84             :     CustomIndexArray<int, mio::AgeGroup> m_age_weights; ///< Weights of every AgeGroup.
      85             : };
      86             : 
      87             : /**
      88             :  * @brief A Household represented by a vector with HouseholdMember%s.
      89             :  * The Household may contain multiple members of the same type.
      90             :  */
      91             : class Household
      92             : {
      93             : public:
      94             :     /**
      95             :      * @brief Constructs a new Household.
      96             :      */
      97          45 :     Household()
      98          45 :         : m_household_member_list()
      99             :     {
     100          45 :         m_number_of_members = 0;
     101          45 :         m_space_per_member  = 0;
     102          45 :     }
     103             : 
     104             :     /**
     105             :      * @brief Returns the number of members, i.e.\ Person%s in the Household.
     106             :      */
     107         288 :     int get_total_number_of_members() const
     108             :     {
     109         288 :         return m_number_of_members;
     110             :     }
     111             : 
     112             :     /**
     113             :      * @brief Set the space per member for the computation of the LocationCapacity of the Household.
     114             :      * @param[in] space_per_member Space per member in cubic meters.
     115             :      */
     116           0 :     void set_space_per_member(int space_per_member)
     117             :     {
     118           0 :         m_space_per_member = space_per_member;
     119           0 :     }
     120             : 
     121             :     /**
     122             :      * @brief Get the space per member of the Household, measured in cubic meters.
     123             :      */
     124         144 :     int get_space_per_member() const
     125             :     {
     126         144 :         return m_space_per_member;
     127             :     }
     128             : 
     129             :     /**
     130             :      * @brief Get the HouseholdMember%s of the Household.
     131             :      */
     132         144 :     const std::vector<std::tuple<HouseholdMember, int>>& get_members() const
     133             :     {
     134         144 :         return m_household_member_list;
     135             :     }
     136             : 
     137             :     /**
     138             :      * @brief Adds a number of the same HouseholdMember%s to a Household.
     139             :      * @param[in] household_member A HouseholdMember.
     140             :      * @param[in] number_of_members The amount of members to be added.
     141             :      */
     142             :     void add_members(HouseholdMember household_member, int number_of_members);
     143             : 
     144             : private:
     145             :     int m_number_of_members; ///< Total number of Person%s in the Household.
     146             :     int m_space_per_member; ///< Space per Person in cubic meters (constant maximal capacity over time).
     147             :     std::vector<std::tuple<HouseholdMember, int>> m_household_member_list; /**< HouseholdMember%s of the Household and 
     148             :     the respective number of Person%s.*/
     149             : };
     150             : 
     151             : /**
     152             :  * @brief A HouseholdGroup represented by different Household%s.
     153             :  * The group may contain multiple Household%s of the same type.
     154             :  */
     155             : class HouseholdGroup
     156             : {
     157             : public:
     158             :     /**
     159             :      * @brief Constructs a new HouseholdGroup.
     160             :      */
     161           9 :     HouseholdGroup()
     162           9 :         : m_household_list()
     163             :     {
     164           9 :         m_number_of_households = 0;
     165           9 :     }
     166             : 
     167             :     /**
     168             :      * @brief Returns the number of Household%s in the HouseholdGroup.
     169             :      */
     170             :     int get_total_number_of_households() const
     171             :     {
     172             :         return m_number_of_households;
     173             :     }
     174             : 
     175             :     /**
     176             :      * @brief Returns the Household%s of the HouseholdGroup.
     177             :      * @return A vector of tuples that contains the Houshold and the amount of times that Household is in the group.
     178             :      */
     179           9 :     const std::vector<std::tuple<Household, int>>& get_households() const
     180             :     {
     181           9 :         return m_household_list;
     182             :     }
     183             : 
     184             :     /**
     185             :      * @brief Adds a number of Household%s of the same kind, e.g.\ same members, to a HouseholdGroup.
     186             :      * @param[in] household A Household.
     187             :      * @param[in] number_of_households The amount of times that Household is in the group.
     188             :      */
     189             :     void add_households(Household household, int number_of_households);
     190             : 
     191             : private:
     192             :     int m_number_of_households; ///< Number of Household%s in this group.
     193             :     std::vector<std::tuple<Household, int>> m_household_list; /**< A list of types of Household%s and the amount of 
     194             :     times it is in the group.*/
     195             : };
     196             : 
     197             : /**
     198             :  * @brief Adds a specific Household to the Model.
     199             :  * Adds Person%s to the Model according to the age distribution of the HouseholdMember%s of the Household.
     200             :  * @param[in,out] model The Model to which the Household has to be added.
     201             :  * @param[in] household The Household to add to Model.
     202             :  */
     203             : void add_household_to_model(Model& model, const Household& household);
     204             : 
     205             : /**
     206             :  * @brief Adds Household%s from a HouseholdGroup to the Model.
     207             :  * @param[in,out] model The Model to which the group has to be added.
     208             :  * @param[in] household_group The HouseholdGroup to add.
     209             :  */
     210             : void add_household_group_to_model(Model& model, const HouseholdGroup& household_group);
     211             : 
     212             : } // namespace abm
     213             : } // namespace mio
     214             : 
     215             : #endif //MIO_ABM_HOUSEHOLD_H

Generated by: LCOV version 1.14