일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 깃
- gitlab
- 도커
- vim
- Flutter
- C++
- Data Structure
- github
- docker
- Algorithm
- Unity
- 다트 언어
- git
- 구조체
- Houdini
- c# winform
- dart 언어
- c#
- 플러터
- 유니티
- c# 추상 클래스
- Python
- HTML
- jupyter lab
- C언어 포인터
- c언어
- 포인터
- C# delegate
- jupyter
- c# 윈폼
Archives
- Today
- Total
nomad-programmer
[CG/Houdini] Seamless Noise 본문
// point vop - snippet node
float pi = 3.1415926535897932384;
float dx = end[0] - start[0];
float dy = end[1] - start[1];
float coord0, coord1, coord2, coord3;
vector4 coords4d;
if(type == "simplex" || type == "perlin"){
float total = 0;
float amplitude = max_amplitude;
float max_value = 0;
for(int i = 0; i <= turbulence; i++){
if(seamless == true){
coord0 = start[0] + cos((position[0] * tiling[0] + tiled_offset[0] % 1) * 2 * pi) * dx / (2 * pi) * frequency + offset[0];
coord1 = start[1] + cos((position[1] * tiling[1] + tiled_offset[1] % 1) * 2 * pi) * dx / (2 * pi) * frequency + offset[1];
coord2 = start[0] + sin((position[0] * tiling[0] + tiled_offset[0] % 1) * 2 * pi) * dx / (2 * pi) * frequency + offset[2];
coord3 = start[1] + sin((position[1] * tiling[1] + tiled_offset[1] % 1) * 2 * pi) * dx / (2 * pi) * frequency + offset[3];
coords4d = set(coord0, coord1, coord2, coord3);
}
else{
coord0 = (position[0] + tiled_offset[0]) * frequency + offset[0];
coord1 = (position[1] + tiled_offset[1]) * frequency + offset[1];
coord2 = (position[0] + tiled_offset[0]) * frequency + offset[2];
coord3 = (position[1] + tiled_offset[1]) * frequency + offset[3];
coords4d = set(coord0, coord1, coord2, coord3);
}
if(type == "simplex"){
total += xnoise(coords4d) * amplitude;
}
else if(type == "perlin"){
total += noise(coords4d) * amplitude;
}
else{
noise = 0;
return;
}
max_value += amplitude;
amplitude *= roughness;
frequency *= 2;
}
noise = fit01(total / max_value, min_amplitude, max_amplitude);
if(0 <= noise){
noise = pow(noise, attenuation);
}
else{
noise = -pow(abs(noise), attenuation);
}
}
else if (type == "worley" || type == "voronoi"){
float f1, f2, f3, f4;
vector4 temp_position1, temp_position2;
int temp_seed;
if(seamless == true){
coord0 = start[0] + cos((position[0] * tiling[0] + tiled_offset[0] % 1) * 2 * pi) * dx / (2 * pi) * frequency + offset[0];
coord1 = start[1] + cos((position[1] * tiling[1] + tiled_offset[1] % 1) * 2 * pi) * dx / (2 * pi) * frequency + offset[1];
coord2 = start[0] + sin((position[0] * tiling[0] + tiled_offset[0] % 1) * 2 * pi) * dx / (2 * pi) * frequency + offset[2];
coord3 = start[1] + sin((position[1] * tiling[1] + tiled_offset[1] % 1) * 2 * pi) * dx / (2 * pi) * frequency + offset[3];
coords4d = set(coord0, coord1, coord2, coord3);
}
else{
coord0 = (position[0] + tiled_offset[0]) * frequency + offset[0];
coord1 = (position[1] + tiled_offset[1]) * frequency + offset[1];
coord2 = (position[0] + tiled_offset[0]) * frequency + offset[2];
coord3 = (position[1] + tiled_offset[1]) * frequency + offset[3];
coords4d = set(coord0, coord1, coord2, coord3);
}
if(type == "worley"){
wnoise(coords4d, temp_seed, f1, f2, f3, f4);
noise = f2 - f1;
if(0 == mode)
noise = f1;
else if(1 == mode)
noise = f2;
else if(2 == mode)
noise = f2 - f1;
else if(3 == mode)
noise = 2 * f3 - f2 - f1;
else
noise = 0;
}
else if(type == "voronoi"){
vnoise(coords4d, set(1, 1, 1, 1), temp_seed, f1, f2, temp_position1, temp_position2);
if(0 == mode)
noise = f1;
else if(1 == mode)
noise = f2;
else if(2 == mode)
noise = f2 - f1;
else
noise = 0;
}
else{
noise = 0;
return;
}
noise = fit01(noise, min_amplitude, max_amplitude);
if(0 <= noise){
noise = pow(noise, attenuation);
}
else{
noise = -pow(abs(noise), attenuation);
}
}
else{
noise = 0;
}
if(clamp == true){
noise = clamp(noise, min_clamp, max_clamp);
}
'CG > Houdini' 카테고리의 다른 글
[CG/Houdini] License 서버 관련 (0) | 2020.11.05 |
---|---|
[Houdini] Visual Studio Code 에서 VEX 사용하기 (0) | 2020.06.21 |
Comments