2017-08-15 31 views
1

私はテンソルフローコードをコンパイルしようとすると、新しいPythonユーザーと新しいスタックオーバーフローを経験しました。私はここからいくつかの助けを得るために、事前に皆に感謝!"PIL"エラーについてNameError:name 'PIL'が定義されていません

そして、これは私のコンパイル結果である:ここでは

D:\Python\Anaconda2\envs\tensorflow\python.exe D:/Python/pycharm_project/test/mnist_chuji 
Traceback (most recent call last): 
    File "D:/Python/pycharm_project/test/mnist_chuji", line 52, in <module> 
     DisplayArray(u_init, rng=[-0.1, 0.1]) 
    File "D:/Python/pycharm_project/test/mnist_chuji", line 15, in DisplayArray 
     PIL.Image.fromarray(a).save(f, fmt) 
NameError: name 'PIL' is not defined 

Process finished with exit code 1 

は私のコードである、と私は私のエラーは、あなたが簡単にそれを見つける作るために起こった行番号にマーク:

#导入模拟仿真需要的库 
import tensorflow as tf 
import numpy as np 

#导入可视化需要的库 
from PIL import Image 
from io import StringIO #python3 使用了io代替了sStringIO 
from IPython.display import clear_output, Image, display 

def DisplayArray(a, fmt='jpeg', rng=[0,1]): 
    """Display an array as a picture.""" 
    a = (a - rng[0])/float(rng[1] - rng[0])*255 
    a = np.uint8(np.clip(a, 0, 255)) 
    f = StringIO() 
    PIL.Image.fromarray(a).save(f, fmt) #line 15 
    display(Image(data=f.getvalue())) 

sess = tf.InteractiveSession() 

def make_kernel(a): 
    """Transform a 2D array into a convolution kernel""" 
    a = np.asarray(a) 
    a = a.reshape(list(a.shape) + [1,1]) 
    return tf.constant(a, dtype=1) 

def simple_conv(x, k): 
    """A simplified 2D convolution operation""" 
    x = tf.expand_dims(tf.expand_dims(x, 0), -1) 
    y = tf.nn.depthwise_conv2d(x, k, [1, 1, 1, 1], padding='SAME') 
    return y[0, :, :, 0] 

def laplace(x): 
    """Compute the 2D laplacian of an array""" 
    laplace_k = make_kernel([[0.5, 1.0, 0.5], 
          [1.0, -6., 1.0], 
          [0.5, 1.0, 0.5]]) 
    return simple_conv(x, laplace_k) 

N = 500 

# Initial Conditions -- some rain drops hit a pond 

# Set everything to zero 
u_init = np.zeros([N, N], dtype="float32") 
ut_init = np.zeros([N, N], dtype="float32") 

# Some rain drops hit a pond at random points 
for n in range(40): 
    a,b = np.random.randint(0, N, 2) 
    u_init[a,b] = np.random.uniform() 

DisplayArray(u_init, rng=[-0.1, 0.1]) #line 52 

# Parameters: 
# eps -- time resolution 
# damping -- wave damping 
eps = tf.placeholder(tf.float32, shape=()) 
damping = tf.placeholder(tf.float32, shape=()) 

# Create variables for simulation state 
U = tf.Variable(u_init) 
Ut = tf.Variable(ut_init) 

# Discretized PDE update rules 
U_ = U + eps * Ut 
Ut_ = Ut + eps * (laplace(U) - damping * Ut) 

# Operation to update the state 
step = tf.group(
    U.assign(U_), 
    Ut.assign(Ut_)) 

# Initialize state to initial conditions 
tf.initialize_all_variables().run() 

# Run 1000 steps of PDE 
for i in range(1000): 
    # Step simulation 
    step.run({eps: 0.03, damping: 0.04}) 
    # Visualize every 50 steps 
    if i % 50 == 0: 
    clear_output() 
    DisplayArray(U.eval(), rng=[-0.1, 0.1]) 

を私は持っています私のtensorflow環境(python 3.5.2)に枕をインストールしてください。

皆さんありがとうございます!

+1

[mcve]を作成する方法をご確認ください – cat

答えて

1

ImagePILからインポートされましたが、PIL自体はインポートされていないため、Image.fromarrayを使用してください。

+0

ありがとうございます!私はあなたのソリューションを試してみましたが、私に新しいエラーを返します:AttributeError:型オブジェクト 'Image'に 'fromarray'属性がありません。それはどういう意味ですか... –

+0

@EricKani私の 'python2'と' python3'の両方に 'PIL.Image.fromarray'があるので、わかりません。ドキュメントを調べたり、PILバージョンをアップグレードしたり、新しい質問をしてください。 – cat

関連する問題