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

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

新規登録して質問してみよう
ただいま回答率
85.49%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

0回答

245閲覧

Deeplearning による画像認識を行いたい

tasuke

総合スコア53

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2018/10/18 01:07

現在、mnistのデータを使用し、DeepLearningの勉強をしています。自分で取り込んだ画像に記された数字が何かを当てるプログラムを作製しようと考え、以下のコードを作成しました。

python

1from sklearn.datasets import fetch_mldata 2 3mnist = fetch_mldata('MNIST original', data_home=".") 4X = mnist.data / 255 5y = mnist.target 6import matplotlib.pyplot as plt 7 8 9plt.imshow(X[0].reshape(28, 28), cmap='gray') 10print("This is {:.0f}".format(y[0])) 11import torch 12from torch.utils.data import TensorDataset, DataLoader 13 14from sklearn.model_selection import train_test_split 15X_train, X_test, y_train, y_test = train_test_split( 16 X, y, test_size=1/7, random_state=0) 17 18X_train = torch.Tensor(X_train) 19X_test = torch.Tensor(X_test) 20y_train = torch.LongTensor(y_train) 21y_test = torch.LongTensor(y_test) 22 23ds_train = TensorDataset(X_train, y_train) 24ds_test = TensorDataset(X_test, y_test) 25 26loader_train = DataLoader(ds_train, batch_size=64, shuffle=True) 27loader_test = DataLoader(ds_test, batch_size=64, shuffle=False) 28 29from torch import nn 30 31model = nn.Sequential() 32model.add_module('fc1', nn.Linear(28*28, 100)) 33model.add_module('relu1', nn.ReLU()) 34model.add_module('fc2', nn.Linear(100, 100)) 35model.add_module('relu2', nn.ReLU()) 36model.add_module('fc3', nn.Linear(100, 10)) 37 38print(model) 39from torch import optim 40 41loss_fn = nn.CrossEntropyLoss() 42 43optimizer = optim.Adam(model.parameters(), lr=0.01) 44 45from torch.autograd import Variable 46 47def train(epoch): 48 model.train() 49 for data, target in loader_train: 50 data, target = Variable(data), Variable(target) 51 optimizer.zero_grad() 52 output = model(data) 53 loss = loss_fn(output, target) 54 loss.backward() 55 optimizer.step() 56 print("epoch{}:end\n".format(epoch)) 57 58def test(): 59 model.eval() 60 correct = 0 61 for data, target in loader_test: 62 data, target = Variable(data), Variable(target) 63 output = model(data) 64 pred = output.data.max(1, keepdim=True)[1] 65 correct += pred.eq(target.data.view_as(pred)).sum() 66 data_num = len(loader_test.dataset) 67 print('\n answer: {}/{} ({:.0f}%)\n'.format(correct,data_num, 100. * correct / data_num)) 68 69for epoch in range(3): 70 train(epoch) 71 72test() 73import tensorflow as tf 74img_r = tf.read_file("8.png") 75read_image = tf.image.decode_image(img_r, channels=3) 76data = Variable(read_image) 77output = model(data) 78pred = output.data.max(0, keepdim=True)[1] 79print("I think {}".format(pred)) 80コード

すると、以下のエラーが表示されてしまいました。
variable data has o be a tensor, but got Tensor

初心者である私にはtensorとTensorの違いが分かりませんでした。エラー内容について教えていただきたいです。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問