Google把自家生成图片的技术 Inceptionism 开源化,称之为 Deep Dream ,一个原本用来将图片分类的AI,让我们看到不一样的世界~在把一张图片喂入之后,选择某一层神经网路(Google 的神经网luo有 10-30 层)进行重复处理的次数和变形的程度,就能获得一张非常后现代的「画作」。
1)下载模型,解压。
下载模型,解压
2)加载预训练的模型,训练。

#coding=utf-8
import tensorflow as tf
import numpy as np
import cv2
inception_model = 'tensorflow_inception_graph.pb'
# 加载inception模型
graph = tf.Graph()
sess = tf.InteractiveSession(graph=graph)X = tf.placeholder(np.float32, name='input')
with tf.gfile.FastGFile(inception_model, 'rb') as f:graph_def = tf.GraphDef()graph_def.ParseFromString(f.read())
imagenet_mean = 117.0
preprocessed = tf.expand_dims(X-imagenet_mean, 0)
tf.import_graph_def(graph_def, {'input':preprocessed})layers = [op.name for op in graph.get_operations() if op.type=='Conv2D' and 'import/' in op.name]
feature_nums = [int(graph.get_tensor_by_name(name+':0').get_shape()[-1]) for name in layers]print('layers:', len(layers))   # 59
print('feature:', sum(feature_nums))  # 7548# deep dream
def deep_dream(obj, img_noise=np.random.uniform(size=(224,224,3)) + 100.0, iter_n=10, step=1.5, octave_n=4, octave_scale=1.4):score = tf.reduce_mean(obj)gradi = tf.gradients(score, X)[0]img = img_noiseoctaves = []def tffunc(*argtypes):placeholders = list(map(tf.placeholder, argtypes))def wrap(f):out = f(*placeholders)def wrapper(*args, **kw):return out.eval(dict(zip(placeholders, args)), session=kw.get('session'))return wrapperreturn wrapdef resize(img, size):img = tf.expand_dims(img, 0)return tf.image.resize_bilinear(img, size)[0,:,:,:]resize = tffunc(np.float32, np.int32)(resize)for _ in range(octave_n-1):hw = img.shape[:2]lo = resize(img, np.int32(np.float32(hw)/octave_scale))hi = img-resize(lo, hw)img = looctaves.append(hi)def calc_grad_tiled(img, t_grad, tile_size=512):sz = tile_sizeh, w = img.shape[:2]sx, sy = np.random.randint(sz, size=2)img_shift = np.roll(np.roll(img, sx, 1), sy, 0)grad = np.zeros_like(img)for y in range(0, max(h-sz//2, sz),sz):for x in range(0, max(w-sz//2, sz),sz):sub = img_shift[y:y+sz,x:x+sz]g = sess.run(t_grad, {X:sub})grad[y:y+sz,x:x+sz] = greturn np.roll(np.roll(grad, -sx, 1), -sy, 0)   for octave in range(octave_n):if octave>0:hi = octaves[-octave]img = resize(img, hi.shape[:2])+hifor _ in range(iter_n):g = calc_grad_tiled(img, gradi)img += g*(step / (np.abs(g).mean()+1e-7))# 保存图像output_file = 'output' + str(octave+1) + '.jpg'cv2.imwrite(output_file, img)print(output_file)# 加载输入图像
input_img = cv2.imread('input.jpg')
input_img = np.float32(input_img)# 选择层
layer = 'mixed4c'deep_dream(tf.square(graph.get_tensor_by_name("import/%s:0"%layer)), input_img)

tensorflow练习8:实现Google的Deep Dream相关推荐

  1. 近期风靡互联网的Deep Dream人工智能图像识别软件

    code: https://github.com/google/deepdream/blob/master/dream.ipynb 声明:本译文包含六篇以上原外文内容,现汇合一处,附有大量的链接.实际 ...

  2. TensorFlow学习笔记--Deep Dream模型

    零.目标 Deep Dream是谷歌推出的一个有意思的技术.在训练好的CNN上,设定几个参数就可以生成一张图象.具体目标是: 了解Deep Dream基本原理 掌握实现生成Deep Dream 模型 ...

  3. TensorFlow实现Deep Dream

    Deep Dream是Google公司在2015年公布的一项有趣的技术.在训练好的卷积神经网络中,只需要设定几个参数,就可以通过这项技术生成一张图像. 假设输入网络的图像为x,网络输出的各个类别的概率 ...

  4. (tensorflow学习) Deep Dream原理及实现

    Deep Dream生成的图像 算法原理 卷积神经网络,我们输入一张图像后经过各种卷积池化等操作,最后分类出图片属于哪个类别. 可见卷积网络能提取图像中的相应特征.如图各个卷积层,如Conv1提取ed ...

  5. Tensorflow入门(10)——Deep Dream

    一.模型 1.AlexNet 卷积神经网络的演进从LeNet到AlexNet到VGGNet.GoogleNet到ResNet.演进的方式是有一定规律的,并且它们也都在ImageNet LSVRC竞赛上 ...

  6. Deep Dream模型

    Deep Dream 是Google 公司在2015 年公布的一顶有趣的技术.在训练好的卷积神经网络中,只需要设定几个参数,就可以通过这项技术生成一张图像.生成出的图像不仅令人印象深刻,而且还能帮助我 ...

  7. 好玩的Deep Dream

    参照<21个项目玩转深度学习>第4章实现的,Deep Dream是google公司在2015年公布的一项有趣技术,通过读取训练模型中某一层的结果值,添加噪声而得到一张结果图,deep Dr ...

  8. Deep Dream 模型

    Deep Dream 是 Google 公司在 2015 年公布的一项有趣的技术 .本文通过极大化卷积层某个通道的平均值来生成图像 , 并学习了如何生成更大尺寸和更高质量的图像. 1.导入 Incep ...

  9. TF之DD:利用Inception模型+GD算法生成更高质量的Deep Dream高质量图片

    TF之DD:利用Inception模型+GD算法生成更高质量的Deep Dream高质量图片 目录 输出结果 设计思路 部分代码 输出结果 设计思路 部分代码 # coding:utf-8#TF之DD ...

最新文章

  1. html引入外部css_CSS 三种基础选择器
  2. 《那些年啊,那些事——一个程序员的奋斗史》——76
  3. Windows中通过bat定时执行命令和mysqldump实现数据库备份
  4. 结构和类中字段的初始化以及用new来操作他们的构造函数
  5. 下载,安装 Source Navigator(ubuntu 14.04)
  6. android自定义更新,Android 完美解决自定义preference与ActivityGroup UI更新的问题
  7. ASP.net(C#)]用DataSet进入对数据源的插入数据、更新数据及刪除数据
  8. 【Python】字典类型
  9. 深度学习笔记(49) 风格代价函数
  10. wxpython使窗口重新显示_wxpython刷新窗口按按钮
  11. 美国一鹦鹉趁主人不在家上网购物:买的都是水果蔬菜
  12. 数据库写入性能测试小工具
  13. 移动电话用户突破6亿大关
  14. [HDU4585]Shaolin
  15. vs2017使用GitHub插件发布项目到github
  16. python实现sm3算法
  17. 谷歌开始卷自己,AI架构Pathways加持,推出200亿生成模型
  18. java/php/net/python旅行社信息管理系统设计
  19. 九 iOS之 图片剪裁
  20. 股票技术指标详解--移动平均线(MA)

热门文章

  1. 稀微离线编程器应用笔记:华大HC32F460烧录
  2. win7计算机搜索不了,win7搜索不到文件 提示没有与搜索条件匹配的项的解决方法...
  3. 大乐透35选5和12选2
  4. 2019年TI杯 简易电路特性测试仪 制作过程(3)——MCU外围电路、电源电路及接线说明 20/04/18
  5. python怎么检验股票日收益率_【练习】python脚本看股票实时盈亏
  6. 轻轻松松学习SpringBoot2:第十一篇: Spring Boot项目启动的几种方式
  7. 服务器 报警以及相关信息 预案,服务器故障应急预案
  8. “OFweek 2017中国智能家居及智能硬件在线展会”圆满落幕
  9. Python自学笔记9:实操案例六(千年虫,购物流程)
  10. 6 进攻退守之可转债及可交換债