Homework #1: Sound Peeking
In this assignment, you are to visualize sound in real-time, using OpenGL for the graphics programming, and integrated ChucK as a sound source. Your program will visualize: 1) live microphone input and 2) a designed sound narrative written in ChucK!
Specification (part 1 of 4): Reading
- read assignment: Artful Design, chapter 3; reading response — due Sunday (10/6) 11:59pm
- read assignment: Artful Design, chapter 2; reading response — due Sunday (10/13) 11:59pm
- (for reference) the original OpenGL (1.1) "The Red Book"
- download and play with sndpeek
Specification (part 2 of 4): Naming + Compilation
- choose a name for your program
- get a framework compiling on your system; might wish to start from the VisualSine example (time domain waveform rendering)
- use the chuck_fft.* files found here NOTE: this library ONLY works with single-precision floating point numbers (e.g., float)
Specification (part 3 of 4): Visualizing the spectrum
- implement short time Fourier transform, and visualize the spectrum over time
- windowing (rectangular, hann, hamming)
- window size
- FFT size
- hop size (for now, hop size can equal window size)
- implement either a waterfall plot (like sndpeek) or a real-time scrolling spectrogram
- test using the microphone input!
- use a simple chuck program that hooks up the microphone to the output so you can test your chuck setup as well as your visualizer.
- (hint: in chuck, the input / microphone is adc)
Specification (part 4 of 4): An Audio-Visual Narrative
- create a ChucK program to run inside your visualizer
- use a combination of microphone (adc in ChucK) and sound synthesis
- think about different "sections" or "movements", and how to transition between them
- try to align the aesthetic of your visualizer and your ChucK program (give it personality)
- (optional): can use keyboard input
- aesthetic goal:
- polish not important!
- technical fanciness not important!
- making the viewer/listener feel something: important!!
- have fun with it!!!
- PRINT OUT USAGE/KEYS TO CONTROLLING YOUR VISUALIZATION ON THE CONSOLE EVERY TIME YOUR VISUALIZER STARTS! (see sndpeek)
- comment your code!
- choose your own coding conventions - but be consistent
- you are welcome to work together, but you must do/turn in your own work
turn in all files via coursework, with concise online documentation + readme
- 0) reading responses, to Chapters 3 and 2 (send URLs to Ge/Vidya; upload URL to Canvas)
- 1) source code to the project (*.h, *.cpp, *.c makefile, etc.) +
- 2) screenshots of your visualizer!
- 3) HTML page for your project (if you have a CCRMA account, should be viewable at http://ccrma.stanford.edu/~YOURID/256a/hw1/). It should include:
- links to your files of various kinds
- instructions on building the project (for example, anyone in the class should be able to download)
- a few screenshots that capture great parts of your visualizer in action
- a short text section that:
- conveys your ideas/comments in constructing each program
- describes any difficulties you encountered in the process
- lists any collaborators
- 4) a high-resolution (screen capture or with camera) video of your visualizer / audio-visual narrative
- 5) upload to Canvas. don't forget to include the HTML for your website!
- 6) (if you are using the VisualStudio project, please delete the intermediate directories and .vs hidden folder before uploading. these can get really large sometimes and we will have to download all your homework...)