Propagate target size.

This commit is contained in:
Lukas Klass 2020-04-28 17:21:26 +02:00
parent 2e6df65928
commit 62013e323e
14 changed files with 41 additions and 24 deletions

View File

@ -1,5 +1,6 @@
from abc import ABC, abstractmethod from abc import ABC, abstractmethod
from .SpectralQty import SpectralQty from .SpectralQty import SpectralQty
from typing import Tuple
class IRadiant(ABC): class IRadiant(ABC):
@ -8,7 +9,7 @@ class IRadiant(ABC):
in the beam. in the beam.
""" """
@abstractmethod @abstractmethod
def calcSignal(self) -> SpectralQty: def calcSignal(self) -> Tuple[SpectralQty, str]:
""" """
Calculate the signal coming from the component Calculate the signal coming from the component
@ -16,6 +17,8 @@ class IRadiant(ABC):
------- -------
signal : SpectralQty signal : SpectralQty
The emitted, reflected or transmitted signal The emitted, reflected or transmitted signal
size : str
The size of the target.
""" """
pass pass

View File

@ -4,7 +4,7 @@ from ...lib.helpers import error
from abc import abstractmethod from abc import abstractmethod
import astropy.units as u import astropy.units as u
from astropy.modeling.models import BlackBody from astropy.modeling.models import BlackBody
from typing import Union, Callable from typing import Union, Callable, Tuple
from logging import info, debug from logging import info, debug
@ -51,7 +51,7 @@ class AOpticalComponent(IRadiant):
self.__obstructor_temp = obstructor_temp self.__obstructor_temp = obstructor_temp
self.__obstructor_emissivity = obstructor_emissivity self.__obstructor_emissivity = obstructor_emissivity
def calcSignal(self) -> SpectralQty: def calcSignal(self) -> Tuple[SpectralQty, str]:
""" """
Calculate the spectral flux density of the target's signal Calculate the spectral flux density of the target's signal
@ -59,12 +59,14 @@ class AOpticalComponent(IRadiant):
------- -------
signal : SpectralQty signal : SpectralQty
The spectral flux density of the target's signal The spectral flux density of the target's signal
size : str
The size of the target.
""" """
signal = self.__parent.calcSignal() signal, size = self.__parent.calcSignal()
info("Calculating signal for class '" + self.__class__.__name__ + "'.") info("Calculating signal for class '" + self.__class__.__name__ + "'.")
signal = self._propagate(signal) * (1 - self.__obstruction) signal = self._propagate(signal) * (1 - self.__obstruction)
debug(signal) debug(signal)
return signal return signal, size
def calcBackground(self) -> SpectralQty: def calcBackground(self) -> SpectralQty:
""" """

View File

@ -4,6 +4,7 @@ from ..SpectralQty import SpectralQty
import astropy.units as u import astropy.units as u
import numpy as np import numpy as np
from logging import info, debug from logging import info, debug
from typing import Tuple
class ATarget(IRadiant): class ATarget(IRadiant):
@ -13,7 +14,7 @@ class ATarget(IRadiant):
@abstractmethod @abstractmethod
@u.quantity_input(wl_bins="length") @u.quantity_input(wl_bins="length")
def __init__(self, sfd: SpectralQty, wl_bins: u.Quantity): def __init__(self, sfd: SpectralQty, wl_bins: u.Quantity, size: str = "Point"):
""" """
Initialize a new target Initialize a new target
@ -21,9 +22,14 @@ class ATarget(IRadiant):
---------- ----------
sfd : SpectralQty sfd : SpectralQty
The spectral flux density of the target The spectral flux density of the target
wl_bins : length-Quantity
The bins to be used for evaluating spectral quantities.
size : str
The size of the target. Can be either point or extended.
""" """
self.__sfd = sfd self.__sfd = sfd
self.__wl_bins = wl_bins self.__wl_bins = wl_bins
self.__size = size
def calcBackground(self) -> SpectralQty: def calcBackground(self) -> SpectralQty:
""" """
@ -39,7 +45,7 @@ class ATarget(IRadiant):
debug(background) debug(background)
return background return background
def calcSignal(self) -> SpectralQty: def calcSignal(self) -> Tuple[SpectralQty, str]:
""" """
Calculate the spectral flux density of the target's signal Calculate the spectral flux density of the target's signal
@ -47,7 +53,9 @@ class ATarget(IRadiant):
------- -------
signal : SpectralQty signal : SpectralQty
The spectral flux density of the target's signal The spectral flux density of the target's signal
size : str
The size of the target.
""" """
info("Calculating Signal for class '" + self.__class__.__name__ + "'.") info("Calculating Signal for class '" + self.__class__.__name__ + "'.")
debug(self.__sfd) debug(self.__sfd)
return self.__sfd return self.__sfd, self.__size

View File

@ -24,7 +24,7 @@ class BlackBodyTarget(ATarget):
@u.quantity_input(wl_bins='length', temp=[u.Kelvin, u.Celsius], mag=u.mag) @u.quantity_input(wl_bins='length', temp=[u.Kelvin, u.Celsius], mag=u.mag)
def __init__(self, wl_bins: u.Quantity, temp: u.Quantity = 5778 * u.K, def __init__(self, wl_bins: u.Quantity, temp: u.Quantity = 5778 * u.K,
mag: u.Quantity = 0 * u.mag, band: str = "V"): mag: u.Quantity = 0 * u.mag, band: str = "V", size: str = "Point"):
""" """
Initialize a new black body point source Initialize a new black body point source
@ -38,6 +38,8 @@ class BlackBodyTarget(ATarget):
Desired apparent magnitude of the point source Desired apparent magnitude of the point source
band : str band : str
Band used for fitting the planck curve to a star of 0th magnitude. Can be one of [U, B, V, R, I, J, H, K]. Band used for fitting the planck curve to a star of 0th magnitude. Can be one of [U, B, V, R, I, J, H, K].
size : str
The size of the target. Can be either point or extended
Returns Returns
------- -------
@ -54,4 +56,4 @@ class BlackBodyTarget(ATarget):
sfd = bb(wl_bins) * factor * 10 ** (- 2 / 5 * mag / u.mag) sfd = bb(wl_bins) * factor * 10 ** (- 2 / 5 * mag / u.mag)
# Initialize super class # Initialize super class
super().__init__(SpectralQty(wl_bins, sfd), wl_bins) super().__init__(SpectralQty(wl_bins, sfd), wl_bins, size)

View File

@ -9,7 +9,7 @@ class FileTarget(ATarget):
""" """
@u.quantity_input(wl_bins="length") @u.quantity_input(wl_bins="length")
def __init__(self, file: str, wl_bins: u.Quantity): def __init__(self, file: str, wl_bins: u.Quantity, size: str = "Point"):
""" """
Initialize a new target from a file containing the spectral flux density values Initialize a new target from a file containing the spectral flux density values
@ -22,8 +22,10 @@ class FileTarget(ATarget):
will be read from the column headers or otherwise assumed to be *nm* and *W / m^2 / nm*. will be read from the column headers or otherwise assumed to be *nm* and *W / m^2 / nm*.
wl_bins : length-Quantity wl_bins : length-Quantity
Wavelengths used for binning Wavelengths used for binning
size : str
The size of the target. Can be either point or extended.
""" """
# Create spectral quantity from file # Create spectral quantity from file
sfd = SpectralQty.fromFile(file, u.nm, u.W / (u.m ** 2 * u.nm)) sfd = SpectralQty.fromFile(file, u.nm, u.W / (u.m ** 2 * u.nm))
# Initialize the super class # Initialize the super class
super().__init__(sfd, wl_bins) super().__init__(sfd, wl_bins, size)

View File

@ -21,7 +21,7 @@ class TestAOpticalComponent(TestCase):
obstruction=0.1, obstructor_temp=300 * u.K, obstructor_emissivity=1) obstruction=0.1, obstructor_temp=300 * u.K, obstructor_emissivity=1)
def test_calcSignal(self): def test_calcSignal(self):
self.assertEqual(self.comp.calcSignal(), self.assertEqual(self.comp.calcSignal()[0],
SpectralQty(self.wl, np.array([1.29074440e-17, 5.65909989e-18, 2.85372997e-18, SpectralQty(self.wl, np.array([1.29074440e-17, 5.65909989e-18, 2.85372997e-18,
1.58973516e-18]) << u.W / (u.m ** 2 * u.nm))) 1.58973516e-18]) << u.W / (u.m ** 2 * u.nm)))

View File

@ -11,7 +11,7 @@ class TestAtmosphere(TestCase):
"data/atmosphere/atmosphere_emission_1.csv") "data/atmosphere/atmosphere_emission_1.csv")
def test_calcSignal(self): def test_calcSignal(self):
self.assertEqual(self.atmosphere.calcSignal(), self.assertEqual(self.atmosphere.calcSignal()[0],
SpectralQty(np.arange(200, 210) << u.nm, SpectralQty(np.arange(200, 210) << u.nm,
np.array([1.10e-15, 1.20e-15, 1.30e-15, 1.26e-15, 1.20e-15, 1.12e-15, 1.02e-15, np.array([1.10e-15, 1.20e-15, 1.30e-15, 1.26e-15, 1.20e-15, 1.12e-15, 1.02e-15,
0.9e-15, 0, 0]) << u.W / (u.m ** 2 * u.nm))) 0.9e-15, 0, 0]) << u.W / (u.m ** 2 * u.nm)))

View File

@ -18,7 +18,7 @@ class TestBeamSplitter(TestCase):
self.assertEqual(self.splitter.calcBackground(), self.assertEqual(self.splitter.calcBackground(),
SpectralQty(self.wl, np.array([4.31413931e-96, 1.37122214e-95, 4.30844544e-95, SpectralQty(self.wl, np.array([4.31413931e-96, 1.37122214e-95, 4.30844544e-95,
1.33846280e-94]) << u.W / (u.m ** 2 * u.nm * u.sr))) 1.33846280e-94]) << u.W / (u.m ** 2 * u.nm * u.sr)))
self.assertEqual(self.splitter.calcSignal(), self.assertEqual(self.splitter.calcSignal()[0],
SpectralQty(np.arange(200, 210, 1) << u.nm, SpectralQty(np.arange(200, 210, 1) << u.nm,
np.array([0, 1.20e-15, 1.30e-15, 1.40e-15, 1.35e-15, 0, 0, 0, 0, 0]) << u.W / np.array([0, 1.20e-15, 1.30e-15, 1.40e-15, 1.35e-15, 0, 0, 0, 0, 0]) << u.W /
(u.m ** 2 * u.nm))) (u.m ** 2 * u.nm)))

View File

@ -9,14 +9,14 @@ class TestFilter(TestCase):
wl = np.array([400, 500, 501, 545, 589, 590, 600]) << u.nm wl = np.array([400, 500, 501, 545, 589, 590, 600]) << u.nm
target = BlackBodyTarget(wl, temp=5778 * u.K, mag=10 * u.mag, band="U") target = BlackBodyTarget(wl, temp=5778 * u.K, mag=10 * u.mag, band="U")
filt = Filter.fromBand(target, "V") filt = Filter.fromBand(target, "V")
self.assertEqual(filt.calcSignal(), SpectralQty(wl, np.array([0.0, 0.0, 0.0, 5.52730709e-15, 5.29671115e-15, self.assertEqual(filt.calcSignal()[0], SpectralQty(wl, np.array([0.0, 0.0, 0.0, 5.52730709e-15, 5.29671115e-15,
5.29030718e-15, 0.0]) << u.W / 5.29030718e-15, 0.0]) << u.W /
(u.m ** 2 * u.nm))) (u.m ** 2 * u.nm)))
def test_fromFile(self): def test_fromFile(self):
target = FileTarget("data/target/target_demo_1.csv", np.arange(200, 210, 1) << u.nm) target = FileTarget("data/target/target_demo_1.csv", np.arange(200, 210, 1) << u.nm)
filt = Filter.fromFile(target, "data/filter/filter_transmittance.csv") filt = Filter.fromFile(target, "data/filter/filter_transmittance.csv")
self.assertEqual(filt.calcSignal(), self.assertEqual(filt.calcSignal()[0],
SpectralQty(np.arange(200, 210, 1) << u.nm, np.array([1.10e-15, 1.20e-15, 1.30e-15, 1.40e-15, SpectralQty(np.arange(200, 210, 1) << u.nm, np.array([1.10e-15, 1.20e-15, 1.30e-15, 1.40e-15,
1.35e-15, 1.44e-15, 1.53e-15, 1.44e-15, 1.35e-15, 1.44e-15, 1.53e-15, 1.44e-15,
1.52e-15, 1.40e-15]) << u.W / 1.52e-15, 1.40e-15]) << u.W /

View File

@ -17,7 +17,7 @@ class TestLens(TestCase):
self.assertEqual(self.lens.calcBackground(), self.assertEqual(self.lens.calcBackground(),
SpectralQty(self.wl, np.array([4.31413931e-96, 1.37122214e-95, 4.30844544e-95, SpectralQty(self.wl, np.array([4.31413931e-96, 1.37122214e-95, 4.30844544e-95,
1.33846280e-94]) << u.W / (u.m ** 2 * u.nm * u.sr))) 1.33846280e-94]) << u.W / (u.m ** 2 * u.nm * u.sr)))
self.assertEqual(self.lens.calcSignal(), self.assertEqual(self.lens.calcSignal()[0],
SpectralQty(np.arange(200, 210, 1) << u.nm, SpectralQty(np.arange(200, 210, 1) << u.nm,
np.array([0, 1.20e-15, 1.30e-15, 1.40e-15, 1.35e-15, 0, 0, 0, 0, 0]) << u.W / np.array([0, 1.20e-15, 1.30e-15, 1.40e-15, 1.35e-15, 0, 0, 0, 0, 0]) << u.W /
(u.m ** 2 * u.nm))) (u.m ** 2 * u.nm)))

View File

@ -17,7 +17,7 @@ class TestMirror(TestCase):
self.assertEqual(self.mirror.calcBackground(), self.assertEqual(self.mirror.calcBackground(),
SpectralQty(self.wl, np.array([4.31413931e-96, 1.37122214e-95, 4.30844544e-95, SpectralQty(self.wl, np.array([4.31413931e-96, 1.37122214e-95, 4.30844544e-95,
1.33846280e-94]) << u.W / (u.m ** 2 * u.nm * u.sr))) 1.33846280e-94]) << u.W / (u.m ** 2 * u.nm * u.sr)))
self.assertEqual(self.mirror.calcSignal(), self.assertEqual(self.mirror.calcSignal()[0],
SpectralQty(np.arange(200, 210, 1) << u.nm, np.array([0, 1.20e-15, 1.30e-15, 1.40e-15, SpectralQty(np.arange(200, 210, 1) << u.nm, np.array([0, 1.20e-15, 1.30e-15, 1.40e-15,
1.35e-15, 0, 0, 0, 0, 0]) << u.W / 1.35e-15, 0, 0, 0, 0, 0]) << u.W /
(u.m ** 2 * u.nm))) (u.m ** 2 * u.nm)))

View File

@ -10,7 +10,7 @@ class TestStrayLight(TestCase):
self.zodiac = StrayLight(self.target, "data/straylight/zodiacal_emission_1.csv") self.zodiac = StrayLight(self.target, "data/straylight/zodiacal_emission_1.csv")
def test_calcSignal(self): def test_calcSignal(self):
self.assertEqual(self.zodiac.calcSignal(), self.assertEqual(self.zodiac.calcSignal()[0],
SpectralQty(np.arange(200, 210) << u.nm, np.array([1.1e-15, 1.2e-15, 1.3e-15, 1.4e-15, 1.5e-15, SpectralQty(np.arange(200, 210) << u.nm, np.array([1.1e-15, 1.2e-15, 1.3e-15, 1.4e-15, 1.5e-15,
1.6e-15, 1.7e-15, 1.8e-15, 1.9e-15, 1.6e-15, 1.7e-15, 1.8e-15, 1.9e-15,
2.0e-15]) << u.W / (u.m ** 2 * u.nm))) 2.0e-15]) << u.W / (u.m ** 2 * u.nm)))

View File

@ -13,7 +13,7 @@ class TestBlackBodyTarget(TestCase):
def test_calcSignal(self): def test_calcSignal(self):
signal = SpectralQty(np.arange(400, 800, 100) << u.nm, np.array([4.91164694e-15, 5.61732017e-15, 5.22403225e-15, signal = SpectralQty(np.arange(400, 800, 100) << u.nm, np.array([4.91164694e-15, 5.61732017e-15, 5.22403225e-15,
4.43017583e-15]) << u.W / (u.m ** 2 * u.nm)) 4.43017583e-15]) << u.W / (u.m ** 2 * u.nm))
self.assertEqual(self.target.calcSignal(), signal) self.assertEqual(self.target.calcSignal(), (signal, "Point"))
def test_calcBackground(self): def test_calcBackground(self):
noise = SpectralQty(np.arange(400, 800, 100) << u.nm, np.repeat(0, 4) << u.W / (u.m ** 2 * u.nm * u.sr)) noise = SpectralQty(np.arange(400, 800, 100) << u.nm, np.repeat(0, 4) << u.W / (u.m ** 2 * u.nm * u.sr))

View File

@ -12,7 +12,7 @@ class TestFileTarget(TestCase):
def test_calcSignal(self): def test_calcSignal(self):
signal = SpectralQty(np.arange(200, 210, 1) << u.nm, signal = SpectralQty(np.arange(200, 210, 1) << u.nm,
np.arange(1.1e-15, 2.0e-15, 1e-16) << u.W / (u.m ** 2 * u.nm)) np.arange(1.1e-15, 2.0e-15, 1e-16) << u.W / (u.m ** 2 * u.nm))
self.assertTrue(self.target.calcSignal().__eq__(signal)) self.assertEqual(self.target.calcSignal(), (signal, "Point"))
def test_calcBackground(self): def test_calcBackground(self):
noise = SpectralQty(np.arange(200, 210, 1) << u.nm, noise = SpectralQty(np.arange(200, 210, 1) << u.nm,