Misc
jmult_max
Calculate the maximum value of jmult.
Parameters: num_part (int): The number of particles. lmax (int): The maximum value of l.
Returns:
Type | Description |
---|---|
int
|
The maximum value of jmult. |
Source code in yasfpy/functions/misc.py
10 11 12 13 14 15 16 17 18 19 20 21 |
|
multi2single_index
Converts the multi-index (j_s, tau, l, m) to a single index.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
j_s
|
int
|
Particle index. |
required |
tau
|
int
|
Polarization value (1 or 2). |
required |
l
|
int
|
The value of l (between 0 and lmax). |
required |
m
|
int
|
The value of m (between -l and l). |
required |
lmax
|
int
|
Cutoff value for the field expansion. |
required |
Returns:
Type | Description |
---|---|
int
|
The single index corresponding to the multi-index (j_s, tau, l, m). |
Source code in yasfpy/functions/misc.py
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 |
|
single_index2multi
Convert a single index to multi-indices (j_s, tau, l, m) for spherical harmonics.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
idx
|
int
|
The single index. |
required |
lmax
|
int
|
Cutoff value for the field expansion. |
required |
Returns:
Name | Type | Description |
---|---|---|
j_s |
int
|
Particle index. |
tau |
int
|
Polarization value (1 or 2). |
l |
float
|
The value of l (between 0 and lmax). |
m |
int
|
The value of m (between -l and l). |
Source code in yasfpy/functions/misc.py
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
|
transformation_coefficients
Calculate the transformation coefficients for spherical harmonics.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
pilm
|
ndarray
|
Array of spherical harmonics. |
required |
taulm
|
ndarray
|
Array of spherical harmonics. |
required |
tau
|
int
|
Polarization state. |
required |
l
|
int
|
Degree of the spherical harmonics. |
required |
m
|
int
|
Order of the spherical harmonics. |
required |
pol
|
int
|
Polarization state. |
required |
dagger
|
bool
|
Whether to apply the dagger operation. Defaults to False. |
False
|
Returns:
Type | Description |
---|---|
float
|
The transformation coefficient. |
Source code in yasfpy/functions/misc.py
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 |
|
mutual_lookup
Calculate mutual lookup tables for scattering calculations.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
lmax
|
int
|
The maximum degree of the spherical harmonics expansion. |
required |
positions_1
|
ndarray
|
The positions of the first set of particles. |
required |
positions_2
|
ndarray
|
The positions of the second set of particles. |
required |
refractive_index
|
ndarray
|
The refractive indices of the particles. |
required |
derivatives
|
bool
|
Whether to calculate the derivatives of the lookup tables. Defaults to False. |
False
|
parallel
|
bool
|
Whether to use parallel computation. Defaults to False. |
False
|
Returns:
Name | Type | Description |
---|---|---|
spherical_bessel |
ndarray
|
The spherical Bessel functions. |
spherical_hankel |
ndarray
|
The spherical Hankel functions. |
e_j_dm_phi |
ndarray
|
The exponential term in the scattering calculation. |
p_lm |
ndarray
|
The normalized Legendre polynomials. |
e_r |
ndarray
|
The unit vectors in the radial direction. |
e_theta |
ndarray
|
The unit vectors in the polar direction. |
e_phi |
ndarray
|
The unit vectors in the azimuthal direction. |
cosine_theta |
ndarray
|
The cosine of the polar angle. |
sine_theta |
ndarray
|
The sine of the polar angle. |
size_parameter |
ndarray
|
The size parameter of the particles. |
spherical_hankel_derivative |
ndarray
|
The derivative of the spherical Hankel functions. |
Source code in yasfpy/functions/misc.py
118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 |
|
generate_refractive_index_table
The function generate_refractive_index_table
takes a list of URLs, retrieves data from each
URL using the material_handler
function, and returns a list of the retrieved data.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
urls
|
list
|
A list of URLs representing different materials. |
required |
Returns:
Name | Type | Description |
---|---|---|
data |
list
|
A list of data. Each element in the list corresponds to a URL in the input list,
and the data is obtained by calling the |
Source code in yasfpy/functions/misc.py
255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 |
|