Pretty Pictures, OpenGL, Taylor Series, and Physics
CS 480 Lecture,
Dr. Lawlor
Pretty Pictures of Simulations
data:image/s3,"s3://crabby-images/af566/af566682c2cfe81b002dfe2748b706cf87e2a14c" alt="Ice simulation"
Ice solidification simulation.
Red is the liquid area, with temperature shown shading to yellow
(hottest). Blue is solidified crystal; I get to choose the
crystal planes, in this case just cartesian axes.
data:image/s3,"s3://crabby-images/8e810/8e81053b730ca4c84a9d0a3fa50d51bdf07fe936" alt="Fluid dynamics simulation"
A fluid dynamics simulation: white paint sheared between layers of darkness.
data:image/s3,"s3://crabby-images/629b5/629b55a44d96c8c53a5c5d7839ea946621b4e29e" alt="Simple beam in bending"
data:image/s3,"s3://crabby-images/1178e/1178e8405c45270a6065d124e5798857ec1ef422" alt="Bending in a wooden structure"
A finite element solid mechanics simulation: wood in compression (red),
tension (green), and shear (blue). Gray gradients are
fixed. Unlike most of my simulations, this one is actually
dimensioned properly, and verified against the real world!
data:image/s3,"s3://crabby-images/c360d/c360df3937cb2f3215fb79b646e9b8e5d8d30545" alt="More drops"
A shallow water simulation, like drops on a pond. The little
drops expand outward, pass through one another, and reflect off the
walls.
data:image/s3,"s3://crabby-images/6f609/6f609e6d30c448b60fd5f358d8cb82d1764e77a3" alt="Reaction-diffusion face"
A photograph toned using reaction-diffusion equations.
Basic OpenGL Particle Rendering
Here's a tiny OpenGL program to splat some random points onto the screen:
/**
Tiny OpenGL/GLUT example program
Dr. Orion Sky Lawlor, olawlor@acm.org, 2009-01-21 (Public Domain)
*/
#include "GL/glut.h" /* windows, mice, etc. http://freeglut.sourceforge.net */
#include <stdlib.h> /* for "rand" */
#include <stdio.h> /* for printf */
/* Random Float: Return a random number between 0 and 1 */
float rf(void) { return (rand()&0xffff)*(1.0/0xffff); }
void display(void) /* Draw everything in our window */
{
glClearColor(0.3,0.5,0.7,1.0); /* clear to a nice blue color */
glClear(GL_COLOR_BUFFER_BIT);
glBegin(GL_POINTS);
srand(1);
for (int p=0;p<100000;p++) {
glColor3f(rf(),rf(),rf());
glVertex3f(2*rf()-1,2*rf()-1,2*rf()-1);
}
glEnd();
glutSwapBuffers(); /* display everything we've rendered so far */
glutPostRedisplay(); /* continual animation */
}
int main(int argc,char **argv) {
glutInit(&argc,argv); /* set up GLUT */
glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA | GLUT_DEPTH);
glutCreateWindow("TinyDemo"); /* make a window */
glutDisplayFunc(display); /* here's how to draw the window */
glutMainLoop(); /* start drawing */
}
If that wasn't crystal clear, work your way through the NeHe tutorials on OpenGL!
Taylor Series
Check out the MathWorld article, or Wikipedia.