0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

はじめに

ARフィルタを使ってやまびこ音(反響音)から反響を除去してみました。
ARフィルタの概要は前回紹介したこちらを読んでみてください。
この記事ではモータの駆動音からやまびこ音を準備し、ARフィルタを実際に使ってみた結果を紹介します。

手順

①実験に使用するためのやまびこ音を作る。
②ARフィルタを作成する。
③ARフィルタを使って①で作成したやまびこ音を取り除く。

やまびこ音の準備

やまびこ音を作るにあたって、室内音響シミュレーションができるpyroomacousticsを使いました。

・音響シミュレーションの条件

シミュレーションには部屋と音源の条件が必要です。
下の表のような設定で音響シミュレーションをしてみました。

設定項目 設定内容
部屋の大きさ 1辺が240mの立方体
壁の材料 南のみ反射しやすい材料
それ以外吸音しやすい材料
マイク1の位置 [122, 120.03, 120]
マイク2の位置 [122, 119.97, 120]
スピーカーの位置 [118, 120, 120]

・ソースコード

import matplotlib.pyplot as plt
import numpy as np
from scipy.io import wavfile
import pyroomacoustics as pra
if __name__ == "__main__":

    # 部屋の大きさを設定(m)
    room_dim = [240, 240, 240]  
    # モノラルで録音したwavファイルの読み込み
    fs, audio = wavfile.read("audio01.wav")

    # 壁の材質をそれぞれ設定
    m = pra.make_materials(
        ceiling="ceiling_fibre_abosrber",  # 吸音しやすい
        floor="ceiling_fibre_abosrber",
        east="ceiling_fibre_abosrber",
        west="ceiling_fibre_abosrber",
        north="ceiling_fibre_abosrber",
        south="reverb_chamber",  # 反射しやすい 
        )

    # 部屋を作成する
    room = pra.ShoeBox(
        room_dim,
        fs=fs,
        materials=m,
        max_order=1,
        air_absorption=False,
        )

    # 音源の座標の入力
    room_audio = [118, 120, 120]
    room.add_source(room_audio, signal=audio, delay=0.5)
    # マイクの位置の設定。
    # 2つ以上設定する場合は異なった位置に設定してください。
    mic1 = [122, 120.03, 120]
    mic2 = [122, 119.97, 120]
    mic_locs = np.c_[mic1, mic2]

    # 最後に部屋に配列を置く
    room.add_microphone_array(mic_locs)
    fig, ax = room.plot()
    # 手動で部屋に対する表示範囲の変更
    ax.set_xlim([0, room_dim[0]+10])
    ax.set_ylim([0, room_dim[1]+10])
    ax.set_zlim([0, room_dim[2]+10])

    # シミュレーションを実行
    room.simulate()

    room.mic_array.to_wav(
        f"audio_reverb.wav",
        norm=True,
        bitdepth=np.int16,
    )
    # 部屋を表示
    plt.figure()
    plt.tight_layout()
    plt.show()

・マイク(〇印)と音源(×印)の位置を立体的に表した図

マイクと音源の位置が大体中央になるように設定されています。
3D_room.png

ARフィルタの結果

・元の音源(モータの駆動音)

元の音源はこちらです。

・作成したやまびこ音

やまびこ音はこちらです。

・ARフィルタをかけた結果

ARフィルタをかけた結果はこちらです

・観察結果

各音データについて音圧波形、メルスペクトログラム、周波数ごとの強度を比較した。

モータの駆動音部分 ARフィルタ後モータの駆動音部分 モータの駆動音の反響音 ARフィルタ後モータの駆動音の反響音

・モータの駆動音部分について音圧波形を比較するとARフィルタ後のほうが圧倒的に小さくなっている
・反響音について周波数強度を比較するとARフィルタ後のほうが圧倒的に小さくなっている

まとめ

ARフィルタ使用前後の反響音を比べてみると、音圧波形の振幅と周波数強度が小さくなっていることがわかりました。
元の音を学習してARフィルタを作成することで反響音をきれいに消すことができました。
一方で学習する範囲の調整は大変で、反響音を消せるフィルタになるために手間がかかりました。
今後、反響音が混ざった音の解析で活用したいです!!

今回使用した室内音響シミュレーションができるpyroomacousticsも面白そうです。
今後も調べていきたいです。

コメントやリクエストがあればぜひよろしくお願いいたします。

参考ページ

ホームシアターにカーペットを敷くべきか?
pyroomacousticsのドキュメントページ

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?