BaseScatteringDoinikov1994
Examples using this class are:
- class osaft.solutions.basedoinikov1994.scattering.BaseScatteringDoinikov1994(N_max)[source]
Bases:
BaseScattering,ABCBase scattering class for Doinikov solutions from 1994
- Parameters:
N_max (
int) – Highest order mode included in the computation [-]
Public Data Attributes:
Returns the wave number in the fluid \(k_f\) [1/m]
Returns the viscous wave number in the fluid \(k_v\) [1/m]
fieldomegaR_0rho_fInherited from
BaseScatteringCutoff mode number for infinite sums
fieldomegaR_0rho_fk_fPublic Methods:
Wrapper to the fluid scattering coefficients for an inviscid fluid
V_r_sc(n, r)Radial scattering field velocity term of mode n without Legendre coefficients
V_theta_sc(n, r)Tangential scattering field velocity term of mode n without Legendre coefficients
A_in(n)Incoming wave amplitude
alpha_n(n)\(\alpha_n\) coefficient
beta_n(n)\(\beta_n\) coefficient
Inherited from
BaseScatteringradial_acoustic_fluid_velocity(r, theta, t, ...)Returns the value for the radial acoustic velocity in [m/s].
tangential_acoustic_fluid_velocity(r, theta, ...)Returns the value for the tangential acoustic velocity in [m/s].
pressure(r, theta, t, scattered, incident[, ...])Returns the acoustic pressure [Pa].
Wrapper to the fluid scattering coefficients for an inviscid fluid
velocity_potential(r, theta, t, scattered, ...)Returns the velocity potential of the fluid in [m^2/s].
radial_particle_velocity(r, theta, t[, mode])Returns the value for the radial particle velocity in [m/s].
tangential_particle_velocity(r, theta, t[, mode])Returns the value for the tangential particle velocity in [m/s].
radial_particle_displacement(r, theta, t[, mode])Particle displacement in radial direction
tangential_particle_displacement(r, theta, t)Particle displacement in tangential direction
radial_mode_superposition(radial_func, r, ...)Returns either a single mode (
mode=int) or a the sum untilN_max(mode=None).Returns either a single mode (
mode=int) or a the sum untilN_max(mode=None).V_r_i(n, r)Radial incident field velocity term of mode n without Legendre coefficients
V_theta_i(n, r)Tangential incident field velocity term of mode n without Legendre coefficients
V_r_sc(n, r)Radial scattering field velocity term of mode n without Legendre coefficients
V_theta_sc(n, r)Tangential scattering field velocity term of mode n without Legendre coefficients
V_r(n, r, scattered, incident)Superposition of
V_r_sc()andV_r_i()depending onscatteredandincidentV_theta(n, r, scattered, incident)Superposition of
V_theta_sc()andV_theta_i()depending onscatteredandincident
- V_r(n, r, scattered, incident)
Superposition of
V_r_sc()andV_r_i()depending onscatteredandincidentAt least one of the two must be True.
- Parameters:
n (
int) – moder (
float) – radial coordinate [m]scattered (
bool) – add scattered fieldincident (
bool) – add incident
- Return type:
complex
- V_r_i(n, r)
Radial incident field velocity term of mode n without Legendre coefficients
Returns radial incident field velocity in [m/s]
- Parameters:
n (
int) – moder (
Union[float,Sequence]) – radial coordinate [m]
- Return type:
complex
- V_r_sc(n, r)[source]
Radial scattering field velocity term of mode n without Legendre coefficients
Returns radial scattering field velocity in [m/s]
- Parameters:
n (
int) – moder (
float) – radial coordinate [m]
- Return type:
complex
- V_theta(n, r, scattered, incident)
Superposition of
V_theta_sc()andV_theta_i()depending onscatteredandincidentAt least one of the two must be True.
- Parameters:
n (
int) – moder (
float) – radial coordinate [m]scattered (
bool) – add scattered fieldincident (
bool) – add incident
- Return type:
complex
- V_theta_i(n, r)
Tangential incident field velocity term of mode n without Legendre coefficients
Returns tangential incident field velocity in [m/s]
- Parameters:
n (
int) – moder (
Union[float,Sequence]) – radial coordinate [m]
- Return type:
complex
- V_theta_sc(n, r)[source]
Tangential scattering field velocity term of mode n without Legendre coefficients
Returns tangential scattering field velocity in [m/s]
- Parameters:
n (
int) – moder (
float) – radial coordinate [m]
- Return type:
complex
- abstract alpha_n(n)[source]
\(\alpha_n\) coefficient
- Parameters:
n (
int) – mode- Return type:
complex
- potential_coefficient(n)[source]
Wrapper to the fluid scattering coefficients for an inviscid fluid
This method must be implemented by every theory to have a common interface for other modules.
- Parameters:
n (
int) – mode- Return type:
complex
- pressure(r, theta, t, scattered, incident, mode=None)
Returns the acoustic pressure [Pa].
- Parameters:
r (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]scattered (
bool) – add scattered fieldincident (
bool) – add incidentmode (
Optional[int], optional) – specific mode number of interest; if None then all modes untilN_maxDefault:None- Return type:
complex- radial_acoustic_fluid_velocity(r, theta, t, scattered, incident, mode=None)
Returns the value for the radial acoustic velocity in [m/s].
This method must be implemented by every theory to have a common interface for other modules.
- Parameters:
r (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]scattered (
bool) – scattered field contributionincident (
bool) – incident field contributionmode (
Optional[int], optional) – specific mode number of interest; if None then all modes untilN_maxDefault:None- Return type:
Union[complex,ndarray]- radial_mode_superposition(radial_func, r, theta, t, mode=None)
Returns either a single mode (
mode=int) or a the sum untilN_max(mode=None).If
mode=intthe formula is\[e^{-i\omega t}\, f_{\text{mode}}(r) \,P_{\text{mode}}(\cos\theta)\]If
mode=Nonethe formula is\[e^{-i\omega t} \sum_{n=0}^{\text{N}_{\text{max}}} \,f_n(r) \,P_n(\cos\theta)\]where \(f_\text{n}(r)\) is the
radial_func(n, r)passed to the method.- Parameters:
radial_func (
Callable[[int,float],complex]) – radial function dependent onrr (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]mode (
Optional[int], optional) – specific mode number of interest; if None then all modes untilN_maxDefault:None- Return type:
Union[complex,ndarray]- radial_particle_displacement(r, theta, t, mode=None)
Particle displacement in radial direction
Returns the value of the particle displacement in radial direction in [m]
- Parameters:
r (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]mode (
Optional[int], optional) – specific mode number of interest; if None that all modes untilN_maxDefault:None- Return type:
Union[complex,ndarray]- abstract radial_particle_velocity(r, theta, t, mode=None)
Returns the value for the radial particle velocity in [m/s].
This method must be implemented by every theory to have a common interface for other modules.
- Parameters:
r (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]mode (
Optional[int], optional) – specific mode number of interest; if None then all modes untilN_maxDefault:None- Return type:
complex- tangential_acoustic_fluid_velocity(r, theta, t, scattered, incident, mode=None)
Returns the value for the tangential acoustic velocity in [m/s].
This method must be implemented by every theory to have a common interface for other modules.
- Parameters:
r (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]scattered (
bool) – scattered field contributionincident (
bool) – incident field contributionmode (
Optional[int], optional) – specific mode number of interest; if None then all modes untilN_maxDefault:None- Return type:
Union[complex,ndarray]- tangential_mode_superposition(tangential_func, r, theta, t, mode)
Returns either a single mode (
mode=int) or a the sum untilN_max(mode=None).If
mode=intthe formula is\[e^{-i\omega t}\, f_\text{mode}(r) \,P^1_{\text{mode}}(\cos\theta)\]If
mode=Nonethe formula is\[e^{-i\omega t}\sum_{n=0}^{\text{N}_{\text{max}}} \,f_n(r) \,P^1_n(\cos\theta)\]where \(f_n(r)\) is the
tangential_func(n, r)passed to the method.- Parameters:
tangential_func (
Callable[[int,float],complex]) – tangential function dependent onrr (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]mode (
int) – specific mode number of interest; if None then all modes untilN_max
- Return type:
Union[complex,ndarray]
- tangential_particle_displacement(r, theta, t, mode=None)
Particle displacement in tangential direction
Returns the value of the particle displacement in tangential direction in [m]
- Parameters:
r (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]mode (
Optional[int], optional) – specific mode number of interest; if None that all modes untilN_maxDefault:None- Return type:
Union[complex,ndarray]- abstract tangential_particle_velocity(r, theta, t, mode=None)
Returns the value for the tangential particle velocity in [m/s].
This method must be implemented by every theory to have a common interface for other modules.
- Parameters:
r (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]mode (
Optional[int], optional) – specific mode number of interest; if None then all modes untilN_maxDefault:None- Return type:
complex- velocity_potential(r, theta, t, scattered, incident, mode=None)
Returns the velocity potential of the fluid in [m^2/s].
- Parameters:
r (
Union[float,Sequence]) – radial coordinate [m]theta (
Union[float,Sequence]) – tangential coordinate [rad]t (
Union[float,Sequence]) – time [s]scattered (
bool) – add scattered fieldincident (
bool) – add incidentmode (
Optional[int], optional) – specific mode number of interest; if None then all modes untilN_maxDefault:None- Return type:
complex- property N_max
Cutoff mode number for infinite sums
- Getter:
returns number of infinite sum term
- Setter:
automatically invokes
osaft.core.variable.BaseVariable.notify()
- abstract property k_f: complex
Returns the wave number in the fluid \(k_f\) [1/m]
- abstract property k_v: complex
Returns the viscous wave number in the fluid \(k_v\) [1/m]