Source code for RCAIDE.Framework.Analyses.Noise.Frequency_Domain_Buildup
# RCAIDE/Framework/Analyses/Noise/Frequency_Domain_Buildup.py
#
#
# Created: Jul 2023, M. Clarke
# Modified: Oct 2024, A. Molloy
# ----------------------------------------------------------------------------------------------------------------------
# IMPORT
# ----------------------------------------------------------------------------------------------------------------------
# RCAIDE Imports
import RCAIDE
from RCAIDE.Library.Methods.Noise.Common.decibel_arithmetic import SPL_arithmetic
from RCAIDE.Library.Methods.Noise.Common.generate_hemisphere_microphone_locations import generate_hemisphere_microphone_locations
from RCAIDE.Library.Methods.Noise.Frequency_Domain_Buildup.Rotor.compute_rotor_noise import compute_rotor_noise
from .Noise import Noise
# package imports
import numpy as np
# ----------------------------------------------------------------------------------------------------------------------
# Frequency_Domain_Buildup
# ----------------------------------------------------------------------------------------------------------------------
[docs]
class Frequency_Domain_Buildup(Noise):
"""This is an acoustic analysis based on a collection of frequency domain methods
Assumptions:
Source:
N/A
Inputs:
None
Outputs:
None
Properties Used:
N/A
"""
def __defaults__(self):
""" This sets the default values for the analysis.
Assumptions:
Ground microphone angles start in front of the aircraft (0 deg) and sweep in a lateral direction
to the starboard wing and around to the tail (180 deg)
Source:
N/A
Inputs:
None
Output:
None
Properties Used:
N/A
"""
# Initialize quantities
self.tag = "Frequency_Domain_Buildup"
self.settings.fidelity = 'line_source'
self.settings.use_plane_loading_surrogate = True
[docs]
def evaluate_noise(self,segment):
""" Process vehicle to setup vehicle, condititon and configuration
Assumptions:
None
Source:
N/4
Inputs:
self.settings.
center_frequencies - 1/3 octave band frequencies [unitless]
Outputs:
None
Properties Used:
self.vehicle
"""
# unpack
config = segment.analyses.noise.vehicle
settings = self.settings
conditions = segment.state.conditions
dim_cf = len(settings.center_frequencies )
ctrl_pts = int(segment.state.numerics.number_of_control_points)
microphone_locations = generate_hemisphere_microphone_locations(settings)
N_hemisphere_mics = len(microphone_locations)
# create empty arrays for results
total_SPL_dBA = np.ones((ctrl_pts,N_hemisphere_mics))*1E-16
total_SPL_spectra = np.ones((ctrl_pts,N_hemisphere_mics,dim_cf))*1E-16
# iterate through sources and iteratively add rotor noise
rotor_tag = None
i = 0
for network in config.networks:
for propulsor in network.propulsors:
for sub_tag , sub_item in propulsor.items():
if isinstance(sub_item, RCAIDE.Library.Components.Powertrain.Converters.Rotor):
rotor_tag = compute_rotor_noise(microphone_locations,sub_item,segment,settings, rotor_index = i, previous_rotor_tag= rotor_tag, identical_propulsors=network.identical_propulsors)
total_SPL_dBA = SPL_arithmetic(np.concatenate((total_SPL_dBA[:,None,:],conditions.noise.converters[sub_item.tag].SPL_dBA[:,None,:]),axis =1),sum_axis=1)
total_SPL_spectra = SPL_arithmetic(np.concatenate((total_SPL_spectra[:,None,:,:],conditions.noise.converters[sub_item.tag].SPL_1_3_spectrum[:,None,:,:]),axis =1),sum_axis=1)
i += 1
conditions.noise.hemisphere_SPL_dBA = total_SPL_dBA
conditions.noise.hemisphere_SPL_1_3_spectrum_dBA = total_SPL_spectra
return