-
Notifications
You must be signed in to change notification settings - Fork 0
/
models.py
160 lines (122 loc) · 5.42 KB
/
models.py
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
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
116
117
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
"""Represent models for near-Earth objects and their close approaches.
The `NearEarthObject` class represents a near-Earth object. Each has a unique
primary designation, an optional unique name, an optional diameter, and a flag
for whether the object is potentially hazardous.
The `CloseApproach` class represents a close approach to Earth by an NEO. Each
has an approach datetime, a nominal approach distance, and a relative approach
velocity.
A `NearEarthObject` maintains a collection of its close approaches, and a
`CloseApproach` maintains a reference to its NEO.
The functions that construct these objects use information extracted from the
data files from NASA, so these objects should be able to handle all of the
quirks of the data set, such as missing names and unknown diameters.
You'll edit this file in Task 1.
"""
from helpers import cd_to_datetime, datetime_to_str
class NearEarthObject:
"""A near-Earth object (NEO).
An NEO encapsulates semantic and physical parameters about the object, such
as its primary designation (required, unique), IAU name (optional),
diameter in kilometers (optional - sometimes unknown), and whether
it's marked as potentially hazardous to Earth.
A `NearEarthObject` also maintains a collection of its close approaches -
initialized to an empty collection, but eventually populated in the
`NEODatabase` constructor.
"""
def __init__(self, **info):
"""Create a new `NearEarthObject`.
:param info: A dictionary of excess keyword arguments
supplied to the constructor.
"""
self.designation = str(info['pdes'])
self.name = info['name'] if ('name' in info) else None
if 'diameter' in info:
self.diameter = float(info['diameter'])
else:
self.diameter = float('nan')
hazad = info.get('pha', '')
self.hazardous = True if hazad == 'Y' else False
self.approaches = []
@property
def fullname(self):
"""Full name of NEO.
Return a representation of the full name of this NEO.
"""
return f'{self.designation} {self.name}'
def __str__(self):
"""Return `str(self)`.
To print the NEO info.
"""
if self.hazardous:
hazardous = ' '
else:
hazardous = ' not'
if self.diameter:
diameter = self.diameter
else:
diameter = 'NOT FOUND'
return (f"A NearEarthObject with primary designation :"
f"{self.designation}, name: {self.name} has a"
f"diameter of {diameter} and is{hazardous}"
f"potentialy hazardous.")
def __repr__(self):
"""Print option.
Return `repr(self)`, a computer-readable
string representation of this object.
"""
return (f"NearEarthObject(designation={self.designation!r},"
f"name={self.name!r}, diameter={self.diameter:.3f},"
f"hazardous={self.hazardous!r})")
class CloseApproach:
"""A close approach to Earth by an NEO.
A `CloseApproach` encapsulates information about the NEO's close
approach to Earth, such as the date and time (in UTC) of closest
approach, the nominal approach distance in astronomical units,
and the relative approach velocity in kilometers per second.
A `CloseApproach` also maintains a reference to its
`NearEarthObject` - initally, this information (the NEO's
primary designation) is saved in a private attribute, but the
referenced NEO is eventually replaced in the`NEODatabase` constructor.
"""
def __init__(self, **info):
"""Create a new `CloseApproach`.
:param info: A dictionary of excess keyword arguments supplied to
the constructor.
"""
self._designation = info['des']
self.time = cd_to_datetime(info['cd']) if 'cd' in info else None
self.distance = float(info['dist']) if 'dist' in info else 0.0
self.velocity = float(info['v_rel']) if 'v_rel' in info else 0.0
self.neo = None
@property
def time_str(self):
"""Approach Time.
Return a formatted representation of this `CloseApproach`'s
approach time. The value in `self.time` should be a Python
`datetime` object. While a `datetime` object has a string
representation, the default representation includes seconds
- significant figures that don't exist in our input data set.
The `datetime_to_str` method converts a `datetime` object
to a formatted string that can be used in human-readable
representations and in serialization to CSV and JSON files.
"""
if self.time is not None:
return datetime_to_str(self.time)
else:
return None
def __str__(self):
"""Return `str(self)`.
Represent the str.
"""
return (f"A CloseApproach with primary designation "
f"{self._designation}, on {self.time_str},"
f"is at closest distance {self.distance} au."
f"and having the velosity {self.velocity}")
def __repr__(self):
"""Return Computer Readable str.
Return `repr(self)`, a computer-readable string
representation of this object.
"""
return (f"CloseApproach(time={self.time_str!r}, i"
f"distance={self.distance:.2f}, "
f"velocity={self.velocity:.2f}, neo={self.neo!r})")