2

Pythonでランダムフォレストを実装しようとしています。コードの実行中にこのエラーが発生しました。私はすでに から using に変換していましたfloat32float64:

x_arr = np.array(train_df, dtype='float64')

Traceback(most recent call last):
  File "C:\Python27\randomforest.py", line 67, in <module>     
    forest=forest.fit(x_array[0::,1::],x_array[0::,0])
  File "C:\Python27\lib\site-packages\sklearn\ensemble\forest.py", line 212, in fit
    X = check_array(X, dtype=DTYPE, accept_sparse="csc")   
  File "C:\Python27\lib\site-packages\sklearn\utils\validation.py", line 398, in check_array
    _assert_all_finite(array)
  File "C:\Python27\lib\site-packages\sklearn\utils\validation.py", line 54, in _assert_all_finite
    " or a value too large for %r." % X.dtype)
ValueError: Input contains NaN, infinity or a value too large for dtype('float32').  

誰か助けてください。

4

2 に答える 2

1

問題は、float64 dtype の設定に失敗していることではありません。エラーメッセージには次のように記載されています。

入力に ​​NaN、無限大、または dtype('float32') には大きすぎる値が含まれています。

したがって、最初にこれらの条件を確認してみてください。

assert not np.any(np.isnan(x_arr))
assert np.all(np.isfinite(x_arr))
assert np.all(x_arr <= finfo('float32').max)
assert np.all(x_arr >= finfo('float32').min)
于 2016-07-13T12:36:25.320 に答える
0

タイトルの質問がまだ答えられていないと感じたので、ここに来ました。オブジェクトに変換float32するfloat64には:numpy.ndarray

array32 = np.ndarray(shape=(2,2), dtype=np.float32, order='F')
print("Type of an object of 'array32': " + str(type(array32[0][0])))

# Convert to float64
array64 = array32.astype(np.float64)
print("Type of an object of 'array64': " + str(type(array64[0][0])))

# Convert back to float32
array32again = array64.astype(np.float32)
print("Type of an object of 'array32again': " + str(type(array32again[0][0])))

あなたに与えます:

Type of an object of 'array32': <class 'numpy.float32'>
Type of an object of 'array64': <class 'numpy.float64'>
Type of an object of 'array32again': <class 'numpy.float32'>
于 2017-08-22T16:14:13.177 に答える