// // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions // are met: // * Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above copyright // notice, this list of conditions and the following disclaimer in the // documentation and/or other materials provided with the distribution. // * Neither the name of NVIDIA CORPORATION nor the names of its // contributors may be used to endorse or promote products derived // from this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // // Copyright (c) 2018 NVIDIA Corporation. All rights reserved. // This file was generated by NvParameterized/scripts/GenParameterized.pl #include "ClothingMaterialLibraryParameters.h" #include #include using namespace NvParameterized; namespace nvidia { namespace clothing { using namespace ClothingMaterialLibraryParametersNS; const char* const ClothingMaterialLibraryParametersFactory::vptr = NvParameterized::getVptr(); const uint32_t NumParamDefs = 43; static NvParameterized::DefinitionImpl* ParamDefTable; // now allocated in buildTree [NumParamDefs]; static const size_t ParamLookupChildrenTable[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 15, 19, 23, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 12, 13, 14, 16, 17, 18, 20, 21, 22, 24, 25, 26, }; #define TENUM(type) nvidia::##type #define CHILDREN(index) &ParamLookupChildrenTable[index] static const NvParameterized::ParamLookupNode ParamLookupTable[NumParamDefs] = { { TYPE_STRUCT, false, 0, CHILDREN(0), 1 }, { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->materials), CHILDREN(1), 1 }, // materials { TYPE_STRUCT, false, 1 * sizeof(ClothingMaterial_Type), CHILDREN(2), 28 }, // materials[] { TYPE_STRING, false, (size_t)(&((ClothingMaterial_Type*)0)->materialName), NULL, 0 }, // materials[].materialName { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->verticalStretchingStiffness), NULL, 0 }, // materials[].verticalStretchingStiffness { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->horizontalStretchingStiffness), NULL, 0 }, // materials[].horizontalStretchingStiffness { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->bendingStiffness), NULL, 0 }, // materials[].bendingStiffness { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->shearingStiffness), NULL, 0 }, // materials[].shearingStiffness { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->tetherStiffness), NULL, 0 }, // materials[].tetherStiffness { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->tetherLimit), NULL, 0 }, // materials[].tetherLimit { TYPE_BOOL, false, (size_t)(&((ClothingMaterial_Type*)0)->orthoBending), NULL, 0 }, // materials[].orthoBending { TYPE_STRUCT, false, (size_t)(&((ClothingMaterial_Type*)0)->verticalStiffnessScaling), CHILDREN(30), 3 }, // materials[].verticalStiffnessScaling { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->compressionRange), NULL, 0 }, // materials[].verticalStiffnessScaling.compressionRange { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->stretchRange), NULL, 0 }, // materials[].verticalStiffnessScaling.stretchRange { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->scale), NULL, 0 }, // materials[].verticalStiffnessScaling.scale { TYPE_STRUCT, false, (size_t)(&((ClothingMaterial_Type*)0)->horizontalStiffnessScaling), CHILDREN(33), 3 }, // materials[].horizontalStiffnessScaling { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->compressionRange), NULL, 0 }, // materials[].horizontalStiffnessScaling.compressionRange { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->stretchRange), NULL, 0 }, // materials[].horizontalStiffnessScaling.stretchRange { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->scale), NULL, 0 }, // materials[].horizontalStiffnessScaling.scale { TYPE_STRUCT, false, (size_t)(&((ClothingMaterial_Type*)0)->bendingStiffnessScaling), CHILDREN(36), 3 }, // materials[].bendingStiffnessScaling { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->compressionRange), NULL, 0 }, // materials[].bendingStiffnessScaling.compressionRange { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->stretchRange), NULL, 0 }, // materials[].bendingStiffnessScaling.stretchRange { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->scale), NULL, 0 }, // materials[].bendingStiffnessScaling.scale { TYPE_STRUCT, false, (size_t)(&((ClothingMaterial_Type*)0)->shearingStiffnessScaling), CHILDREN(39), 3 }, // materials[].shearingStiffnessScaling { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->compressionRange), NULL, 0 }, // materials[].shearingStiffnessScaling.compressionRange { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->stretchRange), NULL, 0 }, // materials[].shearingStiffnessScaling.stretchRange { TYPE_F32, false, (size_t)(&((StiffnessScaling_Type*)0)->scale), NULL, 0 }, // materials[].shearingStiffnessScaling.scale { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->damping), NULL, 0 }, // materials[].damping { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->stiffnessFrequency), NULL, 0 }, // materials[].stiffnessFrequency { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->drag), NULL, 0 }, // materials[].drag { TYPE_BOOL, false, (size_t)(&((ClothingMaterial_Type*)0)->comDamping), NULL, 0 }, // materials[].comDamping { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->friction), NULL, 0 }, // materials[].friction { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->massScale), NULL, 0 }, // materials[].massScale { TYPE_U32, false, (size_t)(&((ClothingMaterial_Type*)0)->solverIterations), NULL, 0 }, // materials[].solverIterations { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->solverFrequency), NULL, 0 }, // materials[].solverFrequency { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->gravityScale), NULL, 0 }, // materials[].gravityScale { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->inertiaScale), NULL, 0 }, // materials[].inertiaScale { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->hardStretchLimitation), NULL, 0 }, // materials[].hardStretchLimitation { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->maxDistanceBias), NULL, 0 }, // materials[].maxDistanceBias { TYPE_U32, false, (size_t)(&((ClothingMaterial_Type*)0)->hierarchicalSolverIterations), NULL, 0 }, // materials[].hierarchicalSolverIterations { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->selfcollisionThickness), NULL, 0 }, // materials[].selfcollisionThickness { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->selfcollisionSquashScale), NULL, 0 }, // materials[].selfcollisionSquashScale { TYPE_F32, false, (size_t)(&((ClothingMaterial_Type*)0)->selfcollisionStiffness), NULL, 0 }, // materials[].selfcollisionStiffness }; bool ClothingMaterialLibraryParameters::mBuiltFlag = false; NvParameterized::MutexType ClothingMaterialLibraryParameters::mBuiltFlagMutex; ClothingMaterialLibraryParameters::ClothingMaterialLibraryParameters(NvParameterized::Traits* traits, void* buf, int32_t* refCount) : NvParameters(traits, buf, refCount) { //mParameterizedTraits->registerFactory(className(), &ClothingMaterialLibraryParametersFactoryInst); if (!buf) //Do not init data if it is inplace-deserialized { initDynamicArrays(); initStrings(); initReferences(); initDefaults(); } } ClothingMaterialLibraryParameters::~ClothingMaterialLibraryParameters() { freeStrings(); freeReferences(); freeDynamicArrays(); } void ClothingMaterialLibraryParameters::destroy() { // We cache these fields here to avoid overwrite in destructor bool doDeallocateSelf = mDoDeallocateSelf; NvParameterized::Traits* traits = mParameterizedTraits; int32_t* refCount = mRefCount; void* buf = mBuffer; this->~ClothingMaterialLibraryParameters(); NvParameters::destroy(this, traits, doDeallocateSelf, refCount, buf); } const NvParameterized::DefinitionImpl* ClothingMaterialLibraryParameters::getParameterDefinitionTree(void) { if (!mBuiltFlag) // Double-checked lock { NvParameterized::MutexType::ScopedLock lock(mBuiltFlagMutex); if (!mBuiltFlag) { buildTree(); } } return(&ParamDefTable[0]); } const NvParameterized::DefinitionImpl* ClothingMaterialLibraryParameters::getParameterDefinitionTree(void) const { ClothingMaterialLibraryParameters* tmpParam = const_cast(this); if (!mBuiltFlag) // Double-checked lock { NvParameterized::MutexType::ScopedLock lock(mBuiltFlagMutex); if (!mBuiltFlag) { tmpParam->buildTree(); } } return(&ParamDefTable[0]); } NvParameterized::ErrorType ClothingMaterialLibraryParameters::getParameterHandle(const char* long_name, Handle& handle) const { ErrorType Ret = NvParameters::getParameterHandle(long_name, handle); if (Ret != ERROR_NONE) { return(Ret); } size_t offset; void* ptr; getVarPtr(handle, ptr, offset); if (ptr == NULL) { return(ERROR_INDEX_OUT_OF_RANGE); } return(ERROR_NONE); } NvParameterized::ErrorType ClothingMaterialLibraryParameters::getParameterHandle(const char* long_name, Handle& handle) { ErrorType Ret = NvParameters::getParameterHandle(long_name, handle); if (Ret != ERROR_NONE) { return(Ret); } size_t offset; void* ptr; getVarPtr(handle, ptr, offset); if (ptr == NULL) { return(ERROR_INDEX_OUT_OF_RANGE); } return(ERROR_NONE); } void ClothingMaterialLibraryParameters::getVarPtr(const Handle& handle, void*& ptr, size_t& offset) const { ptr = getVarPtrHelper(&ParamLookupTable[0], const_cast(¶meters()), handle, offset); } /* Dynamic Handle Indices */ /* [1,0] - materials.materialName */ void ClothingMaterialLibraryParameters::freeParameterDefinitionTable(NvParameterized::Traits* traits) { if (!traits) { return; } if (!mBuiltFlag) // Double-checked lock { return; } NvParameterized::MutexType::ScopedLock lock(mBuiltFlagMutex); if (!mBuiltFlag) { return; } for (uint32_t i = 0; i < NumParamDefs; ++i) { ParamDefTable[i].~DefinitionImpl(); } traits->free(ParamDefTable); mBuiltFlag = false; } #define PDEF_PTR(index) (&ParamDefTable[index]) void ClothingMaterialLibraryParameters::buildTree(void) { uint32_t allocSize = sizeof(NvParameterized::DefinitionImpl) * NumParamDefs; ParamDefTable = (NvParameterized::DefinitionImpl*)(mParameterizedTraits->alloc(allocSize)); memset(ParamDefTable, 0, allocSize); for (uint32_t i = 0; i < NumParamDefs; ++i) { NV_PARAM_PLACEMENT_NEW(ParamDefTable + i, NvParameterized::DefinitionImpl)(*mParameterizedTraits); } // Initialize DefinitionImpl node: nodeIndex=0, longName="" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[0]; ParamDef->init("", TYPE_STRUCT, "STRUCT", true); } // Initialize DefinitionImpl node: nodeIndex=1, longName="materials" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[1]; ParamDef->init("materials", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Array of materials that are part of this library.", true); ParamDefTable[1].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); static const uint8_t dynHandleIndices[2] = { 1, 0, }; ParamDef->setDynamicHandleIndicesMap(dynHandleIndices, 2); } // Initialize DefinitionImpl node: nodeIndex=2, longName="materials[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[2]; ParamDef->init("materials", TYPE_STRUCT, "ClothingMaterial", true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Array of materials that are part of this library.", true); ParamDefTable[2].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=3, longName="materials[].materialName" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[3]; ParamDef->init("materialName", TYPE_STRING, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Material name", true); ParamDefTable[3].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=4, longName="materials[].verticalStretchingStiffness" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[4]; ParamDef->init("verticalStretchingStiffness", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[4].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Vertical stretching stiffness of the cloth in the range (0, 1]. This parameter is ignored by the PhysX 2.8.4 solver.", true); ParamDefTable[4].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=5, longName="materials[].horizontalStretchingStiffness" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[5]; ParamDef->init("horizontalStretchingStiffness", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[5].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Horizontal Stretching stiffness of the cloth in the range (0, 1].", true); ParamDefTable[5].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=6, longName="materials[].bendingStiffness" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[6]; ParamDef->init("bendingStiffness", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[6].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Bending stiffness of the cloth in the range [0, 1].", true); ParamDefTable[6].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=7, longName="materials[].shearingStiffness" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[7]; ParamDef->init("shearingStiffness", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[7].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Shearing stiffness of the cloth in the range [0, 1].", true); ParamDefTable[7].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=8, longName="materials[].tetherStiffness" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[8]; ParamDef->init("tetherStiffness", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[8].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Range [0, 1], but should be 0. The higher this value, the more the piece of clothing is allowed to stretch.", true); ParamDefTable[8].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=9, longName="materials[].tetherLimit" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[9]; ParamDef->init("tetherLimit", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(4.0), true); HintTable[1].init("min", double(1.0), true); ParamDefTable[9].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(4.0), true); HintTable[1].init("min", double(1.0), true); HintTable[2].init("shortDescription", "Range [1, 4], but should be 1. This scales the restlength of the tether constraints.", true); ParamDefTable[9].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=10, longName="materials[].orthoBending" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[10]; ParamDef->init("orthoBending", TYPE_BOOL, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("longDescription", "Bending is modeled via an angular spring between adjacent triangles. This mode is slower but independent of stretching resistance.\n", true); HintTable[1].init("shortDescription", "Enable/disable orthogonal bending resistance.", true); ParamDefTable[10].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=11, longName="materials[].verticalStiffnessScaling" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[11]; ParamDef->init("verticalStiffnessScaling", TYPE_STRUCT, "StiffnessScaling", true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Vertical stiffness scaling", true); ParamDefTable[11].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=12, longName="materials[].verticalStiffnessScaling.compressionRange" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[12]; ParamDef->init("compressionRange", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[12].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "For any edge where the simulated length is within the range [restlength, compressionRange*restlength],\nthe scale will be multiplied on top of the regular stiffness.\nThis is can be used to allow the cloth to compress more easily up to a certain limit.\n", true); HintTable[1].init("max", double(1.0), true); HintTable[2].init("min", double(0.0), true); HintTable[3].init("shortDescription", "Multiplier relative to rest length that defines where the stiffness is scaled down to allow compression.", true); ParamDefTable[12].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=13, longName="materials[].verticalStiffnessScaling.stretchRange" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[13]; ParamDef->init("stretchRange", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("min", double(1.0), true); ParamDefTable[13].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("longDescription", "For any edge where the simulated length is within the range [restlength, stretchRange*restlength],\nthe scale will be multiplied on top of the regular stiffness.\nThis is can be used to allow the cloth to stretch more easily up to a certain limit.\n", true); HintTable[1].init("min", double(1.0), true); HintTable[2].init("shortDescription", "Multiplier relative to rest length that defines the range where the stiffness is scaled down to allow stretching.", true); ParamDefTable[13].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=14, longName="materials[].verticalStiffnessScaling.scale" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[14]; ParamDef->init("scale", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[14].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Stiffness scale [0, 1] applied when inside the scaling range.", true); ParamDefTable[14].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=15, longName="materials[].horizontalStiffnessScaling" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[15]; ParamDef->init("horizontalStiffnessScaling", TYPE_STRUCT, "StiffnessScaling", true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Horizontal stiffness scaling", true); ParamDefTable[15].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=16, longName="materials[].horizontalStiffnessScaling.compressionRange" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[16]; ParamDef->init("compressionRange", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[16].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "For any edge where the simulated length is within the range [restlength, compressionRange*restlength],\nthe scale will be multiplied on top of the regular stiffness.\nThis is can be used to allow the cloth to compress more easily up to a certain limit.\n", true); HintTable[1].init("max", double(1.0), true); HintTable[2].init("min", double(0.0), true); HintTable[3].init("shortDescription", "Multiplier relative to rest length that defines where the stiffness is scaled down to allow compression.", true); ParamDefTable[16].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=17, longName="materials[].horizontalStiffnessScaling.stretchRange" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[17]; ParamDef->init("stretchRange", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("min", double(1.0), true); ParamDefTable[17].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("longDescription", "For any edge where the simulated length is within the range [restlength, stretchRange*restlength],\nthe scale will be multiplied on top of the regular stiffness.\nThis is can be used to allow the cloth to stretch more easily up to a certain limit.\n", true); HintTable[1].init("min", double(1.0), true); HintTable[2].init("shortDescription", "Multiplier relative to rest length that defines the range where the stiffness is scaled down to allow stretching.", true); ParamDefTable[17].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=18, longName="materials[].horizontalStiffnessScaling.scale" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[18]; ParamDef->init("scale", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[18].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Stiffness scale [0, 1] applied when inside the scaling range.", true); ParamDefTable[18].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=19, longName="materials[].bendingStiffnessScaling" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[19]; ParamDef->init("bendingStiffnessScaling", TYPE_STRUCT, "StiffnessScaling", true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Bending stiffness scaling", true); ParamDefTable[19].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=20, longName="materials[].bendingStiffnessScaling.compressionRange" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[20]; ParamDef->init("compressionRange", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[20].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "For any edge where the simulated length is within the range [restlength, compressionRange*restlength],\nthe scale will be multiplied on top of the regular stiffness.\nThis is can be used to allow the cloth to compress more easily up to a certain limit.\n", true); HintTable[1].init("max", double(1.0), true); HintTable[2].init("min", double(0.0), true); HintTable[3].init("shortDescription", "Multiplier relative to rest length that defines where the stiffness is scaled down to allow compression.", true); ParamDefTable[20].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=21, longName="materials[].bendingStiffnessScaling.stretchRange" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[21]; ParamDef->init("stretchRange", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("min", double(1.0), true); ParamDefTable[21].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("longDescription", "For any edge where the simulated length is within the range [restlength, stretchRange*restlength],\nthe scale will be multiplied on top of the regular stiffness.\nThis is can be used to allow the cloth to stretch more easily up to a certain limit.\n", true); HintTable[1].init("min", double(1.0), true); HintTable[2].init("shortDescription", "Multiplier relative to rest length that defines the range where the stiffness is scaled down to allow stretching.", true); ParamDefTable[21].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=22, longName="materials[].bendingStiffnessScaling.scale" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[22]; ParamDef->init("scale", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[22].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Stiffness scale [0, 1] applied when inside the scaling range.", true); ParamDefTable[22].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=23, longName="materials[].shearingStiffnessScaling" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[23]; ParamDef->init("shearingStiffnessScaling", TYPE_STRUCT, "StiffnessScaling", true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Shearing stiffness scaling", true); ParamDefTable[23].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=24, longName="materials[].shearingStiffnessScaling.compressionRange" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[24]; ParamDef->init("compressionRange", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[24].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "For any edge where the simulated length is within the range [restlength, compressionRange*restlength],\nthe scale will be multiplied on top of the regular stiffness.\nThis is can be used to allow the cloth to compress more easily up to a certain limit.\n", true); HintTable[1].init("max", double(1.0), true); HintTable[2].init("min", double(0.0), true); HintTable[3].init("shortDescription", "Multiplier relative to rest length that defines where the stiffness is scaled down to allow compression.", true); ParamDefTable[24].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=25, longName="materials[].shearingStiffnessScaling.stretchRange" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[25]; ParamDef->init("stretchRange", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("min", double(1.0), true); ParamDefTable[25].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("longDescription", "For any edge where the simulated length is within the range [restlength, stretchRange*restlength],\nthe scale will be multiplied on top of the regular stiffness.\nThis is can be used to allow the cloth to stretch more easily up to a certain limit.\n", true); HintTable[1].init("min", double(1.0), true); HintTable[2].init("shortDescription", "Multiplier relative to rest length that defines the range where the stiffness is scaled down to allow stretching.", true); ParamDefTable[25].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=26, longName="materials[].shearingStiffnessScaling.scale" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[26]; ParamDef->init("scale", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[26].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Stiffness scale [0, 1] applied when inside the scaling range.", true); ParamDefTable[26].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=27, longName="materials[].damping" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[27]; ParamDef->init("damping", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[27].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Spring damping of the cloth in the range [0, 1]", true); ParamDefTable[27].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=28, longName="materials[].stiffnessFrequency" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[28]; ParamDef->init("stiffnessFrequency", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(500.0), true); HintTable[1].init("min", double(10.0), true); ParamDefTable[28].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(500.0), true); HintTable[1].init("min", double(10.0), true); HintTable[2].init("shortDescription", "Scales linearity of behavior for the varous stiffness values in the interval (0, 1)", true); ParamDefTable[28].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=29, longName="materials[].drag" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[29]; ParamDef->init("drag", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[29].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "The drag coefficient is the portion of local frame velocity that is applied to each particle.\n", true); HintTable[1].init("max", double(1.0), true); HintTable[2].init("min", double(0.0), true); HintTable[3].init("shortDescription", "Drag coefficient n the range [0, 1]", true); ParamDefTable[29].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=30, longName="materials[].comDamping" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[30]; ParamDef->init("comDamping", TYPE_BOOL, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("longDescription", "If set, the global rigid body modes (translation and rotation) are extracted from damping. This way, the cloth\ncan freely move and rotate even under high damping.\n", true); HintTable[1].init("shortDescription", "Enable/disable center of mass damping of internal velocities.", true); ParamDefTable[30].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=31, longName="materials[].friction" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[31]; ParamDef->init("friction", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[31].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "Currently only spheres and capsules impose friction on the colliding particles.", true); HintTable[1].init("max", double(1.0), true); HintTable[2].init("min", double(0.0), true); HintTable[3].init("shortDescription", "Friction coefficient in the range [0, 1]", true); ParamDefTable[31].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=32, longName="materials[].massScale" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[32]; ParamDef->init("massScale", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(100.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[32].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("max", double(100.0), true); HintTable[1].init("min", double(0.0), true); HintTable[2].init("shortDescription", "Controls the amount of mass scaling during collision [0, 100]", true); ParamDefTable[32].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=33, longName="materials[].solverIterations" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[33]; ParamDef->init("solverIterations", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("min", uint64_t(1), true); ParamDefTable[33].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("longDescription", "Small numbers make the simulation faster while the cloth gets less stiff.\n", true); HintTable[1].init("min", uint64_t(1), true); HintTable[2].init("shortDescription", "Number of solver iterations. For 2.x cloth", true); ParamDefTable[33].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=34, longName="materials[].solverFrequency" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[34]; ParamDef->init("solverFrequency", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("min", uint64_t(20), true); ParamDefTable[34].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[3]; static Hint* HintPtrTable[3] = { &HintTable[0], &HintTable[1], &HintTable[2], }; HintTable[0].init("longDescription", "Small numbers make the simulation faster while the cloth gets less stiff.\n", true); HintTable[1].init("min", uint64_t(20), true); HintTable[2].init("shortDescription", "Number of solver iterations per second. For 3.x cloth", true); ParamDefTable[34].setHints((const NvParameterized::Hint**)HintPtrTable, 3); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=35, longName="materials[].gravityScale" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[35]; ParamDef->init("gravityScale", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("longDescription", "A value of 0 will make the cloth ignore gravity, a value of 10 will apply 10 times the gravity.\n", true); HintTable[1].init("shortDescription", "Amount of gravity that is applied to the cloth.", true); ParamDefTable[35].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=36, longName="materials[].inertiaScale" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[36]; ParamDef->init("inertiaScale", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[36].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "A value of 0 will make the cloth move in global space without inertia, a value of 1 will keep all inertia.\n", true); HintTable[1].init("max", double(1.0), true); HintTable[2].init("min", double(0.0), true); HintTable[3].init("shortDescription", "Amount of inertia that is kept when using local space simulation.", true); ParamDefTable[36].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=37, longName="materials[].hardStretchLimitation" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[37]; ParamDef->init("hardStretchLimitation", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(2.0), true); HintTable[1].init("min", double(0.0), true); ParamDefTable[37].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "Good values are usually between 1 and 1.1. Any value >= 1 will guarantee that a certain set of edges is not longer\nthan that value times the initial rest length.\n", true); HintTable[1].init("max", double(2.0), true); HintTable[2].init("min", double(0.0), true); HintTable[3].init("shortDescription", "Make cloth simulation less stretchy. A value smaller than 1 will turn it off.", true); ParamDefTable[37].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=38, longName="materials[].maxDistanceBias" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[38]; ParamDef->init("maxDistanceBias", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("max", double(1.0), true); HintTable[1].init("min", double(-1.0), true); ParamDefTable[38].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #else static HintImpl HintTable[4]; static Hint* HintPtrTable[4] = { &HintTable[0], &HintTable[1], &HintTable[2], &HintTable[3], }; HintTable[0].init("longDescription", "A value smaller than 0 will turn the sphere into a capsule and eventually a line (at value -1) along the normal of the vertex.\nA value bigger than 0 will turn the sphere into a disc.\n", true); HintTable[1].init("max", double(1.0), true); HintTable[2].init("min", double(-1.0), true); HintTable[3].init("shortDescription", "Deform the max distance sphere into a capsule or a disc.", true); ParamDefTable[38].setHints((const NvParameterized::Hint**)HintPtrTable, 4); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=39, longName="materials[].hierarchicalSolverIterations" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[39]; ParamDef->init("hierarchicalSolverIterations", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("min", uint64_t(0), true); ParamDefTable[39].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("min", uint64_t(0), true); HintTable[1].init("shortDescription", "Number of iterations of the hierarchical cloth solver.", true); ParamDefTable[39].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=40, longName="materials[].selfcollisionThickness" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[40]; ParamDef->init("selfcollisionThickness", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("longDescription", "This feature prevents meshes from self-intersecting. Only works properly when configured properly.", true); HintTable[1].init("shortDescription", "Minimal amount of distance particles will keep of each other.", true); ParamDefTable[40].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=41, longName="materials[].selfcollisionSquashScale" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[41]; ParamDef->init("selfcollisionSquashScale", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("longDescription", "This feature prevents self collision thickness becoming too high for low resolution cloth.", true); HintTable[1].init("shortDescription", "Amount of thickness scaling along surface normal.", true); ParamDefTable[41].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=42, longName="materials[].selfcollisionStiffness" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[42]; ParamDef->init("selfcollisionStiffness", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("longDescription", "This feature prevents meshes from self-intersecting. Only works properly when configured properly.", true); HintTable[1].init("shortDescription", "Stiffness of self collision solver.", true); ParamDefTable[42].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // SetChildren for: nodeIndex=0, longName="" { static Definition* Children[1]; Children[0] = PDEF_PTR(1); ParamDefTable[0].setChildren(Children, 1); } // SetChildren for: nodeIndex=1, longName="materials" { static Definition* Children[1]; Children[0] = PDEF_PTR(2); ParamDefTable[1].setChildren(Children, 1); } // SetChildren for: nodeIndex=2, longName="materials[]" { static Definition* Children[28]; Children[0] = PDEF_PTR(3); Children[1] = PDEF_PTR(4); Children[2] = PDEF_PTR(5); Children[3] = PDEF_PTR(6); Children[4] = PDEF_PTR(7); Children[5] = PDEF_PTR(8); Children[6] = PDEF_PTR(9); Children[7] = PDEF_PTR(10); Children[8] = PDEF_PTR(11); Children[9] = PDEF_PTR(15); Children[10] = PDEF_PTR(19); Children[11] = PDEF_PTR(23); Children[12] = PDEF_PTR(27); Children[13] = PDEF_PTR(28); Children[14] = PDEF_PTR(29); Children[15] = PDEF_PTR(30); Children[16] = PDEF_PTR(31); Children[17] = PDEF_PTR(32); Children[18] = PDEF_PTR(33); Children[19] = PDEF_PTR(34); Children[20] = PDEF_PTR(35); Children[21] = PDEF_PTR(36); Children[22] = PDEF_PTR(37); Children[23] = PDEF_PTR(38); Children[24] = PDEF_PTR(39); Children[25] = PDEF_PTR(40); Children[26] = PDEF_PTR(41); Children[27] = PDEF_PTR(42); ParamDefTable[2].setChildren(Children, 28); } // SetChildren for: nodeIndex=11, longName="materials[].verticalStiffnessScaling" { static Definition* Children[3]; Children[0] = PDEF_PTR(12); Children[1] = PDEF_PTR(13); Children[2] = PDEF_PTR(14); ParamDefTable[11].setChildren(Children, 3); } // SetChildren for: nodeIndex=15, longName="materials[].horizontalStiffnessScaling" { static Definition* Children[3]; Children[0] = PDEF_PTR(16); Children[1] = PDEF_PTR(17); Children[2] = PDEF_PTR(18); ParamDefTable[15].setChildren(Children, 3); } // SetChildren for: nodeIndex=19, longName="materials[].bendingStiffnessScaling" { static Definition* Children[3]; Children[0] = PDEF_PTR(20); Children[1] = PDEF_PTR(21); Children[2] = PDEF_PTR(22); ParamDefTable[19].setChildren(Children, 3); } // SetChildren for: nodeIndex=23, longName="materials[].shearingStiffnessScaling" { static Definition* Children[3]; Children[0] = PDEF_PTR(24); Children[1] = PDEF_PTR(25); Children[2] = PDEF_PTR(26); ParamDefTable[23].setChildren(Children, 3); } mBuiltFlag = true; } void ClothingMaterialLibraryParameters::initStrings(void) { } void ClothingMaterialLibraryParameters::initDynamicArrays(void) { materials.buf = NULL; materials.isAllocated = true; materials.elementSize = sizeof(ClothingMaterial_Type); materials.arraySizes[0] = 0; } void ClothingMaterialLibraryParameters::initDefaults(void) { freeStrings(); freeReferences(); freeDynamicArrays(); initDynamicArrays(); initStrings(); initReferences(); } void ClothingMaterialLibraryParameters::initReferences(void) { } void ClothingMaterialLibraryParameters::freeDynamicArrays(void) { if (materials.isAllocated && materials.buf) { mParameterizedTraits->free(materials.buf); } } void ClothingMaterialLibraryParameters::freeStrings(void) { for (int i = 0; i < materials.arraySizes[0]; ++i) { if (materials.buf[i].materialName.isAllocated && materials.buf[i].materialName.buf) { mParameterizedTraits->strfree((char*)materials.buf[i].materialName.buf); } } } void ClothingMaterialLibraryParameters::freeReferences(void) { } } // namespace clothing } // namespace nvidia