Difference between revisions of "256a-fall-2019/hw1"

From CCRMA Wiki
Jump to: navigation, search
(Specification (part 2 of 4): Naming + Compilation)
(Deliverables)
 
(5 intermediate revisions by 2 users not shown)
Line 58: Line 58:
  
 
* 0) reading responses, to Chapters 3 and 2 (send URLs to Ge/Vidya; upload URL to Canvas)
 
* 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.) +
+
* 1) webpage page for your project (should be viewable at http://ccrma.stanford.edu/~YOURID/256a/hw1/).  It should include:
* 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
 
** links to your files of various kinds
 
** instructions on building the project (for example, anyone in the class should be able to download)
 
** 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 few screenshots that capture great parts of your visualizer in action
 +
** a high-resolution (screen capture or with camera) video of your visualizer in action & narrative
 
** a short text section that:
 
** a short text section that:
 
*** conveys your ideas/comments in constructing each program  
 
*** conveys your ideas/comments in constructing each program  
 
*** describes any difficulties you encountered in the process
 
*** describes any difficulties you encountered in the process
 
*** lists any collaborators
 
*** lists any collaborators
* 4) a high-resolution (screen capture or with camera) video of your visualizer / audio-visual narrative
+
** send URL to Ge and Vidya
* 5) upload to Canvas. don't forget to include the HTML for your website!
+
* 2) also submit to Canvas: source code to the project (*.h, *.cpp, *.c makefile, etc.) +
 +
* 3) also submit to Canvas: screenshots of your visualizer!
 +
* 4) also submit to Canvas: a high-resolution (screen capture or with camera) video of your visualizer / audio-visual narrative
 +
* 5) also submit to Canvas: URL to webpage
 
* 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...)
 
* 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...)

Latest revision as of 14:24, 14 October 2019

Homework #1: Sound Peeking

Due Dates

  • Artful Design chapter 3 reading response: due Sunday (10/6) 11:59pm
  • design milestone: due Monday (10/7) 3:30pm + in-class critique
  • Artful Design chapter 2 reading response: due Sunday (10/13) 11:59pm
  • design "done!": due Monday (10/14) 3:30pm + in-class critique


Waves-bw.jpg

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

  • Artful Design chapter 3 reading response: due Sunday (10/6) 11:59pm
  • 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 hw1-boilerplate 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
  • considerations:
    • 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!!

Note

  • 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

Deliverables

turn in all files through Canvas, with concise online documentation + readme

  • 0) reading responses, to Chapters 3 and 2 (send URLs to Ge/Vidya; upload URL to Canvas)
  • 1) webpage page for your project (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 high-resolution (screen capture or with camera) video of your visualizer in action & narrative
    • a short text section that:
      • conveys your ideas/comments in constructing each program
      • describes any difficulties you encountered in the process
      • lists any collaborators
    • send URL to Ge and Vidya
  • 2) also submit to Canvas: source code to the project (*.h, *.cpp, *.c makefile, etc.) +
  • 3) also submit to Canvas: screenshots of your visualizer!
  • 4) also submit to Canvas: a high-resolution (screen capture or with camera) video of your visualizer / audio-visual narrative
  • 5) also submit to Canvas: URL to webpage
  • 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...)