Skip to content

Commit

Permalink
Merge pull request MathCancer#307 from drbergman/fix-internalized-sub…
Browse files Browse the repository at this point in the history
…strates

Preserve internalized substrates and custom data in `Cell::convert_to_cell_definition` function
  • Loading branch information
MathCancer authored Oct 15, 2024
2 parents f15cefe + e58c64d commit ee154ee
Showing 1 changed file with 17 additions and 4 deletions.
21 changes: 17 additions & 4 deletions core/PhysiCell_cell.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1127,6 +1127,8 @@ void Cell::convert_to_cell_definition( Cell_Definition& cd )
{
Volume cell_volume = phenotype.volume;
Geometry cell_geometry = phenotype.geometry;
Molecular cell_molecular = phenotype.molecular;
Custom_Cell_Data cell_custom_data = custom_data;
// use the cell defaults;
type = cd.type;
type_name = cd.name;
Expand All @@ -1145,6 +1147,18 @@ void Cell::convert_to_cell_definition( Cell_Definition& cd )
phenotype.volume.relative_rupture_volume = cd.phenotype.volume.relative_rupture_volume;

phenotype.geometry = cell_geometry; // leave the geometry alone
phenotype.molecular.internalized_total_substrates = cell_molecular.internalized_total_substrates;

for( int nn = 0 ; nn < custom_data.variables.size() ; nn++ )
{
if( custom_data.variables[nn].conserved_quantity == true )
{ custom_data.variables[nn].value = cell_custom_data.variables[nn].value; }
}
for( int nn = 0 ; nn < custom_data.vector_variables.size() ; nn++ )
{
if( custom_data.vector_variables[nn].conserved_quantity == true )
{ custom_data.vector_variables[nn].value = cell_custom_data.vector_variables[nn].value; }
}
/* things no longer done here:
// assign_orientation(); // not necesary since the this->state is unchanged
// Basic_Agent::set_total_volume(volume); // not necessary since the volume is unchanged
Expand Down Expand Up @@ -2004,7 +2018,7 @@ Cell_Definition* initialize_cell_definition_from_pugixml( pugi::xml_node cd_node
// if we found something to inherit from, then do it!
if( pParent != NULL )
{
std::cout << "\tCopying from type " << pParent->name << " ... " << std::endl;
// this is where we copy data from the first cell definition, including custom_data
*pCD = *pParent;

// but recover the name and ID (type)
Expand Down Expand Up @@ -2067,7 +2081,6 @@ Cell_Definition* initialize_cell_definition_from_pugixml( pugi::xml_node cd_node

}


// sync to microenvironment
pCD->pMicroenvironment = NULL;
if( BioFVM::get_default_microenvironment() != NULL )
Expand Down Expand Up @@ -3193,6 +3206,7 @@ Cell_Definition* initialize_cell_definition_from_pugixml( pugi::xml_node cd_node
{ pCD->custom_data.add_variable( name, units, values[0] ); }

n = pCD->custom_data.find_variable_index( name );
pCD->custom_data.variables[n].conserved_quantity = conserved;
}
// or vector
else
Expand All @@ -3207,10 +3221,10 @@ Cell_Definition* initialize_cell_definition_from_pugixml( pugi::xml_node cd_node
{ pCD->custom_data.add_vector_variable( name, units, values ); }

n = pCD->custom_data.find_vector_variable_index( name );
pCD->custom_data.vector_variables[n].conserved_quantity = conserved;
}

// set conserved attribute

node1 = node1.next_sibling();
}

Expand Down Expand Up @@ -3514,4 +3528,3 @@ int find_cell_definition_index( int search_type )


};

0 comments on commit ee154ee

Please sign in to comment.