CCL Home Software Community Operations |
Homework: High Throughput Povray with Makeflow and Work QueueA ray-tracing tool creates very precise computer images from a detailed geometric specification. Unlike other forms of computer graphics, ray-tracing is very slow, because it computes exactly how a single beam of light propagates through a scene to arrive at each pixel on the screen. Ray-tracing is too slow to be used in real-time for, say, a computer game. Instead, it is used when quality is more important than speed, such as when rendering a high quality movie.Rending a single frame of a Hollywood-quality movie may take minutes to hours even on a very fast computer. Rendering a movie measured in hours would take decades on a single computer. Fortunately, this is a perfect application of high-throughput computing. Each frame of a movie can be rendered on a different computer simultaneously, and then assembled at the end to produce a complete movie. In this assignment, you will learn the basics of POVRay, an open source ray-tracing tool, and then use Work Queue to perform high-throughput generation of simple movies. Quick Introduction to POVRayPOVRay is a widely-used open source ray-tracer that can be run in batch mode on the command line or with a graphical display. You will also need ffmpeg, a video processing tool. Using these steps both can be installed in a master instance:wget http://ccl.cse.nd.edu/software/tutorials/acic19/software/ffmpeg-release-amd64-static.tar.xz wget http://ccl.cse.nd.edu/software/tutorials/acic19/software/povlinux-3.6.tgz tar xvf ffmpeg-release-amd64-static.tar.xz tar xvf povlinux-3.6.tgz cd povray-3.6 ./install -no-arch-check *** type U *** type /home/YOUR_USERNAME/povrayAnd update your PATH: export PATH=/home/${USER}/povray/bin:/home/${USER}/ffmpeg-4.2.1-amd64-static:${PATH}Then, download these example files: wget http://ccl.cse.nd.edu/software/tutorials/acic17/rubiks.pov wget http://ccl.cse.nd.edu/software/tutorials/acic17/WRC_RubiksCube.incYou can try out other examples from the POVRay collections site.. To render a single image of a Rubik's cube: povray +Irubiks.pov +Orubiks.pngWhich produces an image like this:
Now, open up rubiks.pov in a text editor. The POVRay language describes exactly how to render the image, and the elements are fairly self explanatory. Scroll to the bottom, and look for the invocation of the cube: object { WRC_RubiksRevenge("F'f' Rrd2R'r' U'u'Rr d2 U ld'l' U' ldl' R'r'Uu Ff") translate < -6.6/2, 0, -6.6/2 > rotate y*45 }WRC_RubiksRevenge is just a function defined in WRC_RubiksCube.inc, and the funny string following it simply defines how to set up the cubes and the colors. translate just moves the cube in the x, y, and z, directions, and rotate spins it around the Y axis by 45 degrees. (The cube is 6.5 centimeters on each edge, so the translate is just moving the rotation axis to the middle of the cube.) Add a few more cubes to the scene by copying the object clause three or four times. For each one, tweak the rotation and add a second translate after the rotate to move the new cubes around the scene. Adjust the settings until you have a couple of cubes in the view. Now, how do we make a movie? POVRay uses the built-in clock variable to represent the passage of time. clock is a floating point that varies only from zero to one through the course of an animation. You can set the clock value to, say, 0.5 by using the option +K.5. For example, change one of the rotation statements to: rotate y*(45+clock*360)Render three slightly different frames like this: povray +Irubiks.pov +Oframe000.png +K.0 povray +Irubiks.pov +Oframe001.png +K.1 povray +Irubiks.pov +Oframe002.png +K.2And then join them into a movie like this: ffmpeg -r 10 -i frame%03d.png -r ntsc movie.mpgUsing PSFTP, scp, or a similar tool, you can download the movie to your laptop and play it. The AssignmentCreate a program that renders a long movie quickly by creating a large number of frames and then stitching them together with the ffmpeg program. The program should be invoked like this:render_movie 25 scene.pov scene.movThe first argument gives the number of seconds of movie to render, the second, the povray input file, and the third the name of the output movie file. Write a script that generates a single large Makeflow file specifying the total amount of work to be done, then runs Makeflow in Work Queue mode to do the work. Note: Make a point of deleting all of your .png files when each movie is completed, otherwise you may run out of disk space! What to Turn InSee Prof. Merchant for detailed directions on turning in. You should submit the:
|