Compare commits

..

2 Commits

Author SHA1 Message Date
Emilien Bauer
a0515ae626 Try linking GUI to sound 2023-01-21 16:15:10 +00:00
Emilien Bauer
39089cea40 RandomGenerator 2023-01-21 14:23:03 +00:00
6 changed files with 49 additions and 19 deletions

1
.idea/.name generated Normal file
View File

@ -0,0 +1 @@
procedural-musix

10
.idea/codeStyles/Project.xml generated Normal file
View File

@ -0,0 +1,10 @@
<component name="ProjectCodeStyleConfiguration">
<code_scheme name="Project" version="173">
<JetCodeStyleSettings>
<option name="CODE_STYLE_DEFAULTS" value="KOTLIN_OFFICIAL" />
</JetCodeStyleSettings>
<codeStyleSettings language="kotlin">
<option name="CODE_STYLE_DEFAULTS" value="KOTLIN_OFFICIAL" />
</codeStyleSettings>
</code_scheme>
</component>

5
.idea/codeStyles/codeStyleConfig.xml generated Normal file
View File

@ -0,0 +1,5 @@
<component name="ProjectCodeStyleConfiguration">
<state>
<option name="USE_PER_PROJECT_SETTINGS" value="true" />
</state>
</component>

View File

@ -18,6 +18,7 @@ class AudioSink : Thread() {
get() = chunks.size get() = chunks.size
fun enqueueChunk(chunk: AudioChunk) { fun enqueueChunk(chunk: AudioChunk) {
println(chunk.tick)
chunks.add(chunk.toBytes()) chunks.add(chunk.toBytes())
} }

View File

@ -5,6 +5,7 @@ import Params.as_samples
import filter.Compressor import filter.Compressor
import filter.EchoFilter import filter.EchoFilter
import filter.Limiter import filter.Limiter
import java.lang.StrictMath.pow
import gui.SimpleEx import gui.SimpleEx
import random.RandomDisplacementFractal import random.RandomDisplacementFractal
import java.awt.event.WindowAdapter import java.awt.event.WindowAdapter
@ -41,6 +42,25 @@ class SineWaveGenerator(var tone: Float) : StepGenerator() {
} }
} }
class RandomGenerator(var tone: Float) :StepGenerator() {
val N = 200
val loudness = fun(i:Int): Double {
return i.toDouble().pow(power)
}
var loudnessSum = 0.0
var power:Double = -1.0
init {
for (i in 1 .. N)
loudnessSum+=loudness(i)
}
override fun generateSingle(time: Float): Float {
var p : Double = 0.0
for (i in 1 .. N) {
p += sin(time * toFrequency(tone) * TWO_PI * i) * loudness(i)
}
return (p/loudnessSum).toFloat()
}
}
class RandomDisplacementFractalNoiseGenerator(private val period: Float, val repetitions: Int): StepGenerator() { class RandomDisplacementFractalNoiseGenerator(private val period: Float, val repetitions: Int): StepGenerator() {
val width = (period * SAMPLES).toInt() val width = (period * SAMPLES).toInt()
@ -59,23 +79,18 @@ class RandomDisplacementFractalNoiseGenerator(private val period: Float, val rep
} }
fun main(args: Array<String>) { fun main(args: Array<String>) {
val sink = AudioSink() val sink = AudioSink()
val gen = SoundMachine() val machine = SoundMachine()
SoundMachine.State.bpm = 1024F
gen.globalEffects.add(Compressor(as_samples(.4f).toInt())::apply) machine.globalEffects.add(Compressor(as_samples(.4f).toInt())::apply)
gen.globalEffects.add(Limiter(.9f)::apply) machine.globalEffects.add(Limiter(.9f)::apply)
gen.generators.add(Chain( val gen = RandomGenerator(0f)
RandomDisplacementFractalNoiseGenerator(.2f, 100)::generate, machine.generators.add(Chain(gen::generate, ArrayList()))
listOf(
EchoFilter((SAMPLES * 2).toInt(), 0.2f)::apply,
)
)
)
sink.enqueueChunk(gen.nextChunk()) sink.enqueueChunk(machine.nextChunk())
sink.start() sink.start()
@ -83,8 +98,8 @@ fun main(args: Array<String>) {
Thread { Thread {
while (!close) { while (!close) {
sink.enqueueChunk(gen.nextChunk()) sink.enqueueChunk(machine.nextChunk())
while (sink.queueSize > 2) { while (sink.queueSize > 1) {
Thread.sleep(1) Thread.sleep(1)
} }
} }
@ -92,10 +107,10 @@ fun main(args: Array<String>) {
val frame = SimpleEx("Play!") val frame = SimpleEx("Play!")
frame.add_slider("Property 1", 0, 100, 50).addChangeListener { e -> frame.add_slider("Property 1", 0, 10000, 50).addChangeListener { e ->
val value = (e.source as JSlider).value val value = (e.source as JSlider).value
println(value) gen.power = -value.toDouble()/100.0
println("Switching power to " + gen.power.toString())
} }
frame.isVisible = true frame.isVisible = true

View File

@ -1,7 +1,5 @@
package gui package gui
import javafx.scene.layout.StackPane
import java.awt.EventQueue
import java.awt.GridLayout import java.awt.GridLayout
import java.awt.Label import java.awt.Label
import javax.swing.JFrame import javax.swing.JFrame