Datenablage für Tinnitus Therapie Projektarbeit von Julian Seyffer und Heiko Ommert SS2020
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

SoundGenerator.py 4.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. import math
  2. import wave #bearbeiten von .wav-Dateien
  3. import struct
  4. import sounddevice as sd #zum abspielen des audio-arrays
  5. import random as random #für die Rauscherzeugung
  6. import time #nur für die Tests, um Zeit zum Anhören der Sounds einzubauen
  7. #In .wav-Dateien wird der Ton in absoluten Werte eingetragen. Die Standart-framerate ist 44100
  8. #das heißt für jede Sekunde an Ton gibt es 44100 Werte, die die Tonwelle über die Zeit beschreiben
  9. class Tinnitus: #beinhaltet alle Werte, die vom Nutzer eingestellt werden
  10. def __init__(self, l_freq=600, r_freq=600, l_amp=1, r_amp=1, l_rausch=0, r_rausch=0, ear=0):
  11. self.linksFrequenz = l_freq
  12. self.rechtsFrequenz = r_freq
  13. self.linksLautstaerke = l_amp
  14. self.rechtsLautstaerke = r_amp
  15. self.linksRauschenLautstaerke = l_rausch #float von 0-1 (0 ist aus)
  16. self.rechtsRauschenLautstaerke = r_rausch
  17. self.ear = ear # 0:both 1:left 2:right 3:links/rechts unterschiedlich
  18. return
  19. #Die Klasse beinhaltet alle Werte, die zum Erstellen einer .wav-Datei benötigt werden und ein Tinnitus-Objekt, das beim Initialisieren übergeben werden muss.
  20. #Die Audiodaten werden in das Array "audio" geschrieben
  21. class Sound:
  22. def __init__(self, tinnitus, name="sound.wav", audio=None, nchannels=1, sampwidth=2, framerate=44100, comptype="NONE", compname="not compressed"):
  23. if audio is None:
  24. audio = []
  25. self.tinnitus = tinnitus
  26. self.name = name
  27. self.audio = audio #ein Array, in das die Sound-Werte geschrieben werden
  28. self.nchannels = nchannels #Zahl der audio channels (1:mono 2:stereo)
  29. self.sampwidth = sampwidth #Größe eines einzelnen Sound-Werts (in bytes)
  30. self.framerate = framerate #Abtastrate
  31. self.nframes = len(audio) #Anzahl der Sound-Werte -> Muss bei jeder audio-Änderung aktuallisiert werden
  32. self.comptype = comptype
  33. self.compname = compname
  34. return
  35. def neu_audio(self): #Schreibt Werte in das audio-Array. Soll später abhängig sein von den Tinnitus-Werten(Frequenz, Rauschen, ...)
  36. freq = self.tinnitus.linksFrequenz
  37. dauer_ms = 100.0
  38. amp = self.tinnitus.linksLautstaerke
  39. rauschen = self.tinnitus.linksRauschenLautstaerke
  40. self.audio.clear()
  41. num_samples = dauer_ms * (self.framerate / 1000.0) # framerate -pro Sekunde- umgerechnet in -pro Millisekunde-
  42. # einen einfachen Sinus ins array schreiben
  43. for x in range(int(num_samples)):
  44. self.audio.append(amp * math.sin(2 * math.pi * freq * (x / self.framerate)))
  45. #das Rauschen addieren
  46. if(self.tinnitus.linksRauschenLautstaerke != 0):
  47. for x in range(int(num_samples)):
  48. self.audio[x] += random.random() * rauschen
  49. return
  50. def wav_speichern(self): #ezeugt/aktuallisiert die .wav-Datei
  51. self.neu_audio()
  52. #das 100ms audio-array strecken:
  53. for x in range(50): # entspricht 5 Sekunden
  54. for y in range(int(self.framerate/10)):
  55. self.audio.append(self.audio[y])
  56. wav_file = wave.open(self.name, "w")
  57. #erst werden die Rahmen-Parameter gesetzt
  58. self.nframes = len(self.audio) # Anpassen des nframes-Parameters
  59. wav_file.setparams((self.nchannels, self.sampwidth, self.framerate, self.nframes, self.comptype, self.compname))
  60. #dann wird das audio-Array an die Datei übertragen
  61. for sample in self.audio:
  62. wav_file.writeframes(struct.pack('h', int(sample * 32767.0)))
  63. wav_file.close()
  64. return
  65. def play(self):
  66. self.neu_audio()
  67. sd.play(self.audio, self.framerate, loop=1)
  68. return
  69. tinnitus1 = Tinnitus()
  70. sound = Sound(tinnitus1)
  71. if(0):
  72. print("======abnehmende Lautstärke==========")
  73. for x in range(10):
  74. print(" Lautstärke = ", tinnitus1.linksLautstaerke)
  75. sound.play()
  76. time.sleep(0.6)
  77. tinnitus1.linksLautstaerke -= 0.1
  78. print("\n\n")
  79. time.sleep(1)
  80. tinnitus1.linksLautstaerke = 1
  81. if(0):
  82. print("=========RauschTest============")
  83. for x in range(10):
  84. tinnitus1.linksRauschenLautstaerke += 0.01
  85. print(" Rauschen = ", tinnitus1.linksRauschenLautstaerke)
  86. sound.play()
  87. time.sleep(1)
  88. sd.stop()
  89. print("ENDE")