1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
use skyangle::SkyAngle;
use std::ops::{Deref, DerefMut};
type SkyCoordinates = (SkyAngle<f64>, SkyAngle<f64>);
#[derive(Debug, Clone, Copy)]
pub struct Star {
pub coordinates: SkyCoordinates,
pub magnitude: f64,
}
impl Star {
pub fn inside_box(&self, width: f64) -> bool {
let (x, y) = self.coordinates;
let h = width / 2.;
x.to_radians().abs() <= h && y.to_radians().abs() < h
}
}
impl Default for Star {
fn default() -> Self {
Self {
coordinates: (SkyAngle::Arcsecond(0f64), SkyAngle::Arcsecond(0f64)),
magnitude: Default::default(),
}
}
}
impl Star {
pub fn new(coordinates: SkyCoordinates) -> Self {
Self {
coordinates,
..Default::default()
}
}
pub fn magnitude(mut self, magnitude: f64) -> Self {
self.magnitude = magnitude;
self
}
}
#[derive(Debug, Clone)]
pub struct Objects(pub(super) Vec<Star>);
impl Deref for Objects {
type Target = Vec<Star>;
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl DerefMut for Objects {
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.0
}
}
impl Default for Objects {
fn default() -> Self {
Self(Default::default())
}
}
impl From<Star> for Objects {
fn from(star: Star) -> Self {
Self(vec![star])
}
}
impl From<Vec<Star>> for Objects {
fn from(stars: Vec<Star>) -> Self {
Self(stars)
}
}