質問をし直しました(この質問のことわすれててもっかい質問してしまった
import numpy as np class NN: def __init__(self,): self.N1=None self.N2=None self.N3=None self.N4=None n=NN() class Relu: def __init__(self,inp): self.next=inp self.N=self.next.N self.mask = None def f(self,x): return np.maximum(0, x) def b(self,dout,eta): dout[self.mask] = 0 dx = dout self.next.b(dx,eta) class imput: def __init__(self,N): self.N=N def start(self,inp): return inp def b(): print('学習完了') class afine: def __init__(self,N,inp): self.N=N self.next=inp self.w = np.random.rand(self.next.N,N) * (2.0 /self.N) self.by = np.zeros(N) self.x = None self.dW = None self.db = None self.x = None def f(self, x): self.x = x return np.dot(self.x, self.w) + self.by def b(self,dout,eta): dx = np.dot(dout, self.w.T) self.dW = np.dot(self.x.T, dout) self.db = np.sum(dout, axis=0) self.w = self.w - eta*self.dW1 self.by = self.by - eta*self.db1 self.next.b(dx,eta) class output: def __init__(self,zz): self.next=zz def f(self,a): a_max=max(a) x = np.exp(a-a_max) u = np.sum(x) return x/u def loss(self,d,y,eta): batch_size = d.shape[0] if d.size == y.size: # 教師データがone-hot-vectorの場合 dx = (y - d) / batch_size else: dx = y.copy() dx[np.arange(batch_size), d] -= 1 dx = dx / batch_size print('aaaa',dx) self.next.b(dx,eta) """ =====パラメーター====== epoc=エピソード step=ステップ数 eta=学習率 """ eta=0.01 epoc=1000 step=2000 #imput= input型 # mx= ニューロン数 前の層 #output= input i=imput(10) m1=afine(20,i) r1=Relu(m1) m2=afine(20,r1) r2=Relu(m2) m3=afine(10,r2) o=output(m3) #start(何をインプットにするか) #mx.f(どのニューロン群を計算するか) #o.f(何番目のニューロン群を使う) zz=np.array([19,2,31,4,5,12,45,89,3,134]) n.N1=i.start(zz) n.N1=m1.f(n.N1) n.N1=r1.f(n.N1) n.N1=m2.f(n.N1) n.N1=r2.f(n.N1) n.N1=m3.f(n.N1) n.N1=o.f(n.N1) y=np.array([0,0,0,1,0,0,0,0,0,0]) #出力 出力 eta o.loss(n.N1,y,0.01)
出ているエラー
aaaa [-6.16850537e-07 -2.29795762e-07 -3.63282569e-06 9.99996975e-02
-5.69130311e-07 -9.93184016e-02 -5.90788309e-07 -2.76355247e-05
-6.25255035e-04 -2.27659394e-05]
ValueError Traceback (most recent call last)
<ipython-input-18-c435690bb523> in <module>
103 y=np.array([0,0,0,1,0,0,0,0,0,0])
104 #出力 出力 eta
--> 105 o.loss(n.N1,y,0.01)
<ipython-input-18-c435690bb523> in loss(self, d, y, eta)
66 dx = dx / batch_size
67 print('aaaa',dx)
---> 68 self.next.b(dx,eta)
69
70 """
<ipython-input-18-c435690bb523> in b(self, dout, eta)
43 def b(self,dout,eta):
44 dx = np.dot(dout, self.w.T)
---> 45 self.dW = np.dot(self.x.T, dout)
46 self.db = np.sum(dout, axis=0)
47 self.w = self.w - eta*self.dW1
<array_function internals> in dot(*args, **kwargs)
ValueError: shapes (20,) and (10,) not aligned: 20 (dim 0) != 10 (dim 0)
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。