[CI] Use latest RAPIDS; Pandas 2.0 compatibility fix (#10175)
* [CI] Update RAPIDS to latest stable * [CI] Use rapidsai stable channel; fix syntax errors in Dockerfile.gpu * Don't combine astype() with loc() * Work around https://github.com/dmlc/xgboost/issues/10181 * Fix formatting * Fix test --------- Co-authored-by: hcho3 <hcho3@users.noreply.github.com> Co-authored-by: Hyunsu Cho <chohyu01@cs.washington.edu>
This commit is contained in:
committed by
GitHub
parent
6e5c335cea
commit
2925cebdca
@@ -909,9 +909,19 @@ def _transform_cudf_df(
|
||||
enable_categorical: bool,
|
||||
) -> Tuple[ctypes.c_void_p, list, Optional[FeatureNames], Optional[FeatureTypes]]:
|
||||
try:
|
||||
from cudf.api.types import is_categorical_dtype
|
||||
from cudf.api.types import is_bool_dtype, is_categorical_dtype
|
||||
except ImportError:
|
||||
from cudf.utils.dtypes import is_categorical_dtype
|
||||
from pandas.api.types import is_bool_dtype
|
||||
|
||||
# Work around https://github.com/dmlc/xgboost/issues/10181
|
||||
if _is_cudf_ser(data):
|
||||
if is_bool_dtype(data.dtype):
|
||||
data = data.astype(np.uint8)
|
||||
else:
|
||||
data = data.astype(
|
||||
{col: np.uint8 for col in data.select_dtypes(include="bool")}
|
||||
)
|
||||
|
||||
if _is_cudf_ser(data):
|
||||
dtypes = [data.dtype]
|
||||
|
||||
@@ -429,8 +429,8 @@ def make_categorical(
|
||||
categories = np.arange(0, n_categories)
|
||||
for col in df.columns:
|
||||
if rng.binomial(1, cat_ratio, size=1)[0] == 1:
|
||||
df.loc[:, col] = df[col].astype("category")
|
||||
df.loc[:, col] = df[col].cat.set_categories(categories)
|
||||
df[col] = df[col].astype("category")
|
||||
df[col] = df[col].cat.set_categories(categories)
|
||||
|
||||
if sparsity > 0.0:
|
||||
for i in range(n_features):
|
||||
|
||||
Reference in New Issue
Block a user