|
|
@ -55,11 +55,11 @@ public class Examples {
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
return new Example(
|
|
|
|
return new Example(
|
|
|
|
new Scene(getSkyBox(), List.of(
|
|
|
|
new Scene(getSkyBox(), List.of(
|
|
|
|
new Sphere(new Vec3(0, -100.5, -1.0), 100.0, new LambertianMaterial(new ColorRGB(0.8, 0.8, 0.0), cs)),
|
|
|
|
new Sphere(new Vec3(0, -100.5, -1.0), 100.0, new LambertianMaterial(cs.albedo(0.8, 0.8, 0.0))),
|
|
|
|
new Sphere(new Vec3(0, 0, -1.2), 0.5, new LambertianMaterial(new ColorRGB(0.1, 0.2, 0.5), cs)),
|
|
|
|
new Sphere(new Vec3(0, 0, -1.2), 0.5, new LambertianMaterial(cs.albedo(0.1, 0.2, 0.5))),
|
|
|
|
new Sphere(new Vec3(-1.0, 0, -1.2), 0.5, new DielectricMaterial(1.5)),
|
|
|
|
new Sphere(new Vec3(-1.0, 0, -1.2), 0.5, new DielectricMaterial(1.5)),
|
|
|
|
new Sphere(new Vec3(-1.0, 0, -1.2), 0.4, new DielectricMaterial(1 / 1.5)),
|
|
|
|
new Sphere(new Vec3(-1.0, 0, -1.2), 0.4, new DielectricMaterial(1 / 1.5)),
|
|
|
|
new Sphere(new Vec3(1.0, 0, -1.2), 0.5, new MetallicMaterial(new ColorRGB(0.8, 0.6, 0.2), cs, 0.0))
|
|
|
|
new Sphere(new Vec3(1.0, 0, -1.2), 0.5, new MetallicMaterial(cs.albedo(0.8, 0.6, 0.2)))
|
|
|
|
)),
|
|
|
|
)),
|
|
|
|
SimpleCamera.builder()
|
|
|
|
SimpleCamera.builder()
|
|
|
|
.withImage(height * 16 / 9, height)
|
|
|
|
.withImage(height * 16 / 9, height)
|
|
|
@ -92,12 +92,12 @@ public class Examples {
|
|
|
|
if (rnd < 0.8) {
|
|
|
|
if (rnd < 0.8) {
|
|
|
|
// diffuse
|
|
|
|
// diffuse
|
|
|
|
var albedo = ColorRGB.random(rng).times(ColorRGB.random(rng));
|
|
|
|
var albedo = ColorRGB.random(rng).times(ColorRGB.random(rng));
|
|
|
|
material = new LambertianMaterial(albedo, cs);
|
|
|
|
material = new LambertianMaterial(cs.albedo(albedo));
|
|
|
|
} else if (rnd < 0.95) {
|
|
|
|
} else if (rnd < 0.95) {
|
|
|
|
// metal
|
|
|
|
// metal
|
|
|
|
var albedo = ColorRGB.random(rng, 0.5, 1.0);
|
|
|
|
var albedo = ColorRGB.random(rng, 0.5, 1.0);
|
|
|
|
var fuzz = rng.nextDouble() * 0.5;
|
|
|
|
var fuzz = rng.nextDouble() * 0.5;
|
|
|
|
material = new MetallicMaterial(albedo, cs, fuzz);
|
|
|
|
material = new MetallicMaterial(cs.albedo(albedo), fuzz);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
// glass
|
|
|
|
// glass
|
|
|
|
material = new DielectricMaterial(1.5);
|
|
|
|
material = new DielectricMaterial(1.5);
|
|
|
@ -108,8 +108,8 @@ public class Examples {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
objects.add(new Sphere(new Vec3(0, 1, 0), 1.0, new DielectricMaterial(1.5)));
|
|
|
|
objects.add(new Sphere(new Vec3(0, 1, 0), 1.0, new DielectricMaterial(1.5)));
|
|
|
|
objects.add(new Sphere(new Vec3(-4, 1, 0), 1.0, new LambertianMaterial(new ColorRGB(0.4, 0.2, 0.1), cs)));
|
|
|
|
objects.add(new Sphere(new Vec3(-4, 1, 0), 1.0, new LambertianMaterial(cs.albedo(0.4, 0.2, 0.1))));
|
|
|
|
objects.add(new Sphere(new Vec3(4, 1, 0), 1.0, new MetallicMaterial(new ColorRGB(0.7, 0.6, 0.5), cs)));
|
|
|
|
objects.add(new Sphere(new Vec3(4, 1, 0), 1.0, new MetallicMaterial(cs.albedo(0.7, 0.6, 0.5))));
|
|
|
|
|
|
|
|
|
|
|
|
var camera = SimpleCamera.builder()
|
|
|
|
var camera = SimpleCamera.builder()
|
|
|
|
.withImage(height * 16 / 9, height)
|
|
|
|
.withImage(height * 16 / 9, height)
|
|
|
@ -128,11 +128,11 @@ public class Examples {
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
return new Example(
|
|
|
|
return new Example(
|
|
|
|
new Scene(getSkyBox(), List.of(
|
|
|
|
new Scene(getSkyBox(), List.of(
|
|
|
|
new Parallelogram(new Vec3(-3, -2, 5), new Vec3(0, 0, -4), new Vec3(0, 4, 0), new LambertianMaterial(new ColorRGB(1.0, 0.2, 0.2), cs)),
|
|
|
|
new Parallelogram(new Vec3(-3, -2, 5), new Vec3(0, 0, -4), new Vec3(0, 4, 0), new LambertianMaterial(cs.albedo(1.0, 0.2, 0.2))),
|
|
|
|
new Parallelogram(new Vec3(-2, -2, 0), new Vec3(4, 0, 0), new Vec3(0, 4, 0), new LambertianMaterial(new ColorRGB(0.2, 1.0, 0.2), cs)),
|
|
|
|
new Parallelogram(new Vec3(-2, -2, 0), new Vec3(4, 0, 0), new Vec3(0, 4, 0), new LambertianMaterial(cs.albedo(0.2, 1.0, 0.2))),
|
|
|
|
new Parallelogram(new Vec3(3, -2, 1), new Vec3(0, 0, 4), new Vec3(0, 4, 0), new LambertianMaterial(new ColorRGB(0.2, 0.2, 1.0), cs)),
|
|
|
|
new Parallelogram(new Vec3(3, -2, 1), new Vec3(0, 0, 4), new Vec3(0, 4, 0), new LambertianMaterial(cs.albedo(0.2, 0.2, 1.0))),
|
|
|
|
new Parallelogram(new Vec3(-2, 3, 1), new Vec3(4, 0, 0), new Vec3(0, 0, 4), new LambertianMaterial(new ColorRGB(1.0, 0.5, 0.0), cs)),
|
|
|
|
new Parallelogram(new Vec3(-2, 3, 1), new Vec3(4, 0, 0), new Vec3(0, 0, 4), new LambertianMaterial(cs.albedo(1.0, 0.5, 0.0))),
|
|
|
|
new Parallelogram(new Vec3(-2, -3, 5), new Vec3(4, 0, 0), new Vec3(0, 0, -4), new LambertianMaterial(new ColorRGB(0.2, 0.8, 0.8), cs))
|
|
|
|
new Parallelogram(new Vec3(-2, -3, 5), new Vec3(4, 0, 0), new Vec3(0, 0, -4), new LambertianMaterial(cs.albedo(0.2, 0.8, 0.8)))
|
|
|
|
)),
|
|
|
|
)),
|
|
|
|
SimpleCamera.builder()
|
|
|
|
SimpleCamera.builder()
|
|
|
|
.withImage(height, height)
|
|
|
|
.withImage(height, height)
|
|
|
@ -148,10 +148,10 @@ public class Examples {
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
return new Example(
|
|
|
|
return new Example(
|
|
|
|
new Scene(List.of(
|
|
|
|
new Scene(List.of(
|
|
|
|
new Sphere(new Vec3(0, -1000, 0), 1000, new LambertianMaterial(new ColorRGB(0.2, 0.2, 0.2), cs)),
|
|
|
|
new Sphere(new Vec3(0, -1000, 0), 1000, new LambertianMaterial(cs.albedo(0.2, 0.2, 0.2))),
|
|
|
|
new Sphere(new Vec3(0, 2, 0), 2, new LambertianMaterial(new ColorRGB(0.2, 0.2, 0.2), cs)),
|
|
|
|
new Sphere(new Vec3(0, 2, 0), 2, new LambertianMaterial(cs.albedo(0.2, 0.2, 0.2))),
|
|
|
|
new Parallelogram(new Vec3(3, 1, -2), new Vec3(2, 0, 0), new Vec3(0, 2, 0), new DiffuseLight(new ColorRGB(4.0, 4.0, 4.0), cs)),
|
|
|
|
new Parallelogram(new Vec3(3, 1, -2), new Vec3(2, 0, 0), new Vec3(0, 2, 0), new DiffuseLight(cs.illuminant(4.0))),
|
|
|
|
new Sphere(new Vec3(0, 7, 0), 2, new DiffuseLight(new ColorRGB(4.0, 4.0, 4.0), cs))
|
|
|
|
new Sphere(new Vec3(0, 7, 0), 2, new DiffuseLight(cs.illuminant(4.0)))
|
|
|
|
)),
|
|
|
|
)),
|
|
|
|
SimpleCamera.builder()
|
|
|
|
SimpleCamera.builder()
|
|
|
|
.withImage(height * 16 / 9, height)
|
|
|
|
.withImage(height * 16 / 9, height)
|
|
|
@ -166,10 +166,10 @@ public class Examples {
|
|
|
|
if (height <= 0) height = 600;
|
|
|
|
if (height <= 0) height = 600;
|
|
|
|
|
|
|
|
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var red = new LambertianMaterial(new ColorRGB(.65, .05, .05), cs);
|
|
|
|
var red = new LambertianMaterial(cs.albedo(.65, .05, .05));
|
|
|
|
var white = new LambertianMaterial(new ColorRGB(.73, .73, .73), cs);
|
|
|
|
var white = new LambertianMaterial(cs.albedo(.73, .73, .73));
|
|
|
|
var green = new LambertianMaterial(new ColorRGB(.12, .45, .15), cs);
|
|
|
|
var green = new LambertianMaterial(cs.albedo(.12, .45, .15));
|
|
|
|
var light = new DiffuseLight(new ColorRGB(15.0, 15.0, 15.0), cs);
|
|
|
|
var light = new DiffuseLight(cs.illuminant(15.0));
|
|
|
|
|
|
|
|
|
|
|
|
return new Example(
|
|
|
|
return new Example(
|
|
|
|
new Scene(List.of(
|
|
|
|
new Scene(List.of(
|
|
|
@ -194,10 +194,10 @@ public class Examples {
|
|
|
|
public static @NotNull Example getCornellBoxSmoke(int height) {
|
|
|
|
public static @NotNull Example getCornellBoxSmoke(int height) {
|
|
|
|
if (height <= 0) height = 600;
|
|
|
|
if (height <= 0) height = 600;
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var red = new LambertianMaterial(new ColorRGB(.65, .05, .05), cs);
|
|
|
|
var red = new LambertianMaterial(cs.albedo(.65, .05, .05));
|
|
|
|
var white = new LambertianMaterial(new ColorRGB(.73, .73, .73), cs);
|
|
|
|
var white = new LambertianMaterial(cs.albedo(.73, .73, .73));
|
|
|
|
var green = new LambertianMaterial(new ColorRGB(.12, .45, .15), cs);
|
|
|
|
var green = new LambertianMaterial(cs.albedo(.12, .45, .15));
|
|
|
|
var light = new DiffuseLight(new ColorRGB(15.0, 15.0, 15.0), cs);
|
|
|
|
var light = new DiffuseLight(cs.illuminant(15.0));
|
|
|
|
|
|
|
|
|
|
|
|
return new Example(
|
|
|
|
return new Example(
|
|
|
|
new Scene(List.of(
|
|
|
|
new Scene(List.of(
|
|
|
@ -207,13 +207,13 @@ public class Examples {
|
|
|
|
new Box(new Vec3(0, 0, 0), new Vec3(165, 330, 165), white)
|
|
|
|
new Box(new Vec3(0, 0, 0), new Vec3(165, 330, 165), white)
|
|
|
|
.rotateY(Math.toRadians(15))
|
|
|
|
.rotateY(Math.toRadians(15))
|
|
|
|
.translate(new Vec3(265, 0, 295)),
|
|
|
|
.translate(new Vec3(265, 0, 295)),
|
|
|
|
0.01, new IsotropicMaterial(ColorRGB.BLACK, cs)
|
|
|
|
0.01, new IsotropicMaterial(cs.albedo(ColorRGB.BLACK))
|
|
|
|
),
|
|
|
|
),
|
|
|
|
new ConstantMedium(
|
|
|
|
new ConstantMedium(
|
|
|
|
new Box(new Vec3(0, 0, 0), new Vec3(165, 165, 165), white)
|
|
|
|
new Box(new Vec3(0, 0, 0), new Vec3(165, 165, 165), white)
|
|
|
|
.rotateY(Math.toRadians(-18))
|
|
|
|
.rotateY(Math.toRadians(-18))
|
|
|
|
.translate(new Vec3(130, 0, 65)),
|
|
|
|
.translate(new Vec3(130, 0, 65)),
|
|
|
|
0.01, new IsotropicMaterial(ColorRGB.WHITE, cs)
|
|
|
|
0.01, new IsotropicMaterial(cs.albedo(ColorRGB.WHITE))
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)),
|
|
|
|
)),
|
|
|
|
SimpleCamera.builder()
|
|
|
|
SimpleCamera.builder()
|
|
|
@ -229,10 +229,10 @@ public class Examples {
|
|
|
|
if (height <= 0) height = 600;
|
|
|
|
if (height <= 0) height = 600;
|
|
|
|
|
|
|
|
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var red = new LambertianMaterial(new ColorRGB(.65, .05, .05), cs);
|
|
|
|
var red = new LambertianMaterial(cs.albedo(.65, .05, .05));
|
|
|
|
var white = new LambertianMaterial(new ColorRGB(.73, .73, .73), cs);
|
|
|
|
var white = new LambertianMaterial(cs.albedo(.73, .73, .73));
|
|
|
|
var green = new LambertianMaterial(new ColorRGB(.12, .45, .15), cs);
|
|
|
|
var green = new LambertianMaterial(cs.albedo(.12, .45, .15));
|
|
|
|
var light = new DiffuseLight(new ColorRGB(7.0, 7.0, 7.0), cs);
|
|
|
|
var light = new DiffuseLight(cs.illuminant(7.0));
|
|
|
|
var glass = new DielectricMaterial(1.5);
|
|
|
|
var glass = new DielectricMaterial(1.5);
|
|
|
|
|
|
|
|
|
|
|
|
var room = new Box(new Vec3(0, 0, 0), new Vec3(555, 555, 555), white, white, red, green, white, null);
|
|
|
|
var room = new Box(new Vec3(0, 0, 0), new Vec3(555, 555, 555), white, white, red, green, white, null);
|
|
|
@ -259,15 +259,15 @@ public class Examples {
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
var cs = ColorSpaces.sRGB;
|
|
|
|
record Partei(String name, ColorRGB color, double stimmen) { }
|
|
|
|
record Partei(String name, ColorRGB color, double stimmen) { }
|
|
|
|
var data = List.of(
|
|
|
|
var data = List.of(
|
|
|
|
new Partei("CDU", new ColorRGB(0x00, 0x4B, 0x76), 18.9),
|
|
|
|
new Partei("CDU", new ColorRGB(0x004B76), 18.9),
|
|
|
|
new Partei("SPD", new ColorRGB(0xC0, 0x00, 0x3C), 25.7),
|
|
|
|
new Partei("SPD", new ColorRGB(0xC0003C), 25.7),
|
|
|
|
new Partei("AfD", new ColorRGB(0x80, 0xCD, 0xEC), 10.3),
|
|
|
|
new Partei("AfD", new ColorRGB(0x80CDEC), 10.3),
|
|
|
|
new Partei("FDP", new ColorRGB(0xF7, 0xBB, 0x3D), 11.5),
|
|
|
|
new Partei("FDP", new ColorRGB(0xF7BB3D), 11.5),
|
|
|
|
new Partei("DIE LINKE", new ColorRGB(0x5F, 0x31, 0x6E), 4.9),
|
|
|
|
new Partei("DIE LINKE", new ColorRGB(0x5F316E), 4.9),
|
|
|
|
new Partei("GRÜNE", new ColorRGB(0x00, 0x85, 0x4A), 14.8),
|
|
|
|
new Partei("GRÜNE", new ColorRGB(0x00854A), 14.8),
|
|
|
|
new Partei("CSU", new ColorRGB(0x00, 0x77, 0xB6), 5.2)
|
|
|
|
new Partei("CSU", new ColorRGB(0x0077B6), 5.2)
|
|
|
|
);
|
|
|
|
);
|
|
|
|
var white = new LambertianMaterial(new ColorRGB(.99, .99, .99), cs);
|
|
|
|
var white = new LambertianMaterial(cs.albedo(.99, .99, .99));
|
|
|
|
|
|
|
|
|
|
|
|
var count = data.size();
|
|
|
|
var count = data.size();
|
|
|
|
var size = 75d;
|
|
|
|
var size = 75d;
|
|
|
@ -287,7 +287,7 @@ public class Examples {
|
|
|
|
objects.add(new Box(
|
|
|
|
objects.add(new Box(
|
|
|
|
new Vec3((i + 1) * spacing + i * size, 0, spacing),
|
|
|
|
new Vec3((i + 1) * spacing + i * size, 0, spacing),
|
|
|
|
new Vec3((i + 1) * spacing + (i + 1) * size, partei.stimmen() * 15, spacing + size),
|
|
|
|
new Vec3((i + 1) * spacing + (i + 1) * size, partei.stimmen() * 15, spacing + size),
|
|
|
|
new DielectricMaterial(1.5, partei.color(), cs)
|
|
|
|
new DielectricMaterial(1.5, cs.albedo(partei.color()))
|
|
|
|
));
|
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -346,7 +346,7 @@ public class Examples {
|
|
|
|
|
|
|
|
|
|
|
|
// boxes
|
|
|
|
// boxes
|
|
|
|
var boxes = new ArrayList<Hittable>();
|
|
|
|
var boxes = new ArrayList<Hittable>();
|
|
|
|
var ground = new LambertianMaterial(new ColorRGB(0.48, 0.83, 0.53), cs);
|
|
|
|
var ground = new LambertianMaterial(cs.albedo(0.48, 0.83, 0.53));
|
|
|
|
for (int i = 0; i < 20; i++) {
|
|
|
|
for (int i = 0; i < 20; i++) {
|
|
|
|
for (int j = 0; j < 20; j++) {
|
|
|
|
for (int j = 0; j < 20; j++) {
|
|
|
|
var w = 100.0;
|
|
|
|
var w = 100.0;
|
|
|
@ -364,23 +364,23 @@ public class Examples {
|
|
|
|
// light
|
|
|
|
// light
|
|
|
|
objects.add(new Parallelogram(
|
|
|
|
objects.add(new Parallelogram(
|
|
|
|
new Vec3(123, 554, 147), new Vec3(300, 0, 0), new Vec3(0, 0, 265),
|
|
|
|
new Vec3(123, 554, 147), new Vec3(300, 0, 0), new Vec3(0, 0, 265),
|
|
|
|
new DiffuseLight(new ColorRGB(7., 7., 7.), cs)
|
|
|
|
new DiffuseLight(cs.illuminant(7.0))
|
|
|
|
));
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
|
|
// spheres with different materials
|
|
|
|
// spheres with different materials
|
|
|
|
objects.add(new Sphere(new Vec3(400, 400, 200), 50, new LambertianMaterial(new ColorRGB(0.7, 0.3, 0.1), cs)));
|
|
|
|
objects.add(new Sphere(new Vec3(400, 400, 200), 50, new LambertianMaterial(cs.albedo(0.7, 0.3, 0.1))));
|
|
|
|
objects.add(new Sphere(new Vec3(260, 150, 45), 50, new DielectricMaterial(1.5)));
|
|
|
|
objects.add(new Sphere(new Vec3(260, 150, 45), 50, new DielectricMaterial(1.5)));
|
|
|
|
objects.add(new Sphere(new Vec3(0, 150, 145), 50, new MetallicMaterial(new ColorRGB(0.8, 0.8, 0.9), cs, 1.0)));
|
|
|
|
objects.add(new Sphere(new Vec3(0, 150, 145), 50, new MetallicMaterial(cs.albedo(0.8, 0.8, 0.9), 1.0)));
|
|
|
|
|
|
|
|
|
|
|
|
// glass sphere filled with gas
|
|
|
|
// glass sphere filled with gas
|
|
|
|
var boundary = new Sphere(new Vec3(360, 150, 145), 70, new DielectricMaterial(1.5));
|
|
|
|
var boundary = new Sphere(new Vec3(360, 150, 145), 70, new DielectricMaterial(1.5));
|
|
|
|
objects.add(boundary);
|
|
|
|
objects.add(boundary);
|
|
|
|
objects.add(new ConstantMedium(boundary, 0.2, new IsotropicMaterial(new ColorRGB(0.2, 0.4, 0.9), cs)));
|
|
|
|
objects.add(new ConstantMedium(boundary, 0.2, new IsotropicMaterial(cs.albedo(0.2, 0.4, 0.9))));
|
|
|
|
|
|
|
|
|
|
|
|
// put the world in a glass sphere
|
|
|
|
// put the world in a glass sphere
|
|
|
|
objects.add(new ConstantMedium(
|
|
|
|
objects.add(new ConstantMedium(
|
|
|
|
new Sphere(new Vec3(0, 0, 0), 5000, new DielectricMaterial(1.5)),
|
|
|
|
new Sphere(new Vec3(0, 0, 0), 5000, new DielectricMaterial(1.5)),
|
|
|
|
0.0001, new IsotropicMaterial(new ColorRGB(1., 1., 1.), cs)
|
|
|
|
0.0001, new IsotropicMaterial(cs.albedo(1.0, 1.0, 1.0))
|
|
|
|
));
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
|
|
// textures spheres
|
|
|
|
// textures spheres
|
|
|
@ -388,7 +388,7 @@ public class Examples {
|
|
|
|
objects.add(new Sphere(new Vec3(220, 280, 300), 80, new LambertianMaterial(new PerlinTexture(0.2))));
|
|
|
|
objects.add(new Sphere(new Vec3(220, 280, 300), 80, new LambertianMaterial(new PerlinTexture(0.2))));
|
|
|
|
|
|
|
|
|
|
|
|
// box from spheres
|
|
|
|
// box from spheres
|
|
|
|
var white = new LambertianMaterial(new ColorRGB(.73, .73, .73), cs);
|
|
|
|
var white = new LambertianMaterial(cs.albedo(.73, .73, .73));
|
|
|
|
var spheres = new ArrayList<Hittable>();
|
|
|
|
var spheres = new ArrayList<Hittable>();
|
|
|
|
for (int j = 0; j < 1000; j++) {
|
|
|
|
for (int j = 0; j < 1000; j++) {
|
|
|
|
spheres.add(new Sphere(new Vec3(random.nextDouble(165), random.nextDouble(165), random.nextDouble(165)), 10, white));
|
|
|
|
spheres.add(new Sphere(new Vec3(random.nextDouble(165), random.nextDouble(165), random.nextDouble(165)), 10, white));
|
|
|
|