質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CUDA

CUDAは並列計算プラットフォームであり、Nvidia GPU(Graphics Processing Units)向けのプログラミングモデルです。CUDAは様々なプログラミング言語、ライブラリ、APIを通してNvidiaにインターフェイスを提供します。

CPU

CPUは、コンピュータの中心となる処理装置(プロセッサ)で中央処理装置とも呼ばれています。プログラム演算や数値計算、その他の演算ユニットをコントロール。スマホやPCによって内蔵されているCPUは異なりますが、処理性能が早いほど良いとされています。

PyTorch

PyTorchは、オープンソースのPython向けの機械学習ライブラリ。Facebookの人工知能研究グループが開発を主導しています。強力なGPUサポートを備えたテンソル計算、テープベースの自動微分による柔軟なニューラルネットワークの記述が可能です。

機械学習

機械学習は、データからパターンを自動的に発見し、そこから知能的な判断を下すためのコンピューターアルゴリズムを指します。人工知能における課題のひとつです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1152閲覧

pytorch Variableレイヤーをgpuに指定できません

Flan.

総合スコア123

CUDA

CUDAは並列計算プラットフォームであり、Nvidia GPU(Graphics Processing Units)向けのプログラミングモデルです。CUDAは様々なプログラミング言語、ライブラリ、APIを通してNvidiaにインターフェイスを提供します。

CPU

CPUは、コンピュータの中心となる処理装置(プロセッサ)で中央処理装置とも呼ばれています。プログラム演算や数値計算、その他の演算ユニットをコントロール。スマホやPCによって内蔵されているCPUは異なりますが、処理性能が早いほど良いとされています。

PyTorch

PyTorchは、オープンソースのPython向けの機械学習ライブラリ。Facebookの人工知能研究グループが開発を主導しています。強力なGPUサポートを備えたテンソル計算、テープベースの自動微分による柔軟なニューラルネットワークの記述が可能です。

機械学習

機械学習は、データからパターンを自動的に発見し、そこから知能的な判断を下すためのコンピューターアルゴリズムを指します。人工知能における課題のひとつです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/06/07 00:41

編集2020/06/07 01:54

.to(cuda)で指定しているのですが うまくいきません
cpuにあるとエラーがでます

試したこと
試しにもう一度def gpu(self): で二重に指定したのですがうまくいきません
乱数をに入れてみたり 分けて実行もしても同じエラーが出たので
self.tril_maskレイヤーが原因だと思います

なぜこうなるのかまったくわからない わかる人教えてください

     モデル定義 self.L = nn.Linear(self.hidden_size, num_outputs ** 2) nn.init.kaiming_normal_(self.L.weight, a=0, mode='fan_in', nonlinearity='leaky_relu') self.tril_mask = Variable(torch.tril(torch.ones(num_outputs, num_outputs), diagonal=-1).unsqueeze(0)) self.diag_mask = Variable(torch.diag(torch.diag(torch.ones(num_outputs, num_outputs))).unsqueeze(0))        略 L1=self.diag_mask.expand_as(L) L2=torch.exp(L) L3 = L * self.tril_mask.expand_as(L) L=L3 + L2 * L1 P = torch.bmm(L, L.transpose(2, 1)) print(self.tril_mask.is_cuda)        略        return output def gpu(self): self.tril_mask.to('cuda:0') criterion = nn.MSELoss() targetQN = mainQN mainQN.gpu()#!!!!!! targetQN.eval() mainQN.eval()
--------------------------------------------------------------------------- RuntimeError Traceback (most recent call last) <ipython-input-1-87610d0531cc> in <module> 401 total_reward_vec = np.hstack((total_reward_vec[1:], episode_reward)) # 報酬を記録 402 if batch_size<len(memory.buffer*4): --> 403 memory_TDerror.update_TDerror(gamma,multireward_steps) 404 for _ in range(t): 405 trin.pioritized_experience_replay(batch_size, gamma,step=episode,state_size=state_,action_size=acthon,multireward_steps=multireward_steps) <ipython-input-1-87610d0531cc> in update_TDerror(self, gamma, multireward_steps) 304 next_state=memory.buffer[i][0] 305 target = memory.buffer[i][2] + (gamma**multireward_steps) * targetQN.forward(next_state,"net_v")[0] --> 306 self.buffer[i] =target - mainQN.forward(inpp,"net_q")[0] 307 308 <ipython-input-1-87610d0531cc> in forward(self, inputs, net) 194 L1=self.diag_mask.expand_as(L) 195 L2=torch.exp(L) --> 196 L3 = L * self.tril_mask.expand_as(L) 197 L=L3 + L2 * L1 198 P = torch.bmm(L, L.transpose(2, 1)) ~\Anaconda3\envs\pyflan\lib\site-packages\apex\amp\wrap.py in wrapper(*args, **kwargs) 56 args, 57 kwargs) ---> 58 return orig_fn(*new_args, **kwargs) 59 else: 60 raise NotImplementedError('Do not know how to handle ' + RuntimeError: expected device cuda:0 but got device cpu

追記 is_cuda という物を使って調べた結果 False と出ました
.to(cuda:0)をforでやってみましたが(やけくそ)結果同じ

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

Variableを消したらうまくいきました

投稿2020/06/07 02:20

Flan.

総合スコア123

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問