Skip to content

Commit

Permalink
fix(proportion_female): Remove user interface
Browse files Browse the repository at this point in the history
Users thought that they could set proportion_female but it was hard-
coded to 0.5 on the back end. Now, it is back to just being a single
value that is hard coded to 0.5. Tests have also changed back to 0.5.
This partially reverts PR #543. And, was talked about in
NOAA-FIMS/seaside-chats#7 and partially addresses #638.
  • Loading branch information
kellijohnson-NOAA committed Jul 25, 2024
1 parent 7af5dc7 commit 577a68b
Show file tree
Hide file tree
Showing 8 changed files with 13 additions and 54 deletions.
2 changes: 0 additions & 2 deletions inst/include/interface/rcpp/rcpp_interface.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -411,11 +411,9 @@ RCPP_MODULE(fims) {
.field("nyears", &PopulationInterface::nyears)
.field("log_M", &PopulationInterface::log_M)
.field("log_init_naa", &PopulationInterface::log_init_naa)
.field("proportion_female", &PopulationInterface::proportion_female)
.field("ages", &PopulationInterface::ages)
.field("estimate_M", &PopulationInterface::estimate_M)
.field("estimate_init_naa", &PopulationInterface::estimate_initNAA)
.field("estimate_prop_female", &PopulationInterface::estimate_prop_female)
.method("evaluate", &PopulationInterface::evaluate)
.method("SetMaturity", &PopulationInterface::SetMaturity)
.method("SetGrowth", &PopulationInterface::SetGrowth)
Expand Down
9 changes: 0 additions & 9 deletions inst/include/interface/rcpp/rcpp_objects/rcpp_population.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -63,11 +63,8 @@ class PopulationInterface : public PopulationInterfaceBase {
Rcpp::NumericVector log_M; /**< log of the natural mortality of the stock*/
Rcpp::NumericVector log_init_naa; /**<log of the initial numbers at age*/
Rcpp::NumericVector ages; /**<vector of ages in the population; length nages*/
Rcpp::NumericVector proportion_female; /**<doule representing the proportion
of female individuals */
bool estimate_M; /**<whether parameter should be estimated*/
bool estimate_initNAA; /**<whether parameter should be estimated*/
bool estimate_prop_female; /**<whether proportion female should be estimated*/

PopulationInterface() : PopulationInterfaceBase() {}

Expand Down Expand Up @@ -147,12 +144,6 @@ class PopulationInterface : public PopulationInterfaceBase {
for (int i = 0; i < ages.size(); i++) {
population->ages[i] = this->ages[i];
}
for (int i = 0; i < proportion_female.size(); i++) {
population->proportion_female[i] = this->proportion_female[i];
if (estimate_prop_female) {
info->RegisterParameter(population->proportion_female[i]);
}
}

// add to Information
info->populations[population->id] = population;
Expand Down
20 changes: 10 additions & 10 deletions inst/include/population_dynamics/population/population.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,13 +40,15 @@ struct Population : public fims_model_object::FIMSObject<Type> {
size_t nages; /*!< total number of ages in the population*/
size_t nfleets; /*!< total number of fleets in the fishery*/

// constants
const Type proportion_female =
0.5; /*!< Sex proportion fixed at 50/50 for M1*/

// parameters are estimated; after initialize in create_model, push_back to
// parameter list - in information.hpp (same for initial F in fleet)
fims::Vector<Type>
log_init_naa; /*!< estimated parameter: log numbers at age*/
fims::Vector<Type> log_M; /*!< estimated parameter: log Natural Mortality*/
fims::Vector<Type>
proportion_female; /*!< estimated parameter: proportion female by age */

// Transformed values
fims::Vector<Type> M; /*!< transformed parameter: Natural Mortality*/
Expand Down Expand Up @@ -131,7 +133,6 @@ struct Population : public fims_model_object::FIMSObject<Type> {
mortality_F.resize(nyears * nages);
mortality_Z.resize(nyears * nages);
proportion_mature_at_age.resize((nyears + 1) * nages);
proportion_female.resize(nages);
weight_at_age.resize(nages);
unfished_numbers_at_age.resize((nyears + 1) * nages);
numbers_at_age.resize((nyears + 1) * nages);
Expand Down Expand Up @@ -170,7 +171,6 @@ struct Population : public fims_model_object::FIMSObject<Type> {
std::fill(proportion_mature_at_age.begin(), proportion_mature_at_age.end(),
0.0);
std::fill(mortality_Z.begin(), mortality_Z.end(), 0.0);
std::fill(proportion_female.begin(), proportion_female.end(), 0.5);

// Transformation Section
for (size_t age = 0; age < this->nages; age++) {
Expand Down Expand Up @@ -316,9 +316,9 @@ struct Population : public fims_model_object::FIMSObject<Type> {
*/
void CalculateSpawningBiomass(size_t i_age_year, size_t year, size_t age) {
this->spawning_biomass[year] +=
this->proportion_female[age] * this->numbers_at_age[i_age_year] *
this->proportion_female * this->numbers_at_age[i_age_year] *
this->proportion_mature_at_age[i_age_year] * this->weight_at_age[age];
POPULATION_LOG << " proportion female " << this->proportion_female[age]
POPULATION_LOG << " proportion female " << this->proportion_female
<< " "
<< " mature age " << age << " is "
<< this->proportion_mature_at_age[i_age_year] << " "
Expand All @@ -341,7 +341,7 @@ struct Population : public fims_model_object::FIMSObject<Type> {
void CalculateUnfishedSpawningBiomass(size_t i_age_year, size_t year,
size_t age) {
this->unfished_spawning_biomass[year] +=
this->proportion_female[age] *
this->proportion_female *
this->unfished_numbers_at_age[i_age_year] *
this->proportion_mature_at_age[i_age_year] * this->weight_at_age[age];
}
Expand All @@ -354,12 +354,12 @@ struct Population : public fims_model_object::FIMSObject<Type> {
Type CalculateSBPR0() {
std::vector<Type> numbers_spr(this->nages, 1.0);
Type phi_0 = 0.0;
phi_0 += numbers_spr[0] * this->proportion_female[0] *
phi_0 += numbers_spr[0] * this->proportion_female *
this->proportion_mature_at_age[0] *
this->growth->evaluate(ages[0]);
for (size_t a = 1; a < (this->nages - 1); a++) {
numbers_spr[a] = numbers_spr[a - 1] * fims_math::exp(-this->M[a]);
phi_0 += numbers_spr[a] * this->proportion_female[a] *
phi_0 += numbers_spr[a] * this->proportion_female *
this->proportion_mature_at_age[a] *
this->growth->evaluate(ages[a]);
}
Expand All @@ -368,7 +368,7 @@ struct Population : public fims_model_object::FIMSObject<Type> {
(numbers_spr[nages - 2] * fims_math::exp(-this->M[nages - 2])) /
(1 - fims_math::exp(-this->M[this->nages - 1]));
phi_0 += numbers_spr[this->nages - 1] *
this->proportion_female[this->nages - 1] *
this->proportion_female *
this->proportion_mature_at_age[this->nages - 1] *
this->growth->evaluate(ages[this->nages - 1]);
return phi_0;
Expand Down
4 changes: 2 additions & 2 deletions tests/gtest/test_population_B_and_SB.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ namespace
std::vector<double> test_SB(nyears + 1, 0);
std::vector<double> test_B(nyears + 1, 0);

test_SB[year] += population.numbers_at_age[i_age_year] * population.proportion_female[age] * population.proportion_mature_at_age[i_age_year] *
test_SB[year] += population.numbers_at_age[i_age_year] * population.proportion_female * population.proportion_mature_at_age[i_age_year] *
population.growth->evaluate(population.ages[age]);
test_B[year] += population.numbers_at_age[i_age_year] *
population.growth->evaluate(population.ages[age]);
Expand All @@ -40,7 +40,7 @@ namespace

std::vector<double> test_SSB(nyears + 1, 0);

test_SSB[nyears] += population.numbers_at_age[i_age_year] * population.proportion_female[age] *
test_SSB[nyears] += population.numbers_at_age[i_age_year] * population.proportion_female *
population.proportion_mature_at_age[i_age_year] *
population.growth->evaluate(population.ages[age]);

Expand Down
2 changes: 1 addition & 1 deletion tests/gtest/test_population_Unfished_Initial.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ namespace
population.CalculateUnfishedSpawningBiomass(i_age_year, year, age);

test_unfished_spawning_biomass[year] += population.proportion_mature_at_age[i_age_year] *
population.proportion_female[age] *
population.proportion_female *
test_unfished_numbers_at_age[i_age_year] *
population.growth->evaluate(population.ages[age]);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@ namespace
EXPECT_EQ(population.unfished_spawning_biomass.size(), (nyears + 1));
EXPECT_EQ(population.spawning_biomass.size(), nyears + 1);
EXPECT_EQ(population.log_init_naa.size(), nages);
EXPECT_EQ(population.proportion_female.size(), nages);
EXPECT_EQ(population.log_M.size(), nyears * nages);
EXPECT_EQ(population.M.size(), nyears * nages);
}
Expand Down Expand Up @@ -84,13 +83,6 @@ namespace
}
EXPECT_EQ(population.M.size(), nyears * nages);

// Test population.proportion_female
fims::Vector<double> p_female(nages, 0.5);
for(int i = 0; i < nages; i++)
{
EXPECT_EQ(population.proportion_female[i], p_female[i]);
}

// Test population.fleet->Fmort
// fmort and logfmort are vectors of length year
fims::Vector<double> Fmort(nfleets * nyears, 0);
Expand Down
18 changes: 0 additions & 18 deletions tests/gtest/test_population_test_fixture.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -110,15 +110,6 @@ class PopulationEvaluateTestFixture : public testing::Test {
population.log_init_naa[i] = log_naa_distribution(generator);
}

// prop_female
double prop_female_min = 0.1;
double prop_female_max = 0.9;
std::uniform_real_distribution<double> prop_female_distribution(
prop_female_min, prop_female_max);
for (int i = 0; i < nages; i++) {
population.proportion_female[i] = prop_female_distribution(generator);
}

// log_M
double log_M_min = fims_math::log(0.1);
double log_M_max = fims_math::log(0.3);
Expand Down Expand Up @@ -260,15 +251,6 @@ class PopulationPrepareTestFixture : public testing::Test {
population.log_init_naa[i] = log_naa_distribution(generator);
}

// prop_female
double prop_female_min = 0.1;
double prop_female_max = 0.9;
std::uniform_real_distribution<double> prop_female_distribution(
prop_female_min, prop_female_max);
for (int i = 0; i < nages; i++) {
population.proportion_female[i] = prop_female_distribution(generator);
}

// log_M
double log_M_min = fims_math::log(0.1);
double log_M_max = fims_math::log(0.3);
Expand Down
4 changes: 0 additions & 4 deletions tests/testthat/test-rcpp-population-interface.R
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,12 @@ test_that("Population input settings work as expected", {
population$nfleets <- 2
population$nseasons <- 1
population$nyears <- nyears
population$proportion_female <- rep(0.5, nages)
population$estimate_prop_female <- FALSE

expect_equal(population$get_id(), 1)
expect_equal(population$log_M, rep(-1, nyears * nages))
expect_false(population$estimate_M)
expect_equal(population$log_init_naa, rep(0, nages))
expect_true(population$estimate_init_naa)
expect_false(population$estimate_prop_female)
expect_equal(population$proportion_female, rep(0.5, nages))

clear()
})

0 comments on commit 577a68b

Please sign in to comment.