-
Notifications
You must be signed in to change notification settings - Fork 441
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Wrong signal amplitude (NLOS) when Y and Z of source and microphone positions match #249
Comments
Thank you so much for reporting this! I will investigate. |
I just took a look to your files. Thank you for all the details. One thing that is important is that all the wall normals should be pointing outward from the room. This means that for the obstacle in the room, the normals should be pointing towards the inside of the obstacle. |
The normals point in the correct direction. The scaling of the normals seemed to be arbitrary, so I just recumputed them from the triangles (which are counter-clockwise when viewed from the 'outside', if that's relevant), but it didn't affect the output. Could it be an Issue that the STLs are in ASCII format? |
I just noticed the face normals of the STL file are never used directly. I initialize the walls as per the code in |
So I think I found the cause of the error. I have mostly looked at the first example with source at [1, 1, 1] and mic at [3, 1, 1]. The problem comes from the reflecting wall being split into two triangles. This generates two image sources at the same location. Because the line of sight between the image source and the mic intersects the wall exactly on the boundary, the image source is marked as visible from for both triangles. When you move the image source by a millimeter, then the path does not interesect on the boundary anymore and one of the image source is not visible from the microphone and correctly eliminated. This is a corner case of the current implementation. I think you can solve the issue by manually merging the triangles into a single rectangular face. You can also solve this by trying to choose source/mic locations that are not too regular. Add a little bit of noise (e.g. a few mm) to the locations. |
You are right! The normals are determined from the order of the face corners. |
Hi,
I noticed weird behaviour of the amplitude of the simulated signal in non-LOS situations:
When the Y and Z coordinates of sound source and microphone match (e.g. source [1, 1, 1] and mic [3, 1, 1]), the amplitude of the signal is approx. twice as high as it should be (source amplitude divided by distance / length of signal path in metres).
Issue
considering the following room with one reflective wall and an obstacle to block the direct path:
data:image/s3,"s3://crabby-images/ecc97/ecc970eb6224faf67de65d56afbbcee6d7d9ec23" alt="room_nlos"
data:image/s3,"s3://crabby-images/62bbc/62bbc53523693afdbbe3d74066c2066a869d4875" alt="nlos_wrong"
data:image/s3,"s3://crabby-images/e8933/e8933e167e6bbf0e7ea601e63844b9210e8282ce" alt="nlos_correct"
source and mic positions of [1, 1, 1] and [3, 1, 1] produce a wrong amplitude when comparing with manually computed reference (using a sine-wave of amplitude 1 as signal):
changing either Y or Z coordinate of the microphone by 1mm gives correct results:
LOS plus NLOS
Repeating this with LOS plus NLOS (same room but without the obstacle) shows the same behaviour for the NLOS-component of the signal:
data:image/s3,"s3://crabby-images/3431b/3431bdb5436da914b344d0fcd466f8b8d2b9f291" alt="room_los_plus_nlos"
data:image/s3,"s3://crabby-images/36c79/36c799300297140f88c59208c04282f0890253fa" alt="los_plus_nlos_false"
data:image/s3,"s3://crabby-images/6255a/6255a14db6d019c66db9a9b09aaa9a2d7f2df720" alt="los_plus_nlos_correct"
room:
Y and Z matching:
changing Y by 1mm:
Edge case
Changing both Y and Z usually also works:
data:image/s3,"s3://crabby-images/99328/99328ff7a0a14087c55df24dd7287e0de2277591" alt="los_plus_nlos_both"
data:image/s3,"s3://crabby-images/9c8db/9c8dbf70ed4100d08fa8763ee6fa89516200f10f" alt="los_plus_nlos_both_false"
data:image/s3,"s3://crabby-images/68fcd/68fcd0eab357ddc6f67ec03d843fab963611ccc3" alt="los_plus_nlos_both_correct"
However, at different Y position of 1.5, this again results in wrong amplitude for the NLOS component:
Changing only one value still works here:
Raytracing
This also occurs when using raytraycing, although then the signal also shows some tolerable inaccuracies in the 'correct' cases.
Code to reproduce
Code and files (room STLs and material annotation files) for reproducing this issue: pyroomacoustics_issue_nlos_amplitude.zip
relevant code: (without room building and plotting)
`
USE_RAYTRACING = False
SAMPLING_RATE = 44100
SPEED_OF_SOUND = 343 # m/s
sound_delay_samples_per_meter = 1 / SPEED_OF_SOUND * SAMPLING_RATE
SOUND_DELAY_SAMPLES_CONSTANT = 40.5 # determined empirically, matches (pra.constants.get("frac_delay_length") / 2)
SIGNAL_LENGTH = 100
def compute_reflection_point(source: np.ndarray, mic: np.ndarray) -> np.ndarray:
dist_x = mic[0] - source[0]
source_to_wall_to_mic_to_wall_plus_source_to_wall = (2 - source[1]) / ((2 - mic[1]) + (2 - source[1]))
source_to_reflection_point_x = dist_x * source_to_wall_to_mic_to_wall_plus_source_to_wall
reflection_point = np.array([source[0] + source_to_reflection_point_x, 2, 1])
return reflection_point
def verify(signal: np.ndarray, source: np.ndarray, mic: np.ndarray, nlos_only: bool) -> Tuple[np.ndarray, np.ndarray]:
def exec_one_test(signal, mic, nlos_only: bool, source: np.ndarray = np.array([1, 1, 1])):
def main():
# simple sine wave as test signal
signal = np.sin(np.asarray(range(SIGNAL_LENGTH)) * np.pi / 10)
`
Testing Environment
cycler 0.11.0 Cython 0.29.27 fonttools 4.29.1 kiwisolver 1.3.2 matplotlib 3.5.1 numpy 1.22.2 numpy-stl 2.16.3 packaging 21.3 Pillow 9.0.1 pip 22.0.3 pybind11 2.9.1 pyparsing 3.0.7 pyroomacoustics 0.6.0 python-dateutil 2.8.2 python-utils 3.1.0 scipy 1.8.0 setuptools 60.8.1 six 1.16.0
The text was updated successfully, but these errors were encountered: