Package geomss.geom
Class SubrangeSurface
- java.lang.Object
- 
- geomss.geom.AbstractGeomElement<T>
- 
- geomss.geom.AbstractSurface<SubrangeSurface>
- 
- geomss.geom.SubrangeSurface
 
 
 
- 
- All Implemented Interfaces:
- GeomElement<SubrangeSurface>,- ParametricGeometry<SubrangeSurface>,- Subrange<Surface>,- Surface<SubrangeSurface>,- Transformable<SubrangeSurface>,- java.io.Serializable,- java.lang.Cloneable,- java.lang.Comparable,- javolution.lang.Reusable,- javolution.xml.XMLSerializable
 
 public class SubrangeSurface extends AbstractSurface<SubrangeSurface> implements Subrange<Surface> A subrange or trimmedSurfacethat is defined by a set of four 2D boundary curves that define the 4 parametric edges of the trimmed surface on the child surface.Modified by: Joseph A. Huwaldt - Version:
- November 27, 2015
- Author:
- Joseph A. Huwaldt, Date: April 8, 2013
- See Also:
- Serialized Form
 
- 
- 
Field Summary- 
Fields inherited from class geomss.geom.AbstractSurfaceGTOL
 - 
Fields inherited from class geomss.geom.AbstractGeomElementRESOURCES
 
- 
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description SubrangeSurfacecopy()Returns a copy of thisSubrangeSurfaceinstanceallocatedby the calling thread (possibly on the stack).SubrangeSurfacecopyToReal()Return a copy of this object with any transformations or subranges removed (applied).booleanequals(java.lang.Object obj)Compares the specified object with thisSubrangeSurfacefor equality.PointgetBoundsMax()Return the coordinate point representing the maximum bounding box corner (e.g.: max X, max Y, max Z).PointgetBoundsMin()Return the coordinate point representing the minimum bounding box corner of this geometry element (e.g.: min X, min Y, min Z).ParametricGeometrygetChild()Returns the child object this point is subranged onto.SurfacegetParPosition()Returns a 2D surface in parametric space which maps this surface's parametric positions to the child surface.intgetPhyDimension()Returns the number of physical dimensions of the geometry element.PointgetRealPoint(double s, double t)Calculate a point on the surface for the given parametric position on the surface.CurvegetS0Curve()Return the S=0 Boundary for this surface as a curve.CurvegetS1Curve()Return the S=1 Boundary for this surface as a curve.java.util.List<Vector<javax.measure.quantity.Length>>getSDerivatives(double s, double t, int grade, boolean scaled)Calculate all the derivatives from0togradewith respect to parametric s-position on the surface for the given parametric position on the surface,d^{grade}p(s,t)/d^{grade}s.CurvegetT0Curve()Return the T=0 Boundary for this surface as a curve.CurvegetT1Curve()Return the T=1 Boundary for this surface as a curve.java.util.List<Vector<javax.measure.quantity.Length>>getTDerivatives(double s, double t, int grade, boolean scaled)Calculate all the derivatives from0togradewith respect to parametric t-position on the surface for the given parametric position on the surface,d^{grade}p(s,t)/d^{grade}t.SubrangeSurfacegetTransformed(GTransform transform)Returns transformed version of this element.Vector<javax.measure.quantity.Length>getTwistVector(double s, double t)Calculate the twist vector (d^2P/(ds*dt) = d(dP/ds)/dt) for this surface at the specified position on this surface.javax.measure.unit.Unit<javax.measure.quantity.Length>getUnit()Returns the unit in which this surface is stated.inthashCode()Returns the hash code for thisSubrangeSurface.booleanisDegenerate(Parameter<javax.measure.quantity.Length> tol)Returntrueif this surface is degenerate (i.e.: has area less than the specified tolerance squared).booleanisValid()Returntrueif this SubrangeSurface contains valid and finite numerical components.static SubrangeSurfacenewInstance(Surface child, double s0, double t0, double s1, double t1)Returns a SubrangeSurface on the surfacechildthat covers the range of parametric positions froms0,t0tos1,t1.static SubrangeSurfacenewInstance(Surface child, Curve s0, Curve t0, Curve s1, Curve t1, double tol)Returns aSubrangeSurfaceinstance referring to the specifiedSurfaceand the supplied boundary location curves in parametric space.static SubrangeSurfacenewInstance(Surface child, Surface par)Returns aSubrangeSurfaceinstance referring to the specifiedSurfaceand the supplied 2D surface in parametric space which maps the SubrangeSurface to the child Surface.static voidrecycle(SubrangeSurface instance)Recycles a SubrangeSurface instance immediately (on the stack when executing in a StackContext).SubrangeSurfacereverseS()Return a new surface that is identical to this one, but with the S-parameterization reversed.SubrangeSurfacereverseT()Return a new surface that is identical to this one, but with the T-parameterization reversed.voidsetParPosition(Surface par)Sets the range of parametric positions on the child object that this surface refers to.intsize()Returns the number of child-elements that make up this geometry element.GeomList<SubrangeSurface>splitAtS(double s)Split thisSubrangeSurfaceat the specified parametric S-position returning a list containing two new surfaces (a lower surface with smaller S-parametric positions than "s" and an upper surface with larger S-parametric positions).GeomList<SubrangeSurface>splitAtT(double t)Split thisSubrangeSurfaceat the specified parametric T-position returning a list containing two new surfaces (a lower surface with smaller T-parametric positions than "t" and an upper surface with larger T-parametric positions).SubrangeSurfaceto(javax.measure.unit.Unit<javax.measure.quantity.Length> unit)Returns the equivalent to this surface but stated in the specified unit.SubrangeSurfacetoDimension(int newDim)Return the equivalent of this surface converted to the specified number of physical dimensions.NurbsSurfacetoNurbs(Parameter<javax.measure.quantity.Length> tol)Return a NURBS surface representation of this surface to within the specified tolerance.javolution.text.TexttoText()Returns the text representation of this geometry element.SubrangeSurfacetranspose()Return a new surface that is identical to this one but with the transpose of the parameterization of this surface.- 
Methods inherited from class geomss.geom.AbstractSurfaceextractGrid, getArea, getArea, getArea, getClosest, getClosest, getClosest, getClosest, getClosest, getClosest, getCurve, getDerivatives, getFarthest, getFarthest, getFarthest, getGaussianCurvature, getGaussianCurvature, getLimitPoint, getMeanCurvature, getMeanCurvature, getNormal, getNormal, getParDimension, getPoint, getPoint, getRealPoint, getSCurve, getSDerivative, getSDerivative, getSDerivatives, getSDerivatives, getTangentPlane, getTangentPlane, getTCurve, getTDerivative, getTDerivative, getTDerivatives, getTDerivatives, getTwistVector, getVolume, getVolume, getVolume, gridToTolerance, intersect, intersect, intersect, intersect, intersect, isPlanar, isPlanar, splitAtS, splitAtT
 - 
Methods inherited from class geomss.geom.AbstractGeomElementaddChangeListener, clone, compareTo, getAllUserData, getID, getName, getUserData, putAllUserData, putUserData, removeChangeListener, removeUserData, reset, setName, toString
 - 
Methods inherited from interface geomss.geom.GeomElementaddChangeListener, getAllUserData, getID, getName, getUserData, putAllUserData, putUserData, removeChangeListener, removeUserData, setName
 
- 
 
- 
- 
- 
Method Detail- 
newInstancepublic static SubrangeSurface newInstance(Surface child, Surface par) Returns aSubrangeSurfaceinstance referring to the specifiedSurfaceand the supplied 2D surface in parametric space which maps the SubrangeSurface to the child Surface. The mapping surface in parametric space must be in units of meters and be in the range 0,0 to 1,1.- Parameters:
- child- The- Surfacethat this surface is subranged onto (may not be- null).
- par- A 2D surface in parametric space (between 0,0 and 1,1 in meters) that maps the parametric positions from the subrange surface to the child surface. If- nullis passed, the full parametric boundary of the child surface is used.
- Returns:
- the subrange surface having the specified mapping to the child surface.
- Throws:
- DimensionException- if the input parametric space surface does not have a parametric dimension equal to 2.
 
 - 
newInstancepublic static SubrangeSurface newInstance(Surface child, Curve s0, Curve t0, Curve s1, Curve t1, double tol) Returns aSubrangeSurfaceinstance referring to the specifiedSurfaceand the supplied boundary location curves in parametric space. The boundary curves in parametric space must be in units of meters and be in the range 0,0 to 1,1. The start points of the s0,t0 curves must be coincident. The start of the s1 curve and end of the t0 curve must be coincident. The end of the s1 curve and end of the t1 curve must be coincident. And, the end of the s0 curve and start of the t1 curve must be coincident. The corner points of the parametric curves are checked for proper coincidence.- Parameters:
- child- The- Surfacethat this surface is subranged onto (may not be- null).
- s0- A 2D curve of the parametric position (between 0,0 and 1,1 in meters) along each parametric dimension or a subrange curve on the child surface that serves as the s=0 boundary for the subrange surface.
- t0- A 2D curve of the parametric position (between 0,0 and 1,1 in meters) along each parametric dimension or a subrange curve on the child surface that serves as the t=0 boundary for the subrange surface.
- s1- A 2D curve of the parametric position (between 0,0 and 1,1 in meters) along each parametric dimension that serves as the s=1 boundary for the subrange surface.
- t1- A 2D curve of the parametric position (between 0,0 and 1,1 in meters) along each parametric dimension or a subrange curve on the child surface that serves as the t=1 boundary for the subrange surface.
- tol- A tolerance (in parameter space) for how closely the corner points must match.
- Returns:
- the subrange surface having the specified boundary curves.
- Throws:
- DimensionException- if the input boundary curves are not subranges on child and their parametric dimensions are not equal to 2.
 
 - 
newInstancepublic static SubrangeSurface newInstance(Surface child, double s0, double t0, double s1, double t1) Returns a SubrangeSurface on the surfacechildthat covers the range of parametric positions froms0,t0tos1,t1.- Parameters:
- child- The- Surfaceobject that this surface is subranged onto (may not be- null).
- s0- The parametric position on the child surface that should form the s=0 edge of the subrange surface.
- t0- The parametric position on the child surface that should form the t=0 edge of the subrange surface.
- s1- The parametric position on the child surface that should form the s=1 edge of the subrange surface.
- t1- The parametric position on the child surface that should form the t=1 edge of the subrange surface.
- Returns:
- the subrange surface having the specified range of parametric values on the child surface.
 
 - 
getChildpublic ParametricGeometry getChild() Returns the child object this point is subranged onto.
 - 
getParPositionpublic Surface getParPosition() Returns a 2D surface in parametric space which maps this surface's parametric positions to the child surface.- Specified by:
- getParPositionin interface- Subrange<Surface>
- Returns:
- A 2D surface in parametric space that maps this surface's parameters to the child surface.
 
 - 
setParPositionpublic void setParPosition(Surface par) Sets the range of parametric positions on the child object that this surface refers to. The parametric surface must be 2D, in units of meters and be in the range 0,0 to 1,1.- Specified by:
- setParPositionin interface- Subrange<Surface>
- Parameters:
- par- The mapping of parametric positions (0,0 to 1,1) from this surface to the child surface. May not be null.
 
 - 
sizepublic int size() Returns the number of child-elements that make up this geometry element. This implementation returns the size of the child object.- Specified by:
- sizein interface- GeomElement<SubrangeSurface>
- Returns:
- The number of child-elements that make up this geometry element.
 
 - 
getT0Curvepublic Curve getT0Curve() Return the T=0 Boundary for this surface as a curve.- Specified by:
- getT0Curvein interface- Surface<SubrangeSurface>
- Returns:
- The T=0 Boundary for this surface as a curve.
 
 - 
getT1Curvepublic Curve getT1Curve() Return the T=1 Boundary for this surface as a curve.- Specified by:
- getT1Curvein interface- Surface<SubrangeSurface>
- Returns:
- The T=1 Boundary for this surface as a curve.
 
 - 
getS0Curvepublic Curve getS0Curve() Return the S=0 Boundary for this surface as a curve.- Specified by:
- getS0Curvein interface- Surface<SubrangeSurface>
- Returns:
- The S=0 Boundary for this surface as a curve.
 
 - 
getS1Curvepublic Curve getS1Curve() Return the S=1 Boundary for this surface as a curve.- Specified by:
- getS1Curvein interface- Surface<SubrangeSurface>
- Returns:
- The S=1 Boundary for this surface as a curve.
 
 - 
getRealPointpublic Point getRealPoint(double s, double t) Calculate a point on the surface for the given parametric position on the surface.- Specified by:
- getRealPointin interface- Surface<SubrangeSurface>
- Parameters:
- s- 1st parametric dimension distance to calculate a point for (0.0 to 1.0 inclusive).
- t- 2nd parametric dimension distance to calculate a point for (0.0 to 1.0 inclusive).
- Returns:
- The calculated point on the surface at the specified parameter values.
- Throws:
- java.lang.IllegalArgumentException- if there is any problem with the parameter values.
 
 - 
getSDerivativespublic java.util.List<Vector<javax.measure.quantity.Length>> getSDerivatives(double s, double t, int grade, boolean scaled) Calculate all the derivatives from0togradewith respect to parametric s-position on the surface for the given parametric position on the surface,d^{grade}p(s,t)/d^{grade}s.Example: 
 1st derivative (grade = 1), this returns[p(s,t), dp(s,t)/ds];
 2nd derivative (grade = 2), this returns[p(s,t), dp(s,t)/ds, d^2p(s,t)/d^2s]; etc.- Specified by:
- getSDerivativesin class- AbstractSurface<SubrangeSurface>
- Parameters:
- s- 1st parametric dimension distance to calculate derivative for (0.0 to 1.0 inclusive).
- t- 2nd parametric dimension distance to calculate derivative for (0.0 to 1.0 inclusive).
- grade- The maximum grade to calculate the uA-derivatives for (1=1st derivative, 2=2nd derivative, etc)
- scaled- Pass- truefor properly scaled derivatives or- falseif the magnitude of the derivative vector is not required -- this sometimes results in faster calculation times.
- Returns:
- A list of s-derivatives up to the specified grade of the surface at the specified parametric position.
- Throws:
- java.lang.IllegalArgumentException- if the grade is < 0 or the parameter values are invalid.
 
 - 
getTDerivativespublic java.util.List<Vector<javax.measure.quantity.Length>> getTDerivatives(double s, double t, int grade, boolean scaled) Calculate all the derivatives from0togradewith respect to parametric t-position on the surface for the given parametric position on the surface,d^{grade}p(s,t)/d^{grade}t.Example: 
 1st derivative (grade = 1), this returns[p(s,t), dp(s,t)/dt];
 2nd derivative (grade = 2), this returns[p(s,t), dp(s,t)/dt, d^2p(s,t)/d^2t]; etc.- Specified by:
- getTDerivativesin class- AbstractSurface<SubrangeSurface>
- Parameters:
- s- 1st parametric dimension distance to calculate derivative for (0.0 to 1.0 inclusive).
- t- 2nd parametric dimension distance to calculate derivative for (0.0 to 1.0 inclusive).
- grade- The maximum grade to calculate the v-derivatives for (1=1st derivative, 2=2nd derivative, etc)
- scaled- Pass- truefor properly scaled derivatives or- falseif the magnitude of the derivative vector is not required -- this sometimes results in faster calculation times.
- Returns:
- A list of t-derivatives up to the specified grade of the surface at the specified parametric position.
- Throws:
- java.lang.IllegalArgumentException- if the grade is < 0 or the parameter values are invalid.
 
 - 
getTwistVectorpublic Vector<javax.measure.quantity.Length> getTwistVector(double s, double t) Calculate the twist vector (d^2P/(ds*dt) = d(dP/ds)/dt) for this surface at the specified position on this surface.- Specified by:
- getTwistVectorin interface- Surface<SubrangeSurface>
- Parameters:
- s- 1st parametric dimension distance to calculate twist vector for (0.0 to 1.0 inclusive).
- t- 2nd parametric dimension distance to calculate twist vector for (0.0 to 1.0 inclusive).
- Returns:
- The twist vector of this surface at the specified parametric position.
- Throws:
- java.lang.IllegalArgumentException- if the parameter values are invalid.
 
 - 
reverseSpublic SubrangeSurface reverseS() Return a new surface that is identical to this one, but with the S-parameterization reversed.- Specified by:
- reverseSin interface- Surface<SubrangeSurface>
- Returns:
- A new surface that is identical to this one, but with the S-parameterization reversed.
- See Also:
- reverseT()
 
 - 
reverseTpublic SubrangeSurface reverseT() Return a new surface that is identical to this one, but with the T-parameterization reversed.- Specified by:
- reverseTin interface- Surface<SubrangeSurface>
- Returns:
- A new surface that is identical to this one, but with the T-parameterization reversed.
- See Also:
- reverseS()
 
 - 
transposepublic SubrangeSurface transpose() Return a new surface that is identical to this one but with the transpose of the parameterization of this surface. The S and T directions will be swapped.- Specified by:
- transposein interface- Surface<SubrangeSurface>
- Overrides:
- transposein class- AbstractSurface<SubrangeSurface>
- Returns:
- A new surface that is identical to this one but with the transpose of the parameterization of this surface.
- See Also:
- reverseT(),- reverseS()
 
 - 
splitAtSpublic GeomList<SubrangeSurface> splitAtS(double s) Split thisSubrangeSurfaceat the specified parametric S-position returning a list containing two new surfaces (a lower surface with smaller S-parametric positions than "s" and an upper surface with larger S-parametric positions).- Specified by:
- splitAtSin interface- Surface<SubrangeSurface>
- Parameters:
- s- The S-parametric position where this surface should be split (must not be 0 or 1!).
- Returns:
- A list containing two surfaces: 0 == the lower surface, 1 == the upper surface.
 
 - 
splitAtTpublic GeomList<SubrangeSurface> splitAtT(double t) Split thisSubrangeSurfaceat the specified parametric T-position returning a list containing two new surfaces (a lower surface with smaller T-parametric positions than "t" and an upper surface with larger T-parametric positions).- Specified by:
- splitAtTin interface- Surface<SubrangeSurface>
- Parameters:
- t- The T-parametric position where this surface should be split (must not be 0 or 1!).
- Returns:
- A list containing two surfaces: 0 == the lower surface, 1 == the upper surface.
 
 - 
getTransformedpublic SubrangeSurface getTransformed(GTransform transform) Returns transformed version of this element. The returned object implementsGeomTransformand contains this element as a child.- Specified by:
- getTransformedin interface- Transformable<SubrangeSurface>
- Parameters:
- transform- The transformation to apply to this geometry. May not be null.
- Returns:
- A new triangle that is identical to this one with the specified transformation applied.
- Throws:
- DimensionException- if this point is not 3D.
 
 - 
getBoundsMinpublic Point getBoundsMin() Return the coordinate point representing the minimum bounding box corner of this geometry element (e.g.: min X, min Y, min Z).- Specified by:
- getBoundsMinin interface- GeomElement<SubrangeSurface>
- Returns:
- The minimum bounding box coordinate for this geometry element.
- Throws:
- java.lang.IndexOutOfBoundsException- if this list contains no elements.
 
 - 
getBoundsMaxpublic Point getBoundsMax() Return the coordinate point representing the maximum bounding box corner (e.g.: max X, max Y, max Z).- Specified by:
- getBoundsMaxin interface- GeomElement<SubrangeSurface>
- Returns:
- The maximum bounding box coordinate for this geometry element.
- Throws:
- java.lang.IndexOutOfBoundsException- if this list contains no elements.
 
 - 
getPhyDimensionpublic int getPhyDimension() Returns the number of physical dimensions of the geometry element. This implementation always returns the physical dimension of the underlyingSurfaceobjects.- Specified by:
- getPhyDimensionin interface- GeomElement<SubrangeSurface>
- Returns:
- The number of physical dimensions of the geometry element.
 
 - 
toDimensionpublic SubrangeSurface toDimension(int newDim) Return the equivalent of this surface converted to the specified number of physical dimensions. If the number of dimensions is greater than this element, then zeros are added to the additional dimensions. If the number of dimensions is less than this element, then the extra dimensions are simply dropped (truncated). If the new dimensions are the same as the dimension of this element, then this element is simply returned.- Specified by:
- toDimensionin interface- GeomElement<SubrangeSurface>
- Specified by:
- toDimensionin interface- ParametricGeometry<SubrangeSurface>
- Specified by:
- toDimensionin interface- Surface<SubrangeSurface>
- Parameters:
- newDim- The dimension of the surface to return.
- Returns:
- The equivalent of this surface converted to the new dimensions.
 
 - 
toNurbspublic NurbsSurface toNurbs(Parameter<javax.measure.quantity.Length> tol) Return a NURBS surface representation of this surface to within the specified tolerance.- Specified by:
- toNurbsin interface- Surface<SubrangeSurface>
- Parameters:
- tol- The greatest possible difference between this surface and the NURBS representation returned. May not be null.
- Returns:
- A NURBS surface that represents this surface to within the specified tolerance.
 
 - 
getUnitpublic javax.measure.unit.Unit<javax.measure.quantity.Length> getUnit() Returns the unit in which this surface is stated.- Specified by:
- getUnitin interface- GeomElement<SubrangeSurface>
- Returns:
- The unit in which this surface is stated.
 
 - 
topublic SubrangeSurface to(javax.measure.unit.Unit<javax.measure.quantity.Length> unit) throws javax.measure.converter.ConversionException Returns the equivalent to this surface but stated in the specified unit.- Specified by:
- toin interface- GeomElement<SubrangeSurface>
- Specified by:
- toin interface- ParametricGeometry<SubrangeSurface>
- Specified by:
- toin interface- Surface<SubrangeSurface>
- Parameters:
- unit- the length unit of the surface to be returned.
- Returns:
- an equivalent to this surface but stated in the specified unit.
- Throws:
- javax.measure.converter.ConversionException- if the the input unit is not a length unit.
 
 - 
isValidpublic boolean isValid() Returntrueif this SubrangeSurface contains valid and finite numerical components. A value offalsewill be returned if any of the member curves are not valid.- Specified by:
- isValidin interface- GeomElement<SubrangeSurface>
- Returns:
- true if this SubrangeSurface contains valid and finite numerical components.
 
 - 
isDegeneratepublic boolean isDegenerate(Parameter<javax.measure.quantity.Length> tol) Returntrueif this surface is degenerate (i.e.: has area less than the specified tolerance squared).- Specified by:
- isDegeneratein interface- ParametricGeometry<SubrangeSurface>
- Specified by:
- isDegeneratein interface- Surface<SubrangeSurface>
- Overrides:
- isDegeneratein class- AbstractSurface<SubrangeSurface>
- Parameters:
- tol- The tolerance for determining if this surface is degenerate. May not be null.
- Returns:
- true if this surface is degenerate.
 
 - 
equalspublic boolean equals(java.lang.Object obj) Compares the specified object with thisSubrangeSurfacefor equality. Returns true if and only if both surfaces are of the same type, have the same child surface, and both contain the same boundary curves in the same order.- Overrides:
- equalsin class- AbstractGeomElement<SubrangeSurface>
- Parameters:
- obj- the object to compare with.
- Returns:
- trueif this surface is identical to that surface;- falseotherwise.
 
 - 
hashCodepublic int hashCode() Returns the hash code for thisSubrangeSurface.- Overrides:
- hashCodein class- AbstractGeomElement<SubrangeSurface>
- Returns:
- the hash code value.
 
 - 
copyToRealpublic SubrangeSurface copyToReal() Return a copy of this object with any transformations or subranges removed (applied). This method is not yet implemented and current returns a new SubrangeSurface with the child surface and subrange curves copied to real.- Specified by:
- copyToRealin interface- GeomElement<SubrangeSurface>
- Returns:
- A copy of this object with any transformations or subranges removed.
 
 - 
copypublic SubrangeSurface copy() Returns a copy of thisSubrangeSurfaceinstanceallocatedby the calling thread (possibly on the stack).- Specified by:
- copyin interface- GeomElement<SubrangeSurface>
- Specified by:
- copyin interface- ParametricGeometry<SubrangeSurface>
- Specified by:
- copyin interface- Surface<SubrangeSurface>
- Returns:
- an identical and independent copy of this object.
 
 - 
toTextpublic javolution.text.Text toText() Returns the text representation of this geometry element.- Specified by:
- toTextin interface- GeomElement<SubrangeSurface>
- Overrides:
- toTextin class- AbstractGeomElement<SubrangeSurface>
- Returns:
- The text representation of this geometry element.
 
 - 
recyclepublic static void recycle(SubrangeSurface instance) Recycles a SubrangeSurface instance immediately (on the stack when executing in a StackContext).- Parameters:
- instance- The instance to be recycled.
 
 
- 
 
-