Synopsis

PDX_MSGT igeo_Convert141ToNurbs141(long option, MDA_PTR db_ptr, MDA_PTR db_ptr_new_128, EAM_STACK *stack, int model, double tolerance, int max_iters, int u_degree, int v_degree, MDA_PTR *db_ptr_141, double *max_dev)

Purpose

Convert an IGES 141 entity to an all IGES NURBS 141 entity

Description

Given an IGES 141 entity that references non-NURBS entities, converts the non-NURBS entities to NURBS. If the 141 references IGES NURBS entities, the IGES NURBS entities are duplicated in the new model and referenced by the new IGES 141.

Parameter space curves are recomputed: .RS 4 o If the base surface was a non-NURBS surface that was converted to a NURBS(IGES 128) surfaces, .RE .RS 4 o The db_ptr_new_128 is not MDA_NULL_PTR and/or the option mask equals IGEO_USENURBSURF, .RE .RS 4 o The option mask equals IGEO_NEWPARMCRV, .RE .RS 4 o The bounded surface type indicates references to model space curves only. .RE

Model space curves are recomputed: .RS 4 o If the model space curves are not IGES NURBS curves .RE .RS 4 o If a new parameter space curve was computed and the preference flag is parameter space, .RE .RS 4 o The option IGEO_NEWMODELCRV is set to recompute the model space curves. .RE

The u_degree and v_degree are used to determine the degree of an offset surface or offset curve ( u_degree ) that needs to be converted to an approximate NURBS curve or surface. If the option mask IGEO_USEUDEG is set then the u_degree is used to specify the degree of the parameter space curve created from projecting the NURBS model space curve to the NURBS surface (by default the degree of the existing parameter space curve or the maximium surface degree if the parameter space curve is missing is used for the degree of the parameter space curve). The tolerance and max_iters values apply to the NURBS curves or surface that are approximated. In addition, the tolerance applies to the test for curve and surface closure.

By default the IGES entity matrix is applied to the IGES NURBS curve and all the IGES 141 non-pointer DE attributes are applied to the new NURBS base IGES 141 entity. If the model is the same as the db_ptr model than all the IGES pointer DE attributes, property pointers and associativity pointers are applied to the new IGES NURBS 143 entity.

The IGES 141 entity and all its subordinate entities must be valid IGES definitions.

The conversion is exact where the curve and surface entities convert extactly to the NURBS definition, otherwise the conversion is an approximation to tolerance. The projection of new parameter space curves and/or creation of new model space curves from parameter space curves is an approximation to tolerance.

Input

option

IGES_NOMATRIX

Do not apply entity matrix to data

IGEO_KEEPRAT

Keep NURBS curves/surface rational when elevating the degree during conversion

IGEO_BASEDEG

Use the base surface U and V degree for the degree of the offset surface

IGEO_NEWPARMCRV

Recompute the parameter space trimming curve by projecting the NURBS model space curve to the NURBS surface in the cases where the base surface is already a NURBS surface

IGEO_NEWMODELCRV

Recompute the NURBS model space trimming curve from the computed NURBS parameter space trimming curve when the parameter space curve is recomputed. The preference flag will be set to parameter space curve prefered.

IGEO_USENURBSURF

Use the new IGES 128 entity ( db_ptr_new_128) that was converted from non IGES 128 entity

IGEO_USEUDEG

Use the U degree parameter ( u_degree) for the degree of any new parameter space curves

db_ptr

The IGES 141 entity database pointer

db_ptr_new_128

The database pointer of the new IGES 128 entity that should be used for the converted 141 surface or MDA_NULL_PTR.

stack

The entity attribute stack handle

model

The model to crete the new IGES 141 entity in

tolerance

The conversion approximation tolerance. Note: The MODEL_SPACE_PNT_TOL should be at least 2 orders of magnitude less than this tolerance for correct results.

max_iters

The maximium iterations for convergence test

u_degree

The converted NURBS curve degree and/or the converted NURBS surface U degree (should be >= 1). See description for IGEO_USEUDEG option above.

v_degree

The converted NURBS surface V degree (should be >= 1)

Output

db_ptr_141

The new IGES 141 entity database pointer

max_dev

The maximium deviation of the model space curve to the surface.

Tolerances

      MODEL_SPACE_PNT_TOL
      PARM_SPACE_PNT_TOL
      ANGLE_TOL
      ZERO_TOL
      CONVERGE_TOL
      KNOT_TOL
      PNT_PROJ_TOL
      PARALLEL_LINES_TOL
      COLLINEAR_TOL
      COPLANAR_TOL
      .fi

Return

      IGEO_NOERR
      IGEO_NOMEMORY
      Low level error return
      .fi