Speakers
Do you have questions or comments about this model? Ask them here! (You'll first need to log in.)
WHAT IS IT?
This model simulates sound wave interference. There is one speaker at each end. A sinusoidal signal generator powers each speaker. The yellow line represents the sound level due to the left speaker, the cyan line represents the sound level due to the right speaker, and the red line represents the sum of the sound levels due to both speakers.
HOW IT WORKS
Sound effect is due to pressure change spatially and temporally. The waveforms are made up of three lines of turtles. Each turtle acts as it were connected to its neighboring turtles with springs. When neighboring turtles are further away, they exert a stronger force.
When the left end of the sound level goes up, it "pulls up" the turtle to its right, which in turn pulls up the turtle to its right, and so on. In that way, a sound wave moves through the air.
The green turtles (speakers) continue to put more energy into the air. When there is no friction in the air, the waves in the air travel without losing amplitude.
HOW TO USE IT
Click the SETUP button to set up the system. Then, click GO to turn on the speakers.
The FRICTION slider controls the amount of sound damping in the air. The FREQUENCY slider controls the frequency of the signal generator. The AMPLITUDE slider controls the sound level of the speakers.
There are three buttons to hide each curve and three buttons to show each curve, so that the curves can be observed individually or collectively.
Set the PLOT? switch to on and click anywhere on the horizontal line in the View and you will be able to observe the sound level vs. time at the position you selected. The LISTENING-POINT monitor shows the x coordinate of the point. A white vertical line in the View also shows it. Click on the line to move the LISTENING-POINT to different position. The SPEAKER AMPLITUDE plot will plot the sound levels at this listening point.
Set the SHOW-ONLY-RECENT-PLOT? switch to on when you want to see only how the wave has looked in the recent past. With the toggle off, you can see the waves over the whole running time of the model.
THINGS TO NOTICE
How does the pattern of the left speaker wave and the right speaker wave change when you change the FREQUENCY slider? The AMPLITUDE slider?
When two speakers are turned on, the sound level at a certain point at a certain time is the sum of the sound levels produced by the two speakers at that time. Its pattern may be quite different from either of the speaker sound patterns.
THINGS TO TRY
Change the values on the sliders and observe what happens to the sum of the sound levels --- the red curve.
Try adding friction to see what it does to the waves.
Move the listening-point --- what do you observe in the plot window?
Try to create a "standing wave", in which some points on the lines do not move at all, and plot one of the points to see if the sum there is zero.
Try to create a flat red curve.
Compare the relationship between frequency and wavelength.
Find a way to measure the speed of the wave such that the relationship "speed = frequency * wavelength" is true.
EXTENDING THE MODEL
Program the red turtles to find the sum of the absolute values of the two waves.
Make it possible to "fix" the waves to zero at some point along the line --- as if this were a string and you put your finger on it.
Make the waves "reflect" from each end instead of going on.
NETLOGO FEATURES
In order to have three independent waves, three lines of turtles are created --- yellow, then cyan, and then red --- in order from left to right. Special turtles are created to control the ends of these waves. One end generates the wave (green) and the other end prevents the wave motion from wrapping (dark blue).
For this project, it does not make sense for the turtles to "wrap" when they get to the top or bottom of the world. So the y-position of the turtles is kept in a new variable (YPOS-NEW), and the turtle is hidden if its y-position moves outside the boundary of the world.
During each iteration of GO, each turtle looks at its neighbors and calculates a new speed and position accordingly. The order in which this is done is not obvious, since the turtles are running in parallel. It's important that the order in which the turtles look at their neighbors doesn't matter. Therefore temporary variables are created, "ypos-old", and "yvel-old". Each turtle looks at its neighbors in previous state and updates its own temporary variables "ypos-new" and "yvel-new". Then all the turtles update their states together.
A TRUE STORY
A CCL member was asked by an undergraduate student to help her with some physics experiment problems:
The experiment was about wave propagation and interference. In the experiment, two speakers are put on a straight track one meter apart and facing each other. The speakers are connected to a 1500 Hz sinusoidal signal generator. The student is asked to use a microphone to measure the sound level along the track between the two speakers and write down the positions where the microphone readings are a minimum.
The student is asked to explain the results and to determine if the minimum readings should be zero or not.
The results of the experiment show that the average distance between two minimum readings is about one half of the wavelength. The CCL member could not explain the results and determine if the readings should be zero or not.
The ROPE sample model helped him to answer the student. In the rope model, one end of the rope is fixed. So the model setup is similar to the experiment setup except for the length and the frequency. The CCL member and the student then worked together to modify the rope model and change the meaning of the y coordinate -- changing it from representing the absolute value of the deflection, because the microphone reading is the root mean square value of the sound level. When they ran the program, they got the experimental results and, more importantly, it became very clear to them why the minimum readings should be zero and the distance between any two minima is one half of the wavelength.
Isn't it amazing that such a simple program can be so helpful?
Try and repeat what the student and CCL member did and answer the physical experiment problems.
RELATED MODELS
Rope
HOW TO CITE
If you mention this model in a publication, we ask that you include these citations for the model itself and for the NetLogo software:
- Wilensky, U. (1998). NetLogo Speakers model. http://ccl.northwestern.edu/netlogo/models/Speakers. Center for Connected Learning and Computer-Based Modeling, Northwestern Institute on Complex Systems, Northwestern University, Evanston, IL.
- Wilensky, U. (1999). NetLogo. http://ccl.northwestern.edu/netlogo/. Center for Connected Learning and Computer-Based Modeling, Northwestern Institute on Complex Systems, Northwestern University, Evanston, IL.
COPYRIGHT AND LICENSE
Copyright 1998 Uri Wilensky.
This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License. To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-sa/3.0/ or send a letter to Creative Commons, 559 Nathan Abbott Way, Stanford, California 94305, USA.
Commercial licenses are also available. To inquire about commercial licenses, please contact Uri Wilensky at uri@northwestern.edu.
This model was created as part of the project: CONNECTED MATHEMATICS: MAKING SENSE OF COMPLEX PHENOMENA THROUGH BUILDING OBJECT-BASED PARALLEL MODELS (OBPML). The project gratefully acknowledges the support of the National Science Foundation (Applications of Advanced Technologies Program) -- grant numbers RED #9552950 and REC #9632612.
This model was converted to NetLogo as part of the projects: PARTICIPATORY SIMULATIONS: NETWORK-BASED DESIGN FOR SYSTEMS LEARNING IN CLASSROOMS and/or INTEGRATED SIMULATION AND MODELING ENVIRONMENT. The project gratefully acknowledges the support of the National Science Foundation (REPP & ROLE programs) -- grant numbers REC #9814682 and REC-0126227. Converted from StarLogoT to NetLogo, 2002.
Comments and Questions
breed [ lefts a-left ] breed [ rights a-right ] breed [ sums a-sum ] turtles-own [ yvel-old yvel-new ypos-old ypos-new time ] globals [ listening-point ] to setup clear-all set-default-shape turtles "circle" ;; Create the turtles that represent the waves ;; We need three lines across the world, so it sets ;; their xcor based on their incrementing turtle id foreach sort patches with [pycor = 0] [ ask ? [ sprout-lefts 1 [ set color yellow ] ] ] foreach sort patches with [pycor = 0] [ ask ? [ sprout-rights 1 [ set color cyan ] ] ] foreach sort patches with [pycor = 0] [ ask ? [ sprout-sums 1 [ set color red ] ] ] ;; Initialize all variables to zero. All of the turtles are stationary. set listening-point 0 ask turtles [ set yvel-old 0 set ypos-old 0 set time 0 ] ;; The ends of the waves are special. One side drives the wave, while ;; the other side anchors the waves- (prevents wrapping) ;; First define the driving turtles, which are colored green. ;; Next define the anchor turtles, which are colored blue ask lefts [ if ( xcor = max-pxcor ) [ set color blue ] if ( xcor = min-pxcor ) [ set color green ] ] ask rights [ if ( xcor = min-pxcor ) [ set color blue ] if ( xcor = max-pxcor ) [ set color green ] ] ;; draw the speakers, gray centered line, and listening point ask patches [ if pycor = 0 [ set pcolor gray ] draw-left-speaker draw-right-speaker if ( pxcor = listening-point and pycor > 0 and pycor < 4 ) [ set pcolor white ] ] get-a-point reset-ticks end to go ;; Move all the wave turtles ask turtles [ if ( color = green ) [ drive-force ] if ( color = yellow or color = cyan ) [ driven-force ] if ( color = blue ) [ update ] if ( color = red ) [ interfere ] ] get-a-point tick ;; Reset the velocities ask turtles [ set yvel-old yvel-new set ypos-old ypos-new ] ;; Check if a hide/show switch changed show-or-hide end to drive-force ;; procedure for green turtles set time time + 1 ifelse (breed = lefts) [ set ypos-new amplitude-left * ( sin (frequency-left * 0.1 * time )) ] [ set ypos-new amplitude-right * ( sin (frequency-right * 0.1 * time )) ] set ypos-old ypos-new set ycor ypos-new end to driven-force ;; procedure for yellow and cyan turtles set yvel-new yvel-old + ( [ypos-old] of turtle ( who - 1 ) ) - ypos-old + ( [ypos-old] of turtle ( who + 1 ) ) - ypos-old set yvel-new ( ( 1000 - friction ) / 1000 ) * yvel-new set ypos-new ypos-old + yvel-new set ycor ypos-new end to update ;; procedure for blue turtles ifelse ( breed = lefts ) [ set ypos-new [ypos-old] of turtle ( who - 1 ) ] [ set ypos-new [ypos-old] of turtle ( who + 1 ) ] set ycor ypos-new end to interfere ;; procedure for red turtles set ypos-new ( ( [ypos-new] of turtle ( who - world-width ) ) + ( [ypos-new] of turtle ( who - ( 2 * world-width ) ) ) ) ifelse patch-at 0 (ypos-new - ycor) != nobody and show-sum? [ set ycor ypos-new show-turtle ] [ hide-turtle ] end to get-a-point ;; Changes the listening-point if the mouse is down if mouse-down? [ ask patches with [ pxcor = listening-point and pycor > 0 and pycor < 4 ] [ set pcolor black ] set listening-point round mouse-xcor ask patches with [ pxcor = listening-point and pycor > 0 and pycor < 4 ] [ set pcolor white ] ] end to draw-right-speaker ;; patch procedure if ( pxcor = max-pxcor ) and ( pycor > ( -0.1 * max-pxcor ) ) and ( pycor < ( 0.1 * max-pxcor ) ) [ set pcolor orange ] if ( pxcor = round ( 0.9 * max-pxcor ) ) and ( pycor > ( -0.2 * max-pxcor ) ) and ( pycor < ( 0.2 * max-pxcor ) ) [ set pcolor orange ] end to draw-left-speaker ;; patch procedure if ( pxcor = min-pxcor ) and ( pycor > ( -0.1 * max-pxcor ) ) and ( pycor < ( 0.1 * max-pxcor ) ) [ set pcolor orange ] if ( pxcor = round ( - ( 0.9 * max-pxcor ) ) ) and ( pycor > ( -0.2 * max-pxcor ) ) and ( pycor < ( 0.2 * max-pxcor ) ) [ set pcolor orange ] end to show-or-hide ;; The sums are hidden in the interference procedure because they may ;; move outside the world ifelse show-left? [ if any? lefts with [ hidden? ] [ ask lefts [ st ] ] ] [ if any? lefts with [ not hidden? ] [ ask lefts [ ht ] ] ] ifelse show-right? [ if any? rights with [ hidden? ] [ ask rights [ st ] ] ] [ if any? rights with [ not hidden? ] [ ask rights [ ht ] ] ] end ; Copyright 1998 Uri Wilensky. ; See Info tab for full copyright and license.
There are 10 versions of this model.
Attached files
File | Type | Description | Last updated | |
---|---|---|---|---|
Speakers.png | preview | Preview for 'Speakers' | over 11 years ago, by Uri Wilensky | Download |
This model does not have any ancestors.
This model does not have any descendants.