Browse Source

Mikrofon Activity Ausbesserung Kalibrierung;

Speicherung der dB-Werte nur, wenn positiv + Kommentare zum Verständnis der zu speichernden Variablen
Mikrofon
Julia Prölß 1 year ago
parent
commit
d3d7def833
1 changed files with 46 additions and 32 deletions
  1. 46
    32
      app/src/main/java/com/example/greenwatch/Mikrofon.java

+ 46
- 32
app/src/main/java/com/example/greenwatch/Mikrofon.java View File

private final static String KEY_WERT = "KEY_WERT_" + Mikrofon.class.getSimpleName(); private final static String KEY_WERT = "KEY_WERT_" + Mikrofon.class.getSimpleName();
private final static String KEY_KALIBRIERUNG = "KEY_KALIBRIERUNG_" + Mikrofon.class.getSimpleName(); private final static String KEY_KALIBRIERUNG = "KEY_KALIBRIERUNG_" + Mikrofon.class.getSimpleName();


//zu speichernde Daten: detection_mic, zeit,
// kalibrierung_do (Unterscheidung, ob Activity aus Benutzersicht (back-Taste --> erneuter Start führt zu erneutem Kalbireren) oder durch Kippen beendet (isFinishing()==false und nicht ernuet kalbrieren),
//threshold + sensitivity speichern, damit beim Kippen das nicht verloren geht,
//Verarbeitungsergebnis ergebnis in der doInBackground Funktion muss auch gespeichert werden, da dort der aktuelle db-Wert enthalten ist --> sonst machen Werte kurz nach dem Kippen keinen Sinn mehr
//aktuell noch SharedPref bei kalibrierung_do und threshold implementiert --> kann nach erfolgreichem Einbinden in Model entfernt werden
//Infos zu Variablen:
//detection_mic: solange true, solange ergebnis.db > threshold+sensitivity -> wird false, sobald ergebnis.db < threshold
//zeit: wird sowohl bei Beginn der Detektion als auch beim Ende der Detektion aktualisiert
//Funktion der App: nach Start 3s Thread.sleep, damit man das Handy positionieren kann -> Kalibrierung folgt, dauert mehrere Sekunden, erst nach Kalbrierung werden Werte angezeigt
//offenes Problem: beim allerersten Start nach der Installation wird der alte Kalbrierwert verwendet und nicht erneut kalibriert --> nach Einbinden Verhalten erneut prüfen






textViewMaxAmp = (TextView) findViewById(R.id.textViewMaxAmp); textViewMaxAmp = (TextView) findViewById(R.id.textViewMaxAmp);
textViewMaxAmpdb = (TextView) findViewById(R.id.textViewMaxAmpdb); textViewMaxAmpdb = (TextView) findViewById(R.id.textViewMaxAmpdb);
textViewZeitstempel = (TextView) findViewById(R.id.textViewZeitstempel); textViewZeitstempel = (TextView) findViewById(R.id.textViewZeitstempel);
//kalibrierung_do = true;



} }



@Override @Override
protected void onResume() { protected void onResume() {
super.onResume(); super.onResume();
int zaehlerZeitMessung = 0; int zaehlerZeitMessung = 0;
int anzahlVerarbeitet = 0; int anzahlVerarbeitet = 0;
GleitenderMittelwert gleitenderMittelwert = new GleitenderMittelwert(0.3f); GleitenderMittelwert gleitenderMittelwert = new GleitenderMittelwert(0.3f);
GleitenderMittelwert gleitenderMittelwertdB = new GleitenderMittelwert(0.1f);
GleitenderMittelwert gleitenderMittelwertdB = new GleitenderMittelwert(0.2f);
float db = 0; float db = 0;
boolean erlaubt_rise = true; boolean erlaubt_rise = true;
boolean erlaubt_fall = true; boolean erlaubt_fall = true;


//kalibrierung
if(kalibrierung_do){
//3s warten auf weitere Ausführung
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}

int anzahlIterationen = 100;
float sum = 0;
//Mittelwertbildung für kalibrierten threshold
for(int i = 0; i < anzahlIterationen; i++){
if (isCancelled()) {
break;
} else {
int z = recorder.read(puffer, 0, puffer.length);
Verarbeitungsergebnis kalibrierung = verarbeiten(puffer, z);
sum += (float) kalibrierung.db;
System.out.println("Kalibrierungswert zum Testen" + kalibrierung.db);
}

}
threshold = sum/anzahlIterationen;
kalibrierung_do = false;
}




for (; ; ) { for (; ; ) {
Verarbeitungsergebnis ergebnis = verarbeiten(puffer, n); Verarbeitungsergebnis ergebnis = verarbeiten(puffer, n);
anzahlVerarbeitet += n; anzahlVerarbeitet += n;


//kalibrierung
if(kalibrierung_do){
// Warten für 3 Sekunden
/*long startTime = System.currentTimeMillis(); // Startzeit
while (System.currentTimeMillis() - startTime < 3000) {
//Warten
}*/
//3s warten auf weitere Ausführung
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
//int z = recorder.read(puffer, 0, puffer.length);
//Verarbeitungsergebnis kalibrierung = verarbeiten(puffer, z);
int anzahlIterationen = 3000;
float sum = 0;
for(int i = 0; i < anzahlIterationen; i++){
sum += ergebnis.db;
}
threshold = sum/anzahlIterationen;
kalibrierung_do = false;
}


zaehlerZeitMessung++; zaehlerZeitMessung++;
if (zaehlerZeitMessung == maxZaehlerZeitMessung) { if (zaehlerZeitMessung == maxZaehlerZeitMessung) {
long time = System.currentTimeMillis(); long time = System.currentTimeMillis();
//Hysterese beim Setzen bzw. Rücksetzen ob detektiert //Hysterese beim Setzen bzw. Rücksetzen ob detektiert
//beim ersten detektieren wird Zeitpunkt gespeichert //beim ersten detektieren wird Zeitpunkt gespeichert
if(ergebnis.db >= (threshold+sensitivity)){ if(ergebnis.db >= (threshold+sensitivity)){
detection_mic = true;
detection_mic = true; //solange true, solange ergebnis.db > threshold+sensitivity
erlaubt_fall = true; erlaubt_fall = true;
while(erlaubt_rise){ while(erlaubt_rise){
erlaubt_rise = false; erlaubt_rise = false;
zeit = Zeitpunkt() + " - " + ergebnis.db + " - " + (threshold+sensitivity); //Überschreiben des Zeitpunkts beim Erkennen der Detektion zeit = Zeitpunkt() + " - " + ergebnis.db + " - " + (threshold+sensitivity); //Überschreiben des Zeitpunkts beim Erkennen der Detektion
//nur zum Testen in zeit noch ergebnis.db und threshold ausgegeben -> muss am Ende nur Zeitpunkt() rein, Rest weg //nur zum Testen in zeit noch ergebnis.db und threshold ausgegeben -> muss am Ende nur Zeitpunkt() rein, Rest weg
//Amplitude zum Zeitpunkt der Detektion steht in ergebnis.db, wird zyklisch bei jedem Durchlauf der for-Schleife überschrieben
} }
} else if (ergebnis.db <= (threshold)) { } else if (ergebnis.db <= (threshold)) {
detection_mic = false; detection_mic = false;
private Verarbeitungsergebnis verarbeiten(short[] daten, int n) { private Verarbeitungsergebnis verarbeiten(short[] daten, int n) {
String status; String status;
short maxAmp = -1; short maxAmp = -1;
int db = 0;
int db = 0, wert_db = 0;


if (n == AudioRecord.ERROR_INVALID_OPERATION) { if (n == AudioRecord.ERROR_INVALID_OPERATION) {
status = "ERROR_INVALID_OPERATION"; status = "ERROR_INVALID_OPERATION";
maxAmp = ringPuffer.maximum(); maxAmp = ringPuffer.maximum();
} }
//Umwandlung Amplitudenwert in dB //Umwandlung Amplitudenwert in dB
db = (int) (20*Math.log10(maxAmp));
wert_db = (int) (20*Math.log10(maxAmp));

if(wert_db > 0){
db = wert_db;
}



return new Verarbeitungsergebnis(status, maxAmp,0, db); return new Verarbeitungsergebnis(status, maxAmp,0, db);
} }

Loading…
Cancel
Save