data:image/s3,"s3://crabby-images/1d348/1d3488605da22ce6161cac468e53ceed72c0e073" alt=""
StyleTrans Houdini
1. Houdini + Python + Vex
2. Python style transfer
目标 goal
本次作业的目标是希望通过底层的语言(Python/Vex)和高层的软件(Houdini)混合使用,实现复杂艺术效果的创作。
The goal of this assignment is to achieve the creation of complex artistic effects through the mixed use of low-level language(Python/Vex) and high-level software(Houdini).
︎︎ 学习 Study
1. Houdini tutorial :
https://www.youtube.com/watch?v=emEux6cGOww
2. Houdini reference:
https://www.sidefx.com/docs/houdini/index.html
3.Houdini Python reference:
https://www.sidefx.com/docs/houdini/hom/index.html
4.Houdini Vex reference:
https://www.sidefx.com/docs/houdini/vex/lang.html
5.Python style transfer tutorial
https://www.youtube.com/watch?v=bFeltWvzZpQ&t=127s
https://www.youtube.com/watch?v=imX4kSKDY7s
https://www.youtube.com/watch?v=LoePx3QC5Js&t=12s
5. Tensorflow reference:
https://www.tensorflow.org/api_docs
6.OpenCV reference:
https://docs.opencv.org/master/
Some interesting works
Guest Tutorial: Dr. Jeroen Claus - Visualizing SARS-Cov-2 Spike Proteins (Rendering The Corona Virus):
https://vimeo.com/402495101
https://www.youtube.com/watch?v=emEux6cGOww
2. Houdini reference:
https://www.sidefx.com/docs/houdini/index.html
3.Houdini Python reference:
https://www.sidefx.com/docs/houdini/hom/index.html
4.Houdini Vex reference:
https://www.sidefx.com/docs/houdini/vex/lang.html
5.Python style transfer tutorial
https://www.youtube.com/watch?v=bFeltWvzZpQ&t=127s
https://www.youtube.com/watch?v=imX4kSKDY7s
https://www.youtube.com/watch?v=LoePx3QC5Js&t=12s
5. Tensorflow reference:
https://www.tensorflow.org/api_docs
6.OpenCV reference:
https://docs.opencv.org/master/
Some interesting works
Guest Tutorial: Dr. Jeroen Claus - Visualizing SARS-Cov-2 Spike Proteins (Rendering The Corona Virus):
https://vimeo.com/402495101
Python style transfer 风格迁移 :
content_image :
![]()
data:image/s3,"s3://crabby-images/bff36/bff3679bd007ba6a5b9cf4f5d9b6fe53f4d0b9d5" alt=""
style_image :
![]()
data:image/s3,"s3://crabby-images/b59e2/b59e2a6a65863033518d93e13130e21b336298c9" alt=""
Result :
![]()
data:image/s3,"s3://crabby-images/2ff79/2ff79d4ab661b3e38726cbb65b99e5929c5cd80f" alt=""
Explanation 解释 :
︎︎︎GitHub
使用的库 libraris and packages:
import tensorflow_hub as hub |
import tensorflow as tf |
from matplotlib import pyplot as plt |
import numpy as np |
import cv2 |
#TF模型 TF Model model = hub.load('https://tfhub.dev/google/magenta/arbitrary-image-stylization-v1-256/2') |
#文件导入 File Load Fuction |
def load_image(img_path): |
img = tf.io.read_file(img_path) |
img = tf.image.decode_image(img, channels=3) |
img = tf.image.convert_image_dtype(img, tf.float32) |
img = img[tf.newaxis, :] |
return img |
#分别导入内容图片和风格图片 Load content and style image |
content_image = load_image('Example1.jpg') |
style_image = load_image('Example2.jpeg') |
content_image.shape |
plt.imshow(np.squeeze(style_image)) |
plt.show() |
#TF进行风格转换 TF style transfer |
stylized_image = model(tf.constant(content_image), tf.constant(style_image))[0] |
#生成图片的展示和储存 Generated pictures display and store plt.imshow(np.squeeze(stylized_image)) |
plt.show() cv2.imwrite('generated_img.jpg', cv2.cvtColor(np.squeeze(stylized_image)*255, cv2.COLOR_BGR2RGB)) |
Art work gallery:
data:image/s3,"s3://crabby-images/02909/02909e5beec454d49e87c62b087c7766ce61a05c" alt=""
data:image/s3,"s3://crabby-images/5e175/5e175a7acbc15058c8f72b0a7b9534984ce4fc28" alt=""
data:image/s3,"s3://crabby-images/6e320/6e3207e745f80973494cf1c20acad50a6226ca28" alt=""
data:image/s3,"s3://crabby-images/fda2e/fda2ea429da51b9d0a910561e9d36f221f1483ad" alt=""
data:image/s3,"s3://crabby-images/904b6/904b6e38c8c88fee7366e50b732b92ea0c360cb4" alt=""
data:image/s3,"s3://crabby-images/5c6c8/5c6c86ca9c766d1b1b60c557ce6c22c15d783ac1" alt=""
data:image/s3,"s3://crabby-images/e40f8/e40f8dc6b219452c97b11cc8357e2a3e09903e20" alt=""
data:image/s3,"s3://crabby-images/42a43/42a43a1bca2e2c5c72c899b0afee84574bf4cba2" alt=""
data:image/s3,"s3://crabby-images/4d536/4d53662030ebc0a866c7236d7a7c8882b7923457" alt=""
data:image/s3,"s3://crabby-images/1117b/1117b7a19be11503f7c452695f04fd1f509fa25c" alt=""
data:image/s3,"s3://crabby-images/6f364/6f364144d5c265d3ee4c0cad64ef5cad83eb1e82" alt=""
data:image/s3,"s3://crabby-images/75743/757430518ab2b23f587750829f2c9a583779fa9a" alt=""
data:image/s3,"s3://crabby-images/903de/903de61503ce14ed63f99171e99ce5e349c8c26b" alt=""
data:image/s3,"s3://crabby-images/90a3e/90a3ea79e790a9464f571737ee39fe22f7174f38" alt=""
data:image/s3,"s3://crabby-images/75e73/75e738f7bdb8b4bf7817fd01468d93b095bd79fa" alt=""
Dog Pictures
Artist Works
Stryle Transfer
Houdini Work (Houdini + Python + Vex)
Houdini experiments
data:image/s3,"s3://crabby-images/2856c/2856c23f736b900bf0bc148c9ad44ea26f864f7f" alt=""
data:image/s3,"s3://crabby-images/ba042/ba0426af76510684d41dd74f33fbb6cb7f1cba30" alt=""
data:image/s3,"s3://crabby-images/3c74e/3c74e0138281fad406fb5d3b43931773023654d0" alt=""
︎Mandelbrot set 2D(Python)
import numpy as np
import matplotlib.pyplot as plt
def mandelbrot(h,w,maxit=50):
y,x = np.ogrid[-1.4:1.4:h*1j,-2:0.8:w*1j]
c = x+y*1j
z = c
divtime = maxit + np.zeros(z.shape,dtype=int)
for i in range(maxit):
z = z**2 +c
diverge = z*np.conj(z) > 2**2
div_now = diverge & (divtime==maxit)
divtime[div_now] = i
z[diverge] = 2
return divtime
plt.imshow(mandelbrot(1000,1000))
plt.show()
import matplotlib.pyplot as plt
def mandelbrot(h,w,maxit=50):
y,x = np.ogrid[-1.4:1.4:h*1j,-2:0.8:w*1j]
c = x+y*1j
z = c
divtime = maxit + np.zeros(z.shape,dtype=int)
for i in range(maxit):
z = z**2 +c
diverge = z*np.conj(z) > 2**2
div_now = diverge & (divtime==maxit)
divtime[div_now] = i
z[diverge] = 2
return divtime
plt.imshow(mandelbrot(1000,1000))
plt.show()
data:image/s3,"s3://crabby-images/b9aa7/b9aa75559e00107a86dd2162f72f38700261df5c" alt=""
︎Mandelbrot set 2D(VEX)
int ite = chi("../CONTROLLER/ite");
vector2 c = set(@P.x, @P.z);
vector2 v = set(0,0);
int isInf = 0;
int infIte = 0;
for(int i=0; i
float x = v.x * v.x - v.y * v.y + c.x;
float y = 2 * v.x * v.y + c.y;
v = set(x,y);
if(isInf != 1){
if(length(v) > 100){
isInf = 1;
infIte = i;
}
}
}
if(isInf == 1){
float col = fit(infIte, 0, ite-1, 0, 1);
f@col = col;
}else{
f@col = 0;
}
vector2 c = set(@P.x, @P.z);
vector2 v = set(0,0);
int isInf = 0;
int infIte = 0;
for(int i=0; i
float y = 2 * v.x * v.y + c.y;
v = set(x,y);
if(isInf != 1){
if(length(v) > 100){
isInf = 1;
infIte = i;
}
}
}
if(isInf == 1){
float col = fit(infIte, 0, ite-1, 0, 1);
f@col = col;
}else{
f@col = 0;
}
data:image/s3,"s3://crabby-images/252a8/252a85901ee08284ae131063ec17bf8facf7dcab" alt=""
data:image/s3,"s3://crabby-images/3ada5/3ada5ad54fa105f0bfa037247cbb9e7ae39ebf0f" alt=""
︎Mandelbrot set 3D
int iteration = chi("../CONTROLLER/iteration");
float n = chf("../CONTROLLER/n");
vector c = @P;
vector v = @P;
for(int i=0; i
float r = length(v);
float phi = atan2(v.y, v.x);
float theta = atan2(sqrt(v.x * v.x + v.y*v.y), v.z);
float vr = pow(r, n);
float vx = sin(n * theta) * cos(n * phi);
float vy = sin(n * theta) * sin(n * phi);
float vz = cos(n * theta);
v = set(vx, vy, vz) * vr + c;
if(length(v) > 100){
@density = 0;
}
}
float n = chf("../CONTROLLER/n");
vector c = @P;
vector v = @P;
for(int i=0; i
float phi = atan2(v.y, v.x);
float theta = atan2(sqrt(v.x * v.x + v.y*v.y), v.z);
float vr = pow(r, n);
float vx = sin(n * theta) * cos(n * phi);
float vy = sin(n * theta) * sin(n * phi);
float vz = cos(n * theta);
v = set(vx, vy, vz) * vr + c;
if(length(v) > 100){
@density = 0;
}
}
data:image/s3,"s3://crabby-images/88239/88239de5975ff211c439dcd09e8e095414c76766" alt=""
data:image/s3,"s3://crabby-images/bea43/bea434a638ff6d76920fca73d3a9849a83183db6" alt=""
Rendered picture 渲染图片
data:image/s3,"s3://crabby-images/7aa51/7aa515fcaed243d2a14cfc3e7298548a1c4dbd54" alt=""
data:image/s3,"s3://crabby-images/7afcb/7afcbc2a70f312e3ce34afaebc3e2bc466b23087" alt=""
data:image/s3,"s3://crabby-images/b6b75/b6b7567ca745d130b44ea7edf5168f6657e2129e" alt=""
data:image/s3,"s3://crabby-images/c0858/c08587c106ea08a997fe4fdcf1af2b0e46af01b2" alt=""
data:image/s3,"s3://crabby-images/c0e51/c0e51150c89237df238769c9dc83dc28bb64570f" alt=""
data:image/s3,"s3://crabby-images/274bb/274bbb58448bdbd89124e7822270c6dd256d87ff" alt=""
Rendered picture style transfer
data:image/s3,"s3://crabby-images/bf261/bf261e3a131bbb423ae8b220c61f8eb663f16069" alt=""
data:image/s3,"s3://crabby-images/854af/854afa75668941cd1c18eb31df50ea989b5b106b" alt=""
data:image/s3,"s3://crabby-images/8848e/8848ebfee51f14b18efe432fdd6ef7203df0080b" alt=""
data:image/s3,"s3://crabby-images/1d348/1d3488605da22ce6161cac468e53ceed72c0e073" alt=""
data:image/s3,"s3://crabby-images/aa24c/aa24c2333b5fbaebb7b05209c1af845c0313d057" alt=""
Other experiments
data:image/s3,"s3://crabby-images/acf65/acf65d59fe024269a5a7560b33a47816c8834f9c" alt=""
data:image/s3,"s3://crabby-images/c721f/c721fd624472ab675646faa47a9375ec9788e64e" alt=""
data:image/s3,"s3://crabby-images/ca616/ca616fe702dd1970580357e1cb0c5ea1fdac88a6" alt=""
data:image/s3,"s3://crabby-images/a0290/a0290e4d76f77b49b6e747fea7a6d3688c2b15ed" alt=""
data:image/s3,"s3://crabby-images/d4eeb/d4eeb66630238adbd12941addad8ca56a984660d" alt=""
data:image/s3,"s3://crabby-images/59c13/59c13545cab74f4b80fdf68398e9995ed6bf67d5" alt=""