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
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddPoint(double x, double y, double z) Adds a single point to the cloudvoidAdds a single point o this point cloudvoidaddPoints(double[] points) Adds the given vector to the current points.voidSame asaddPoints(double[])but with an array listvoidclear()Clears all datagetDate(int index) getEnd()longgetEndMs()intgetIndex(long wrappedTimeMs) intGets the bounding indices for the given date.intgetStart()longgetWrapTime(Instant instant) longgetWrapTimeMs(Instant instant) doublegetX(int index) doublegetY(int index) doublegetZ(int index) booleanhasTime()booleanisEmpty()voidbooleanbooleanvoidLoads the data point at the index in the vector in the Orbit reference system.booleanReturns a vector with the data point at the given time.booleanReturns a vector with the data point at the given time.voidloadPointF(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) voidsetX(int index, double value) voidsetY(int index, double value) voidsetZ(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() -
hasTime
public boolean hasTime() -
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)
-