Add a benchmark for ShadedCube.
authorBernie Innocenti <bernie@codewiz.org>
Mon, 8 May 2017 03:10:17 +0000 (23:10 -0400)
committerBernie Innocenti <bernie@codewiz.org>
Mon, 8 May 2017 03:10:17 +0000 (23:10 -0400)
benches/bounding_box.rs
benches/shaded_cube.rs [new file with mode: 0644]

index 277435c954d56515b401fbd6ad132ff2ad88607e..597f215ef4598b2135f5a14ea781cb2e63fc8afa 100644 (file)
@@ -6,9 +6,9 @@ extern crate glutin;
 extern crate glium;
 extern crate test;
 
+use glium::DisplayBuild;
 use mandelwow_lib::Cube;
 use mandelwow_lib::bounding_box::*;
-use glium::DisplayBuild;
 
 #[bench]
 fn bench_bounding_box(b: &mut test::Bencher) {
diff --git a/benches/shaded_cube.rs b/benches/shaded_cube.rs
new file mode 100644 (file)
index 0000000..8ea5a0e
--- /dev/null
@@ -0,0 +1,29 @@
+#![feature(test)]
+
+extern crate mandelwow_lib;
+#[macro_use(uniform)]
+extern crate glium;
+extern crate glutin;
+extern crate test;
+
+use glium::DisplayBuild;
+use mandelwow_lib::Cube;
+use mandelwow_lib::shaded_cube::*;
+
+#[bench]
+fn bench_shaded_cube(b: &mut test::Bencher) {
+    let display = glutin::WindowBuilder::new().build_glium().unwrap();
+    let program = shaded_program(&display);
+    let bounds = Cube { xmin: -2., xmax: 0.7, ymin: -1., ymax:  1., zmin: -1.1, zmax:  1.1 };
+    let cube = ShadedCube::new(&display, &bounds, &program);
+    let mut frame = display.draw();
+    b.iter(|| {
+        let mat = [[1., 0., 0., 0.], [0., 1., 0., 0.], [0., 0., 1., 0.], [0., 0., 0., 1.0f32]];
+        let uniforms = uniform! {
+            model: mat,
+            viewpersp: mat,
+        };
+        cube.draw(&mut frame, &uniforms);
+    });
+    frame.finish().unwrap();
+}