Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/flarive/cortex-raytracer
Open source CPU monte carlo raytracer
https://github.com/flarive/cortex-raytracer
cameras lights materials monte-carlo-simulation raytracer raytracing textures
Last synced: 5 days ago
JSON representation
Open source CPU monte carlo raytracer
- Host: GitHub
- URL: https://github.com/flarive/cortex-raytracer
- Owner: flarive
- Created: 2024-02-24T19:59:59.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2025-01-12T20:24:35.000Z (about 1 month ago)
- Last Synced: 2025-01-12T21:27:44.385Z (about 1 month ago)
- Topics: cameras, lights, materials, monte-carlo-simulation, raytracer, raytracing, textures
- Language: C++
- Homepage:
- Size: 522 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Cortex-Raytracer
Cortex RT is a self made CPU based monte carlo path tracer created from scratch in C++.
data:image/s3,"s3://crabby-images/46ff9/46ff9c5893a3acab48598225799d7333bdaf3d16" alt="Screenshot"
# Primitives
Cortex supports an extended list of builtin uv mapped primitives mostly for testing purposes :
- Plane
- Cylinder
- Disk
- Cone
- Box
- Torus
- SpherePrimitives with test UV texture | Primitives with stone texture
--- | ---
data:image/s3,"s3://crabby-images/3aaef/3aaef9890fb68c1e16cba7c196753635504a2956" alt="Screenshot of all builtin primitives" | data:image/s3,"s3://crabby-images/2c8a1/2c8a137d1ed8e2ddf80f1989de88c65ad24b0a71" alt="Screenshot of all builtin primitives"[extended_primitives.scene](https://github.com/flarive/Cortex-Raytracer/blob/master/scenes/extended_primitives.scene)
# Meshes
Cortex RT supports loading Wavefront .obj files.
obj is a kind of old legacy plain text 3D file format but it is still widely used by 3D software (blender, 3ds max, maya...) as an export file format.
- .obj file contains vertex, faces, normals, uv mapping and smmothing groups definition
- .mtl (Material template library) additional file contains materials definition (color, textures, ambient, diffuse, specular, bump...)If you want to knowm more about obj and mtl files : https://en.wikipedia.org/wiki/Wavefront_.obj_file
teapot.obj solid color | teapot.obj textured | 3ds max obj exporter
--- | --- | ---
data:image/s3,"s3://crabby-images/8f108/8f1083d4f35ce6847ff367b74b9799cbc6e63fff" alt="" | data:image/s3,"s3://crabby-images/82c15/82c153f4ecfadc79b3ad5ea88c2ab3e2832c18b0" alt="" | data:image/s3,"s3://crabby-images/c8140/c8140b242924ea57f6f11d6d20b8e091a9277ad3" alt="Screenshot of 3ds max OBJ file exporter"# Scenes
Cortex RT comes with a convenient .scene configuration file system to describe the scene to be rendered (primitives, meshes, camera, lights, materials, textures, rendering quality...)
```
# teapot_mesh.sceneimage:
{
width = 512;
height = 388;
maxDepth = 100;
samplesPerPixel = 100;
background =
{
color = { r = 0.0; g = 0.0; b = 0.0; };
};
};# Configuration of the camera
camera:
{
aspectRatio = "16:9";
lookFrom = { x = 0.0; y = 4.0; z = 9.0; };
lookAt = { x = 0.0; y = 0.0; z = 0.0; };
upAxis = { x = 0.0; y = 1.0; z = 0.0; };
fov = 18.0;
};# Lights in the scene
lights:
{
sphereLights: (
{
name = "MySphereLight";
position = { x = 0.0; y = 8.0; z = 5.0; };
radius = 3.0;
intensity = 3.0;
color = { r = 1.0; g = 1.0; b = 1.0; };
invisible = true;
}
)
}textures:
{
solidColor: (
{
name = "ground_texture";
color = { r = 0.7; g = 0.8; b = 1.0; };
},
),
image: (
{
name = "teapot_diffuse_texture";
filepath = "../../data/models/rusted_metal1.jpg";
}
)
}materials:
{
lambertian: (
{
name = "ground_material";
texture = "ground_texture";
}
),
phong: (
{
name = "teapot_material";
diffuseTexture = "teapot_diffuse_texture";
ambientColor = { r = 0.0; g = 0.0; b = 0.0; };
shininess = 0.9;
}
)
}# Meshes in the scene
meshes:
{
obj: (
{
name = "MyTeapotModel"
filepath = "../../data/models/teapot.obj";
position = { x = 0.0; y = 0.0; z = 0.0; };
material = "teapot_material"
use_mtl = false;
use_smoothing = true;
transform =
{
translate = { x = 0.0; y = 0.0; z = 0.0; };
rotate = { x = 0.0; y = 0.0; z = 0.0; };
scale = { x = 0.02; y = 0.02; z = 0.02; };
};
}
);
};# Primitives in the scene
primitives:
{
# List of boxes
boxes: (
{
name = "MyGround";
position = { x = 0.0; y = -1.0; z = 0.0; };
size = { x = 40.0; y = 0.5; z = 40.0; };
material = "ground_material";
uvmapping = { scale_u = 1.0; scale_v = 1.0; offset_u = 0.0; offset_v = 0.0; repeat_u = 2.0; repeat_v = 2.0; };
}
);
};
```# Materials
data:image/s3,"s3://crabby-images/e64a8/e64a80fd84b2dcffb7d82ea9e39e115d3c5718ef" alt="Screenshot of all suported materials"
Cortex RT mostly support following materials :
- Phong
- Oren Nayar
- Anisotropic (for wood, slate, ice, velvet...)
- Isotropic (for glass, crystals with cubic symmetry, diamonds, plastic, metal...)
- Dielectric (for water, glass, diamond...)
- Lambertian (simple diffuse material without any specular relection)
- Metal (for metals, mirrors...)
- Emissive (WIP)crate.obj (diffuse + specular + bump textures) | cushion.obj (diffuse + specular + normal textures)
--- | ---
data:image/s3,"s3://crabby-images/d4cd6/d4cd6c760b1df5480da97dc57ae577f1424b7acd" alt="Screenshot of phong crate model with diffuse + specular + bump textures" | data:image/s3,"s3://crabby-images/aaab3/aaab34295de0d2517fb6417a6fa6f38a38ab2272" alt="Screenshot of phong cushion model with diffuse + specular + normal textures"
data:image/s3,"s3://crabby-images/22a6e/22a6edbbca06131a5675563d0fae8418e80acd5f" alt="Screenshot of crate textures" | data:image/s3,"s3://crabby-images/762b2/762b2fc88eb0b33a674875c2d2337a648814feeb" alt="Screenshot of cushion textures"The phong reflection model is a full featured material that combines ambient + diffuse + specular.
https://en.wikipedia.org/wiki/Phong_reflection_modelOn top of that, Cortex RT phong material also support a lot of possible textures (solid color, gradient, image, bump, normal, displacement, alpha...)
```
# Sample materials section in scene file
materials:
{
lambertian: (
{
name = "ground_material";
texture = "ground_texture";
}
),
phong: (
{
name = "crate_material";
diffuseTexture = "crate_diffuse_texture";
specularTexture = "crate_specular_texture";
#bumpTexture = "crate_bump_texture";
normalTexture = "crate_normal_texture";
ambientColor = { r = 0.0; g = 0.0; b = 0.0; };
shininess = 0.0;
}
)
}
```
[all_materials_spheres.scene](https://github.com/flarive/Cortex-Raytracer/blob/master/scenes/all_materials_spheres.scene)# Textures
data:image/s3,"s3://crabby-images/fa5ea/fa5eae8c5ec0e3f4d31605c245ab234963bdc87b" alt="Screenshot of all suported materials"
Cortex RT supports quite a lot of textures you can combine in a material :
- Solid color texture
- Gradient color texture
- Image texture
- Bump texture
- Normal texture
- Displacement texture (WIP)
- Alpha texture (transparency texture)
- Perlin texture (procedural noise)
- Checker (procedural checkboard pattern texture)
- Emissive texture (WIP)```
# Sample textures section in scene file
textures:
{
image: (
{
name = "ground_texture";
filepath = "../../data/textures/scifi_floor2.png";
},
{
name = "crate_diffuse_texture";
filepath = "../../data/models/crate_diffuse.jpg";
},
{
name = "crate_specular_texture";
filepath = "../../data/models/crate_specular.jpg";
},
{
name = "crate_bump_texture";
filepath = "../../data/models/crate_bump.jpg";
}
),
normal: (
{
name = "crate_normal_texture";
filepath = "../../data/models/crate_normal.jpg";
strength = 0.005;
}
)
}
```[all_textures_spheres.scene](https://github.com/flarive/Cortex-Raytracer/blob/master/scenes/all_textures_spheres.scene)
Bump texture | Normal texture
--- | ---
data:image/s3,"s3://crabby-images/9b9b2/9b9b2623e565f5beb87c9701a1ab44aff0ae0e90" alt="Screenshot of bump texture" | data:image/s3,"s3://crabby-images/f3e0d/f3e0d792a97e2b562cd7c16f8d5c8603641f8cda" alt="Screenshot of normal texture"# Camera
Cortex RT provides 2 kinds of camera : perspective (default) and orthographic (no perception of depth)
Perspective camera | Orthographic camera
--- | ---
data:image/s3,"s3://crabby-images/3685b/3685b2de552c9f3c3d423bfece74e9a6b59ac19a" alt="" | data:image/s3,"s3://crabby-images/39c43/39c434ac7333bcab4352fef0d19dfac787522ca5" alt=""```
# Configuration of a perspective camera
camera:
{
aspectRatio = "16:9";
lookFrom = { x = 0.0; y = 2.0; z = 9.0; };
lookAt = { x = 0.0; y = 0.6; z = 0.0; };
upAxis = { x = 0.0; y = 1.0; z = 0.0; };
fov = 18.0; // Field Of View (zoom level in degrees)
};
``````
# Configuration of an orthographic camera
camera:
{
aspectRatio = "16:9";
lookFrom = { x = 0.0; y = 2.0; z = 9.0; };
lookAt = { x = 0.0; y = 0.6; z = 0.0; };
upAxis = { x = 0.0; y = 1.0; z = 0.0; };
orthographic = true;
orthoHeight = 2.0; // Orthographic viewport height (height of the viewport in world space units)
};
```# Rendering parameters
The image section in .scene files defines some usefull render settings :
- width/height : The size in pixels of the final rendered image (according to the camera aspect ratio)
- maxDepth : The max number of ray bounces (50 should be more than enough)
- samplesPerPixel (spp) : The max number of samples calculated to generate each pixel of the rendered image (50 is very fast but very noisy, 500-1000 is high quality, 5000+ is extra high quality but very slow)
- background : The background to use while rendering the scene (color, simple image or hdr skybox image)```
# Configuration of the rendered image quality
image:
{
width = 512;
height = 388;
maxDepth = 50;
samplesPerPixel = 500;
background =
{
#color = { r = 0.1; g = 0.1; b = 0.1; };
filepath = "../../data/backgrounds/hdr/christmas_photo_studio_02_2k.hdr";
is_skybox = true;
};
};
```50 spp | 500 spp | 1000 spp | 5000 spp | 10000 spp
--- | --- | --- | --- | ---
data:image/s3,"s3://crabby-images/385ed/385ed1808794ae7b91d25f21d10b64aec9e2b006" alt="" | data:image/s3,"s3://crabby-images/0836d/0836d0998bb4bbe7302a67cccd61d5f38bdd6b4f" alt="" | data:image/s3,"s3://crabby-images/e284a/e284a2d1ab33f2934197390a1cdb5cf4ab176b62" alt="" | data:image/s3,"s3://crabby-images/bf30d/bf30dba5aec12a055f84683e961763fa431e28a1" alt="" | data:image/s3,"s3://crabby-images/44448/44448178d9300b86bef2935d91c35190bb88b365" alt=""# Lights
Cortex RT supports 3 different kinds of lights :
- Omni light :
Also known as a point light, an omni light emits light equally in all directions from a single point in space, similar to a light bulb.- Directional light :
Simulates light coming from a specific direction, as if it were emitted from an infinitely large source, such as the sun.- Spot light :
More focused light source that emits light in a specific direction within a cone.Lights are produced by hidden objects (quad or sphere) with an emissive material.\
Such objects can be displayed for debug lightning purpose.Omni light | Omni light debug (emissive sphere)
--- | ---
data:image/s3,"s3://crabby-images/50713/507133221f5d92bb7e88c8ddda9c20b7438f1f19" alt="" | data:image/s3,"s3://crabby-images/e7081/e7081fe531db44cac5d1469475d3b3404ef17edc" alt=""Directional light | Directional light debug (emissive quad)
--- | ---
data:image/s3,"s3://crabby-images/07577/07577d1ea48dfc16d012a8bb0f5e4fa8fbc5d4de" alt="" | data:image/s3,"s3://crabby-images/61564/61564fd416c0a55baf9906818cd47df2b58e671e" alt=""Spot light | Spot light debug (emissive sphere)
--- | ---
data:image/s3,"s3://crabby-images/2012a/2012a10b9b23374f7214e0ffa453331e6a0bb00d" alt="" | data:image/s3,"s3://crabby-images/b60dc/b60dc2d889093341d7dbc137769a630d8d9a5fe7" alt=""[all_lights_types.scene](https://github.com/flarive/Cortex-Raytracer/blob/master/scenes/all_lights_types.scene)
# Transforms and groups
Cortex RT supports applying transforms to primitives and meshes (translate, rotate, scale).
Transform attribute overrides the object position and size already defined.```
# Transform applied on a box primitive
primitives:
{
boxes: (
{
name = "MyGround";
position = { x = 0.0; y = -0.28; z = 0.0; };
size = { x = 10.0; y = 0.5; z = 40.0; };
material = "ground_material";
},
{
name = "MyBox"
position = { x = 0.0; y = 0.35; z = 0.0; };
size = { x = 0.7; y = 0.7; z = 0.7; };
material = "uvmapper_material";
uvmapping = { scale_u = 0.5; scale_v = 0.5; offset_u = 0.0; offset_v = 0.0; };
transform =
{
translate = { x = 0.0; y = 0.0; z = 0.0; };
rotate = { x = 0.0; y = 45.0; z = 0.0; };
scale = { x = 2.0; y = 2.0; z = 2.0; };
};
}
);
};# Transform applied on a custom mesh
meshes:
{
obj: (
{
name = "MyMesh"
filepath = "../../data/models/smooth_sphere.obj";
use_mtl = true;
use_smoothing = true;
transform =
{
translate = { x = -1.3; y = 0.0; z = 0.0; };
rotate = { x = 0.0; y = 45.0; z = 0.0; };
scale = { x = 1.2; y = 1.2; z = 1.2; };
};
}
);
};
```In a scene objects (primitives and meshes) can be grouped by using groups.
A transform can also be applied to a group.```
primitives:
{
boxes: (
{
name = "MyBox1"
position = { x = 0.0; y = 0.0; z = 0.0; };
size = { x = 0.7; y = 0.7; z = 0.7; };
material = "uvmapper_material";
group = "MyGroup";
},
{
name = "MyBox2"
position = { x = 0.0; y = 0.0; z = 0.0; };
size = { x = 0.7; y = 0.7; z = 0.7; };
material = "uvmapper_material";
group = "MyGroup";
}
);
};# Definition of groups
groups: (
{
name = "MyGroup";
transform =
{
translate = { x = -100.0; y = 270.0; z = 395.0; };
rotate = { x = 0.0; y = 15.0; z = 0.0; };
scale = { x = 2.0; y = 2.0; z = 2.0; };
};
}
);
```[transforms.scene](https://github.com/flarive/Cortex-Raytracer/blob/master/scenes/transforms.scene)
# Anti aliasing
# Performances and optimizations
# Command line exe
# Graphical User Interface
# Dependencies
# Thanks to
# What's next ?