Skip to content

Commit

Permalink
Fixed return 0 instead of Nan for cumulative thickness
Browse files Browse the repository at this point in the history
  • Loading branch information
Erik-Geo committed Sep 4, 2024
1 parent a8e396c commit af383e4
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 5 deletions.
5 changes: 3 additions & 2 deletions geost/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -860,7 +860,6 @@ def get_cumulative_layer_thickness(self, column: str, values: str | List[str]):
cumulative_thickness
)
cum_thickness = cum_thickness.unstack(level=column)
cum_thickness[cum_thickness.isna()] = 0
return cum_thickness

def get_layer_top(self, column: str, values: str | List[str]):
Expand Down Expand Up @@ -2150,14 +2149,16 @@ def get_cumulative_layer_thickness(
cum_thickness = self.data.get_cumulative_layer_thickness(column, values)

if include_in_header:
columns = [c + "_thickness" for c in cum_thickness.columns]
self.header.gdf.drop(
columns=[c + "_thickness" for c in cum_thickness.columns],
columns=columns,
errors="ignore",
inplace=True,
)
self.header = self.header.gdf.merge(
cum_thickness.add_suffix("_thickness"), on="nr", how="left"
)
self.header[columns] = self.header[columns].fillna(0)
else:
return cum_thickness

Expand Down
22 changes: 21 additions & 1 deletion tests/test_collections.py
Original file line number Diff line number Diff line change
Expand Up @@ -503,7 +503,7 @@ def test_to_csv(self, borehole_collection, tmp_path):

class TestBoreholeCollection:
@pytest.mark.unittest
def test_get_cumulative_layer_thickness(self, borehole_collection):
def test_get_cumulative_layer_thickness_multiple(self, borehole_collection):
borehole_collection.get_cumulative_layer_thickness(
"lith", ["Z", "K"], include_in_header=True
)
Expand All @@ -517,6 +517,26 @@ def test_get_cumulative_layer_thickness(self, borehole_collection):
borehole_collection.header["Z_thickness"], expected_sand_thickness
)

# Single query
borehole_collection.get_cumulative_layer_thickness(
"lith", "Z", include_in_header=True
)
assert_almost_equal(
borehole_collection.header["Z_thickness"], expected_sand_thickness
)

@pytest.mark.unittest
def test_get_cumulative_layer_thickness_single(self, borehole_collection):
expected_sand_thickness = [2.2, 0.0, 2.6, 0.5, 3.0]

# Single query
borehole_collection.get_cumulative_layer_thickness(
"lith", "Z", include_in_header=True
)
assert_almost_equal(
borehole_collection.header["Z_thickness"], expected_sand_thickness
)

@pytest.mark.unittest
def test_get_layer_top(self, borehole_collection):
borehole_collection.get_layer_top("lith", ["Z", "K"], include_in_header=True)
Expand Down
4 changes: 2 additions & 2 deletions tests/test_data_objects.py
Original file line number Diff line number Diff line change
Expand Up @@ -78,8 +78,8 @@ def test_get_cumulative_layer_thickness(self, borehole_data):

result = borehole_data.get_cumulative_layer_thickness("lith", ["Z", "K"])
expected_boreholes_returned = ["A", "B", "C", "D", "E"]
expected_sand_thickness = [2.2, 0.0, 2.6, 0.5, 3.0]
expected_clay_thickness = [2.0, 2.0, 2.9, 1.1, 0.0]
expected_sand_thickness = [2.2, np.nan, 2.6, 0.5, 3.0]
expected_clay_thickness = [2.0, 2.0, 2.9, 1.1, np.nan]

assert result.shape == (5, 2)
assert_array_equal(result.index, expected_boreholes_returned)
Expand Down

0 comments on commit af383e4

Please sign in to comment.