Package gaiasky.data.util
Class PointCloudData
java.lang.Object
gaiasky.data.util.PointCloudData
Contains a point cloud dataset, with cartesian XYZ positions in the equatorial
system with the origin in the barycenter of the solar system, and optionally times
for each of those.
-
Field Summary
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addPoint
(double x, double y, double z) Adds a single point to the cloudvoid
Adds a single point o this point cloudvoid
addPoints
(double[] points) Adds the given vector to the current points.void
Same asaddPoints(double[])
but with an array listvoid
clear()
Clears all datagetDate
(int index) getEnd()
long
getEndMs()
int
getIndex
(long wrappedTimeMs) int
Gets the bounding indices for the given date.int
getStart()
long
getWrapTime
(Instant instant) long
getWrapTimeMs
(Instant instant) double
getX
(int index) double
getY
(int index) double
getZ
(int index) boolean
isEmpty()
void
boolean
boolean
void
Loads the data point at the index in the vector in the Orbit reference system.boolean
Returns a vector with the data point at the given time.boolean
Returns a vector with the data point at the given time.void
loadPointF
(com.badlogic.gdx.math.Vector3 v, int index) Loads the data point at the index in the vector in the world reference system.loadTime
(int index) void
setX
(int index, double value) void
setY
(int index, double value) void
setZ
(int index, double value)
-
Field Details
-
x
-
y
-
z
-
time
-
period
public double period
-
-
Constructor Details
-
PointCloudData
public PointCloudData() -
PointCloudData
public PointCloudData(int capacity)
-
-
Method Details
-
clear
public void clear()Clears all data -
isEmpty
public boolean isEmpty() -
addPoints
public void addPoints(double[] points) Adds the given vector to the current points. The vector is of the form [x0, y0, z0, x1, y1, z1, ..., xn, yn, zn]. If the size of the vector is not a multiple of 3, no points are added- Parameters:
points
- The points to add to this point cloud
-
addPoints
Same asaddPoints(double[])
but with an array list- Parameters:
points
- The points to add to this point cloud
-
addPoint
Adds a single point o this point cloud- Parameters:
point
- The point
-
addPoint
public void addPoint(double x, double y, double z) Adds a single point to the cloud- Parameters:
x
- The x componenty
- The y componentz
- The z component
-
loadPoint
Loads the data point at the index in the vector in the Orbit reference system.- Parameters:
v
- The vector to load the data into.index
- The data index.
-
loadPoint
-
loadTime
-
getNumPoints
public int getNumPoints() -
getX
public double getX(int index) -
setX
public void setX(int index, double value) -
getY
public double getY(int index) -
setY
public void setY(int index, double value) -
getZ
public double getZ(int index) -
setZ
public void setZ(int index, double value) -
getDate
-
getStart
-
getStartMs
public long getStartMs() -
getEnd
-
getEndMs
public long getEndMs() -
loadPointF
public void loadPointF(com.badlogic.gdx.math.Vector3 v, int index) Loads the data point at the index in the vector in the world reference system.- Parameters:
v
- The vector to store the result.index
- The index of the point to load.
-
loadPoint
Returns a vector with the data point at the given time. It uses linear interpolation. The time instant must be within the bounds of this point cloud's times- Parameters:
v
- The vector to store the result.instant
- The time as an instant.- Returns:
- Whether the operation completes successfully
-
loadPoint
-
loadPoint
Returns a vector with the data point at the given time. It uses linear interpolation. The time instant must be within the bounds of this point cloud's times- Parameters:
v
- The vectortimeMs
- The time in milliseconds- Returns:
- Whether the operation completes successfully
-
loadPoint
-
getWrapTime
-
getWrapTimeMs
-
getIndex
Gets the bounding indices for the given date. If the date is out of range, it wraps.- Parameters:
instant
- The date- Returns:
- The two indices
-
getIndex
public int getIndex(long wrappedTimeMs)
-