Skip to content

Commit

Permalink
Fix check for zero with columns in __floordiv__ and __mod__
Browse files Browse the repository at this point in the history
Closes #5938.
  • Loading branch information
wence- committed Nov 8, 2022
1 parent e3f50dc commit 77d94d1
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 3 deletions.
4 changes: 1 addition & 3 deletions python/cudf/cudf/core/column/numerical.py
Original file line number Diff line number Diff line change
Expand Up @@ -229,9 +229,7 @@ def _binaryop(self, other: ColumnBinaryOperand, op: str) -> ColumnBase:
(np.isscalar(tmp) or isinstance(tmp, cudf.Scalar))
and (0 == tmp)
)
or (
(isinstance(tmp, NumericalColumn)) and (0.0 in tmp)
)
or ((isinstance(tmp, NumericalColumn)) and (0 in tmp))
)
):
out_dtype = cudf.dtype("float64")
Expand Down
11 changes: 11 additions & 0 deletions python/cudf/cudf/tests/test_binops.py
Original file line number Diff line number Diff line change
Expand Up @@ -892,6 +892,17 @@ def test_floordiv_zero_float64(series_dtype, scalar_dtype):
)


@pytest.mark.parametrize(
"dtype",
(np.bool_, np.int8, np.uint8, np.int64, np.uint64, np.float32, np.float64),
)
def test_rmod_zero_nan(dtype):
sr = pd.Series([1, 1, 0], dtype=dtype)
cr = cudf.from_pandas(sr)
utils.assert_eq(1 % sr, 1 % cr)
utils.assert_eq(1 % cr, cudf.Series([0, 0, None], dtype=np.float64))


def test_series_misc_binop():
pds = pd.Series([1, 2, 4], name="abc xyz")
gds = cudf.Series([1, 2, 4], name="abc xyz")
Expand Down

0 comments on commit 77d94d1

Please sign in to comment.