當前位置: 首頁>>代碼示例>>Python>>正文


Python PatchViewer.clear方法代碼示例

本文整理匯總了Python中pylearn2.gui.patch_viewer.PatchViewer.clear方法的典型用法代碼示例。如果您正苦於以下問題:Python PatchViewer.clear方法的具體用法?Python PatchViewer.clear怎麽用?Python PatchViewer.clear使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pylearn2.gui.patch_viewer.PatchViewer的用法示例。


在下文中一共展示了PatchViewer.clear方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: GenerateAndSave

# 需要導入模塊: from pylearn2.gui.patch_viewer import PatchViewer [as 別名]
# 或者: from pylearn2.gui.patch_viewer.PatchViewer import clear [as 別名]
class GenerateAndSave(TrainExtension):
    """
    Keeps track of what the generator in a (vanilla) GAN returns for a
    particular set of noise values.
    """

    def __init__(self, generator, save_prefix, batch_size=20, grid_shape=(5, 4)):
        assert isinstance(generator, Generator)

        self.batch_sym = T.matrix('generate_batch')
        self.generate_f = theano.function([self.batch_sym],
                                          generator.dropout_fprop(self.batch_sym)[0])

        self.batch = generator.get_noise(batch_size).eval()
        self.save_prefix = save_prefix
        self.patch_viewer = PatchViewer(grid_shape=grid_shape, patch_shape=(32, 32),
                                        is_color=True)

    def on_monitor(self, model, dataset, algorithm):
        samples = self.generate_f(self.batch).swapaxes(0, 3)

        self.patch_viewer.clear()
        for sample in samples:
            self.patch_viewer.add_patch(sample, rescale=True)

        fname = self.save_prefix + '.%05i.png' % model.monitor.get_epochs_seen()
        self.patch_viewer.save(fname)
開發者ID:HyoungWooPark,項目名稱:adversarial,代碼行數:29,代碼來源:train_extensions.py

示例2: plot

# 需要導入模塊: from pylearn2.gui.patch_viewer import PatchViewer [as 別名]
# 或者: from pylearn2.gui.patch_viewer.PatchViewer import clear [as 別名]
def plot(w):

    nblocks = int(model.n_g / model.sparse_gmask.bw_g)
    filters_per_block = model.sparse_gmask.bw_g * model.sparse_hmask.bw_h

    block_viewer = PatchViewer((model.sparse_gmask.bw_g, model.sparse_hmask.bw_h),
                               (opts.height, opts.width),
                               is_color = opts.color,
                               pad=(2,2))

    chan_viewer = PatchViewer(get_dims(nblocks),
                              (block_viewer.image.shape[0],
                              block_viewer.image.shape[1]),
                              is_color = opts.color,
                              pad=(5,5))

    main_viewer = PatchViewer(get_dims(nplots),
                              (chan_viewer.image.shape[0],
                               chan_viewer.image.shape[1]),
                              is_color = opts.color,
                              pad=(10,10))

    topo_shape = [opts.height, opts.width, opts.chans]
    view_converter = DefaultViewConverter(topo_shape)

    if opts.splitblocks:
        os.makedirs('filters/')

    for chan_i in xrange(nplots):

        viewer_dims = slice(0, None) if opts.color else chan_i

        for bidx in xrange(nblocks):

            for fidx in xrange(filters_per_block):
                fi = bidx * filters_per_block + fidx
                topo_view = view_converter.design_mat_to_topo_view(w[fi:fi+1,:])
                try:
                    block_viewer.add_patch(topo_view[0,:,:,viewer_dims])
                except:
                    import pdb; pdb.set_trace()

            if opts.splitblocks:
                pl.imshow(block_viewer.image, interpolation='nearest')
                pl.axis('off')
                pl.title('Wv - block %i, chan %i' % (bidx, chan_i))
                pl.savefig('filters/filters_chan%i_block%i.png' % (bidx, chan_i))

            chan_viewer.add_patch(block_viewer.image[:,:,viewer_dims] - 0.5)
            block_viewer.clear()

        main_viewer.add_patch(chan_viewer.image[:,:,viewer_dims] - 0.5)
        chan_viewer.clear()

    return copy.copy(main_viewer.image)
開發者ID:gdesjardins,項目名稱:hossrbm_public,代碼行數:57,代碼來源:show_weights_linear.py

示例3: xrange

# 需要導入模塊: from pylearn2.gui.patch_viewer import PatchViewer [as 別名]
# 或者: from pylearn2.gui.patch_viewer.PatchViewer import clear [as 別名]
        else: 
            new_w = w_di
    else:
        new_w = numpy.zeros((len(w_di), opts.height * opts.width)) if di else w_di

    for fi in xrange(len(w_di)):

        if opts.k != -1:
            # build "new_w" as a linear combination of "strongest" filters in layer below
            if di > 0:
                temp.fill(0.)
                idx = numpy.argsort(w_di[fi])[-opts.k:]
                for fi_m1 in idx:
                    new_w[fi:fi+1] += w_di[fi, fi_m1] * prev_w[fi_m1:fi_m1+1,:]
                #for fi_m1 in xrange(len(w_di[fi])):
            else:
                temp = w_di[fi:fi+1,:]

        topo_view = view_converter.design_mat_to_topo_view(new_w[fi:fi+1])
        block_viewer.add_patch(topo_view[0])

    main_viewer.add_patch(block_viewer.image[:,:,0] - 0.5)
    block_viewer.clear()
    
    prev_w = new_w

pl.imshow(main_viewer.image, interpolation=None)
pl.axis('off');
pl.savefig('weights.png')
pl.show()
開發者ID:gdesjardins,項目名稱:DBM,代碼行數:32,代碼來源:show_weights.py

示例4: make_viewer

# 需要導入模塊: from pylearn2.gui.patch_viewer import PatchViewer [as 別名]
# 或者: from pylearn2.gui.patch_viewer.PatchViewer import clear [as 別名]
    posw[posw < 0] = 0.
    probs = posw / numpy.max(posw, axis=1)[:, None]
    r = numpy.random.random(probs.shape)
    pos_w1 = numpy.dot(posw * (probs > r), W[0])

    # negative weights
    negw = copy.copy(-W[1])
    negw[negw < 0] = 0.
    probs = negw / numpy.max(negw, axis=1)[:, None]
    r = numpy.random.random(probs.shape)
    neg_w1 = numpy.dot(-negw * (probs > r), W[0])

    block_viewer = make_viewer(
            pos_w1 + neg_w1,
            get_dims(max_filters),
            (opts.height, opts.width))

    main_viewer.add_patch(block_viewer.image[:,:,0] - 0.5)


    pl.imshow(main_viewer.image, interpolation=None)
    pl.axis('off');
    pl.savefig('weights.png')
    if k == 0:
        pl.show()
    else:
        pl.draw()

    block_viewer.clear()
    main_viewer.clear()
開發者ID:gdesjardins,項目名稱:DBM,代碼行數:32,代碼來源:animate_weights.py


注:本文中的pylearn2.gui.patch_viewer.PatchViewer.clear方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。