import sys
import toolutils
outputitem = None
inputindex = -1
inputitem = None
outputindex = -1
num_args = 1
h_extra_args = ''
pane = toolutils.activePane(kwargs)
if not isinstance(pane, hou.NetworkEditor):
pane = hou.ui.paneTabOfType(hou.paneTabType.NetworkEditor)
if pane is None:
hou.ui.displayMessage(
'Cannot create node: cannot find any network pane')
sys.exit(0)
else: # We're creating this tool from the TAB menu inside a network editor
pane_node = pane.pwd()
if "outputnodename" in kwargs and "inputindex" in kwargs:
outputitem = pane_node.item(kwargs["outputnodename"])
inputindex = kwargs["inputindex"]
h_extra_args += 'set arg4 = "' + kwargs["outputnodename"] + '"\n'
h_extra_args += 'set arg5 = "' + str(inputindex) + '"\n'
num_args = 6
if "inputnodename" in kwargs and "outputindex" in kwargs:
inputitem = pane_node.item(kwargs["inputnodename"])
outputindex = kwargs["outputindex"]
h_extra_args += 'set arg6 = "' + kwargs["inputnodename"] + '"\n'
h_extra_args += 'set arg9 = "' + str(outputindex) + '"\n'
num_args = 9
if "autoplace" in kwargs:
autoplace = kwargs["autoplace"]
else:
autoplace = False
# If shift-clicked we want to auto append to the current
# node
if "shiftclick" in kwargs and kwargs["shiftclick"]:
if inputitem is None:
inputitem = pane.currentNode()
outputindex = 0
if "nodepositionx" in kwargs and "nodepositiony" in kwargs:
try:
pos = [ float( kwargs["nodepositionx"] ),
float( kwargs["nodepositiony"] )]
except:
pos = None
else:
pos = None
if not autoplace and not pane.listMode():
if pos is not None:
pass
elif outputitem is None:
pos = pane.selectPosition(inputitem, outputindex, None, -1)
else:
pos = pane.selectPosition(inputitem, outputindex,
outputitem, inputindex)
if pos is not None:
if "node_bbox" in kwargs:
size = kwargs["node_bbox"]
pos[0] -= size[0] / 2
pos[1] -= size[1] / 2
else:
pos[0] -= 0.573625
pos[1] -= 0.220625
h_extra_args += 'set arg2 = "' + str(pos[0]) + '"\n'
h_extra_args += 'set arg3 = "' + str(pos[1]) + '"\n'
h_extra_args += 'set argc = "' + str(num_args) + '"\n'
pane_node = pane.pwd()
child_type = pane_node.childTypeCategory().nodeTypes()
if 'geo' not in child_type:
hou.ui.displayMessage(
'Cannot create node: incompatible pane network type')
sys.exit(0)
# First clear the node selection
pane_node.setSelected(False, True)
h_path = pane_node.path()
h_preamble = 'set arg1 = "' + h_path + '"\n'
h_cmd = r'''
if ($argc < 2 || "$arg2" == "") then
set arg2 = 0
endif
if ($argc < 3 || "$arg3" == "") then
set arg3 = 0
endif
# Automatically generated script
# $arg1 - the path to add this node
# $arg2 - x position of the tile
# $arg3 - y position of the tile
# $arg4 - input node to wire to
# $arg5 - which input to wire to
# $arg6 - output node to wire to
# $arg7 - the type of this node
# $arg8 - the node is an indirect input
# $arg9 - index of output from $arg6
\set noalias = 1
set saved_path = `execute("oppwf")`
opcf $arg1
# Node $_obj_tube1 (Object/geo)
set _obj_tube1 = `run("opadd -e -n -v geo tube1")`
oplocate -x `$arg2 + 0` -y `$arg3 + 0` $_obj_tube1
opspareds ' group { name "stdswitcher4" label "Transform" parm { name "xOrd" baseparm label "Transform Order" joinnext export none } parm { name "rOrd" baseparm label "Rotate Order" nolabel export none } parm { name "t" baseparm label "Translate" export all } parm { name "r" baseparm label "Rotate" export all } parm { name "s" baseparm label "Scale" export none } parm { name "p" baseparm label "Pivot Translate" export none } parm { name "pr" baseparm label "Pivot Rotate" export none } parm { name "scale" baseparm label "Uniform Scale" export none } parm { name "pre_xform" baseparm label "Modify Pre-Transform" export none } parm { name "keeppos" baseparm label "Keep Position When Parenting" export none } parm { name "childcomp" baseparm label "Child Compensation" export none } parm { name "constraints_on" baseparm label "Enable Constraints" export none } parm { name "constraints_path" baseparm label "Constraints" export none } parm { name "lookatpath" baseparm label "Look At" invisible export none } parm { name "lookupobjpath" baseparm label "Look Up Object" invisible export none } parm { name "lookup" baseparm label "Look At Up Vector" invisible export none } parm { name "pathobjpath" baseparm label "Path Object" invisible export none } parm { name "roll" baseparm label "Roll" invisible export none } parm { name "pos" baseparm label "Position" invisible export none } parm { name "uparmtype" baseparm label "Parameterization" invisible export none } parm { name "pathorient" baseparm label "Orient Along Path" invisible export none } parm { name "up" baseparm label "Orient Up Vector" invisible export none } parm { name "bank" baseparm label "Auto-Bank factor" invisible export none } } group { name "stdswitcher4_1" label "Render" parm { name "shop_materialpath" baseparm label "Material" export none } parm { name "shop_materialopts" baseparm label "Options" invisible export none } parm { name "tdisplay" baseparm label "Display" joinnext export none } parm { name "display" baseparm label "Display" export none } parm { name "viewportlod" label "Display As" type ordinal default { "full" } help "Choose how the object\'s geometry should be rendered in the viewport" menu { "full" "Full Geometry" "points" "Point Cloud" "box" "Bounding Box" "centroid" "Centroid" "hidden" "Hidden" "subd" "Subdivision Surface / Curves" } parmtag { "spare_category" "Render" } } parm { name "vm_rendervisibility" label "Render Visibility" type string default { "*" } menureplace { "*" "Visible to all" "primary" "Visible only to primary rays" "primary|shadow" "Visible only to primary and shadow rays" "-primary" "Invisible to primary rays (Phantom)" "-diffuse" "Invisible to diffuse rays" "-diffuse&-reflect&-refract" "Invisible to secondary rays" "" "Invisible (Unrenderable)" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "rendervisibility" } parmtag { "spare_category" "Render" } } parm { name "vm_rendersubd" label "Render Polygons As Subdivision (Mantra)" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "rendersubd" } parmtag { "spare_category" "Geometry" } } parm { name "vm_subdstyle" label "Subdivision Style" type string default { "mantra_catclark" } hidewhen "{ vm_rendersubd == 0 }" menu { "mantra_catclark" "Mantra Catmull-Clark" "osd_catclark" "OpenSubdiv Catmull-Clark" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "subdstyle" } parmtag { "spare_category" "Geometry" } } parm { name "vm_subdgroup" label "Subdivision Group" type string default { "" } hidewhen "{ vm_rendersubd == 0 }" parmtag { "mantra_class" "object" } parmtag { "mantra_name" "subdgroup" } parmtag { "spare_category" "Geometry" } } parm { name "vm_osd_quality" label "Open Subdiv Quality" type float default { "1" } hidewhen "{ vm_rendersubd == 0 vm_subdstyle != osd_catclark }" range { 0 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "osd_quality" } parmtag { "spare_category" "Geometry" } } parm { name "vm_osd_vtxinterp" label "OSD Vtx Interp" type integer default { "2" } hidewhen "{ vm_rendersubd == 0 vm_subdstyle != osd_catclark }" menu { "0" "No vertex interpolation" "1" "Edges only" "2" "Edges and Corners" } range { 0 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "osd_vtxinterp" } parmtag { "spare_category" "Geometry" } } parm { name "vm_osd_fvarinterp" label "OSD FVar Interp" type integer default { "4" } hidewhen "{ vm_rendersubd == 0 vm_subdstyle != osd_catclark }" menu { "0" "Smooth everywhere" "1" "Sharpen corners only" "2" "Sharpen edges and corners" "3" "Sharpen edges and propagated corners" "4" "Sharpen all boundaries" "5" "Bilinear interpolation" } range { 0 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "osd_fvarinterp" } parmtag { "spare_category" "Geometry" } } group { name "folder0" label "Shading" parm { name "categories" label "Categories" type string default { "" } help "A list of tags which can be used to select the object" parmtag { "spare_category" "Shading" } } parm { name "reflectmask" label "Reflection Mask" type oplist default { "*" } help "Objects that will be reflected on this object." parmtag { "opexpand" "1" } parmtag { "opfilter" "!!OBJ/GEOMETRY!!" } parmtag { "oprelative" "/obj" } parmtag { "spare_category" "Shading" } } parm { name "refractmask" label "Refraction Mask" type oplist default { "*" } help "Objects that will be refracted on this object." parmtag { "opexpand" "1" } parmtag { "opfilter" "!!OBJ/GEOMETRY!!" } parmtag { "oprelative" "/obj" } parmtag { "spare_category" "Shading" } } parm { name "lightmask" label "Light Mask" type oplist default { "*" } help "Lights that illuminate this object." parmtag { "opexpand" "1" } parmtag { "opfilter" "!!OBJ/LIGHT!!" } parmtag { "oprelative" "/obj" } parmtag { "spare_category" "Shading" } } parm { name "lightcategories" label "Light Selection" type string default { "*" } parmtag { "spare_category" "Shading" } } parm { name "vm_lpetag" label "LPE Tag" type string default { "" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "lpetag" } parmtag { "spare_category" "Shading" } } parm { name "vm_volumefilter" label "Volume Filter" type string default { "box" } menu { "box" "Box Filter" "gaussian" "Gaussian" "bartlett" "Bartlett (triangle)" "catrom" "Catmull-Rom" "hanning" "Hanning" "blackman" "Blackman" "sinc" "Sinc (sharpening)" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "filter" } parmtag { "spare_category" "Shading" } } parm { name "vm_volumefilterwidth" label "Volume Filter Width" type float default { "1" } range { 0.001 5 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "filterwidth" } parmtag { "spare_category" "Shading" } } parm { name "vm_matte" label "Matte shading" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "matte" } parmtag { "spare_category" "Shading" } } parm { name "vm_rayshade" label "Raytrace Shading" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "rayshade" } parmtag { "spare_category" "Shading" } } } group { name "folder0_1" label "Sampling" parm { name "geo_velocityblur" label "Geometry Velocity Blur" type ordinal default { "off" } disablewhen "{ allowmotionblur == 0 }" menu { "off" "No Velocity Blur" "on" "Velocity Blur" "accelblur" "Acceleration Blur" } } parm { name "geo_accelattribute" label "Acceleration Attribute" type string default { "accel" } hidewhen "{ geo_velocityblur != accelblur }" parmtag { "spare_category" "Sampling" } } } group { name "folder0_2" label "Dicing" parm { name "vm_shadingquality" label "Shading Quality" type float default { "1" } range { 0 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "shadingquality" } parmtag { "spare_category" "Dicing" } } parm { name "vm_flatness" label "Dicing Flatness" type float default { "0.05" } range { 0 1 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "flatness" } parmtag { "spare_category" "Dicing" } } parm { name "vm_raypredice" label "Ray Predicing" type integer default { "0" } menu { "0" "Disable Predicing" "1" "Full Predicing" "2" "Precompute Bounds" } range { 0 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "raypredice" } parmtag { "spare_category" "Dicing" } } parm { name "vm_curvesurface" label "Shade Curves As Surfaces" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "curvesurface" } parmtag { "spare_category" "Dicing" } } } group { name "folder0_3" label "Geometry" parm { name "vm_rmbackface" label "Backface Removal" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "rmbackface" } parmtag { "spare_category" "Geometry" } } parm { name "shop_geometrypath" label "Procedural Shader" type oppath default { "" } parmtag { "opfilter" "!!SHOP/GEOMETRY!!" } parmtag { "oprelative" "." } parmtag { "spare_category" "Geometry" } } parm { name "vm_forcegeometry" label "Force Procedural Geometry Output" type toggle default { "1" } parmtag { "spare_category" "Geometry" } } parm { name "vm_rendersubdcurves" label "Render Polygon Curves As Subdivision (Mantra)" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "rendersubdcurves" } parmtag { "spare_category" "Geometry" } } parm { name "vm_renderpoints" label "Render As Points (Mantra)" type integer default { "2" } menu { "0" "No Point Rendering" "1" "Render Only Points" "2" "Render Unconnected Points" } range { 0 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "renderpoints" } parmtag { "spare_category" "Geometry" } } parm { name "vm_renderpointsas" label "Render Points As (Mantra)" type integer default { "0" } disablewhen "{ vm_renderpoints == 0 }" menu { "0" "Spheres" "1" "Circles" } range { 0 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "renderpointsas" } parmtag { "spare_category" "Geometry" } } parm { name "vm_usenforpoints" label "Use N For Point Rendering" type toggle default { "0" } disablewhen "{ vm_renderpoints == 0 }" parmtag { "mantra_class" "object" } parmtag { "mantra_name" "usenforpoints" } parmtag { "spare_category" "Geometry" } } parm { name "vm_pointscale" label "Point Scale" type float default { "1" } disablewhen "{ vm_renderpoints == 0 }" range { 0! 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "pointscale" } parmtag { "spare_category" "Geometry" } } parm { name "vm_pscalediameter" label "Treat Point Scale as Diameter Instead of Radius" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "pscalediameter" } parmtag { "spare_category" "Geometry" } } parm { name "vm_metavolume" label "Metaballs as Volume" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "metavolume" } parmtag { "spare_category" "Geometry" } } parm { name "vm_coving" label "Coving" type integer default { "1" } menu { "0" "Disable Coving" "1" "Coving for displacement/sub-d" "2" "Coving for all primitives" } range { 0 10 } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "coving" } parmtag { "spare_category" "Geometry" } } parm { name "vm_materialoverride" label "Material Override" type string default { "compact" } menu { "none" "Disabled" "full" "Evaluate for Each Primitve/Point" "compact" "Evaluate Once" } parmtag { "spare_category" "Geometry" } } parm { name "vm_overridedetail" label "Ignore Geometry Attribute Shaders" type toggle default { "0" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "overridedetail" } parmtag { "spare_category" "Geometry" } } parm { name "vm_procuseroottransform" label "Proc Use Root Transform" type toggle default { "1" } parmtag { "mantra_class" "object" } parmtag { "mantra_name" "procuseroottransform" } parmtag { "spare_category" "Geometry" } } } } group { name "stdswitcher4_2" label "Arnold" parm { name "shop_propertiespath" label "Default Properties" type oppath default { "" } help "Specifies a Property SHOP that is used to resolve rendering parameter values. At render time, this SHOP (if given) is used to resolve rendering parameter values first, before looking for then on the objects being rendered." range { 0 1 } parmtag { "opfilter" "!!SHOP/PROPERTIES!!" } parmtag { "oprelative" "." } parmtag { "spare_category" "Shaders" } } parm { name "ar_user_options" label "User Options" type string joinnext default { "" } help "This string is passed to AiNodeSetAttributes() ont the Arnold node. It can contain any number of parameter/value pairs separated by whitespace (spaces, tabs, newlines) as found in .ass files." disablewhen "{ ar_user_options_enable == 0 }" } parm { name "ar_user_options_enable" label "Enable" type toggle default { "0" } help "Overrides the value of any parameter of the Arnold node." } group { name "folder_subdivision" label "Subdivision" parm { name "ar_subdiv_type" label "Type" type string default { "none" } help "Subdivision algorithm. None ignores any subdivision and renders the mesh as it is. Linear subdivision puts vertices in the middle of each face. The Catmull-Clark algorithm is used to create smooth surfaces by recursive subdivision surface modeling. The resulting surface will always consist of a mesh of quadrilateral faces." menu { "none" "None" "catclark" "Catmull-Clark" "linear" "Linear" } range { 0 1 } parmtag { "spare_category" "Subdivision" } } parm { name "ar_subdiv_iterations" label "Iterations" type integer default { "1" } help "The number of iterations / levels of subdivision. With Catmull-Clark subdivision, increasing the number of iterations produces a smoother mesh." disablewhen "{ ar_subdiv_type == none }" range { 1! 10 } parmtag { "spare_category" "Subdivision" } } parm { name "ar_subdiv_adaptive_metric" label "Adaptive Metric" type string joinnext default { "auto" } help "The adaptive subdivision criterion. Auto subdiv will choose between the EDGELENGTH mode and the FLATNESS depending on the displacement property of the polymesh. This means that if there is a displacement it will use the EDGELENGTH algorithm. If there is not displacement (or it is ignored in the global options) it will use FLATNESS." disablewhen "{ ar_subdiv_type == none }" menu { "auto" "Auto" "edge_length" "Edge Length" "flatness" "Flatness" } parmtag { "spare_category" "Subdivision" } } parm { name "ar_subdiv_adaptive_error" label " Error" type float default { "0" } help "The \\"adaptive error\\" refers to the acceptable tessellation error as seen from the camera. If there\'s no displacement, then the error represents the distance from the subdivided mesh to the \\"true\\" or \\"limit\\" surface -- sort of a \\"flatness\\" heuristic. The smaller the error, the closer to the limit surface a mesh will be and the less inter-frame popping when the subdivision level jumps. If displacement is enabled, then the error represents the final size of the subdivided quads. A value of 0 disables adaptive subdivision." disablewhen "{ ar_subdiv_type == none }" range { 0! 10 } parmtag { "spare_category" "Subdivision" } } parm { name "ar_subdiv_adaptive_space" label "Adaptive Space" type string default { "raster" } help "The space in which the adaptive metric is evaluated." disablewhen "{ ar_subdiv_type == none }" menu { "raster" "Raster" "object" "Object" } parmtag { "spare_category" "Subdivision" } } parm { name "ar_subdiv_uv_smoothing" label "UV Smoothing" type string joinnext default { "pin_corners" } help "UV smoothing algorithm." disablewhen "{ ar_subdiv_type == none }" menu { "pin_corners" "Pin Corners" "pin_borders" "Pin Borders" "linear" "Linear" "smooth" "Smooth" } range { 0 1 } parmtag { "spare_category" "Subdivision" } } parm { name "ar_subdiv_smooth_derivs" label "Smooth Derivatives" type toggle default { "0" } help "This option makes it possible to remove the faceted appearance from anisotropic speculars. The object must have a valid UV map for this option to work and only works if you apply at least one subdivision level to the geometry." disablewhen "{ ar_subdiv_type == none }" range { 0 1 } parmtag { "spare_category" "Subdivision" } } parm { name "ar_merge_vertex_indices" label "Merge Vertex Indices" type toggle default { "1" } help "Enable merging of the indices and data of coincident and identical vertex attribute values (UVs, normals, vertex user data). This allows the proper interpolation of vertex attributes when subdividing, and yields more compact render scenes in memory and on disk, at the cost of a slower export." range { 0 1 } parmtag { "spare_category" "Subdivision" } } parm { name "ar_subdiv_frustum_ignore" label "Ignore Frustum Culling" type toggle default { "0" } help "Subdivision surfaces outside the view or dicing camera frustum will not be subdivided. This can be turned on globally by enabling subdiv_frustum_culling on the ROP and can be turned off for specific meshes by setting subdiv_frustum_ignore true." disablewhen "{ ar_subdiv_type == none }" parmtag { "spare_category" "Subdivision" } } } group { name "folder_subdivision_1" label "Displacement" parm { name "ar_disp_height" label "Height" type float default { "1" } range { 0 10 } parmtag { "spare_category" "Displacement" } } parm { name "ar_disp_zero_value" label "Zero Value" type float default { "0" } range { 0 1 } parmtag { "spare_category" "Displacement" } } parm { name "ar_disp_padding" label "Bounds Padding" type float default { "0" } range { 0 10 } parmtag { "spare_category" "Displacement" } } parm { name "ar_disp_autobump" label "Autobump" type toggle default { "0" } range { 0 1 } parmtag { "spare_category" "Displacement" } } groupcollapsible { name "folder_autobump" label "Autobump Visibility" parm { name "ar_autobump_visibility_camera" label "Camera" type toggle default { "1" } help "Toggle autobump for camera rays (i.e. primary or view rays)." disablewhen "{ ar_disp_autobump == 0 }" range { 0 1 } parmtag { "spare_category" "Displacement" } } parm { name "ar_autobump_visibility_shadow" label "Shadow" type toggle default { "0" } help "Toggle autobump for shadow rays fired in the direct lighting calculations." disablewhen "{ ar_disp_autobump == 0 }" range { 0 1 } parmtag { "spare_category" "Displacement" } } parm { name "ar_autobump_visibility_diffuse_transmit" label "Diffuse Transmission" type toggle default { "0" } help "Toggle autobump for indirect diffuse transmission rays." disablewhen "{ ar_disp_autobump == 0 }" range { 0 1 } parmtag { "spare_category" "Displacement" } } parm { name "ar_autobump_visibility_specular_transmit" label "Specular Transmission" type toggle default { "0" } help "Toggle autobump for indirect specular transmission rays." disablewhen "{ ar_disp_autobump == 0 }" range { 0 1 } parmtag { "spare_category" "Displacement" } } parm { name "ar_autobump_visibility_diffuse_reflect" label "Diffuse Reflection" type toggle default { "0" } help "Toggle autobump for indirect diffuse reflection rays." disablewhen "{ ar_disp_autobump == 0 }" range { 0 1 } parmtag { "spare_category" "Displacement" } } parm { name "ar_autobump_visibility_specular_reflect" label "Specular Reflection" type toggle default { "0" } help "Toggle autobump for indirect specular reflection rays." disablewhen "{ ar_disp_autobump == 0 }" range { 0 1 } parmtag { "spare_category" "Displacement" } } parm { name "ar_autobump_visibility_volume" label "Volume Scattering" type toggle default { "0" } help "Toggle autobump for indirect volume scattering rays." disablewhen "{ ar_disp_autobump == 0 }" range { 0 1 } parmtag { "spare_category" "Displacement" } } } } group { name "folder_subdivision_2" label "Shapes" parm { name "ar_min_pixel_width" label "Minimum Pixel Width" type float default { "0" } help "If this value is non-zero, points or curves with a small on-screen width will be automatically enlarged so that they are at least the specified size in pixels. The enlargement fraction is then used in the hair shader to adjust the opacity so that the visible thickness of the hair remains the same. For a given number of AA samples, this makes it a lot easier to antialias fine hair, at the expense of render time (because of the additional transparency/depth complexity). Good values are in the range 0.2 to 0.7. Values closer to 0 are faster to render but need more AA samples. So if your scene already uses very high AA settings, you should use a low value like 0.1. For best results, you may need to increase the auto-transparency depth, and/or lower the auto-transparency threshold, but watch the effect on render times. Note that this parameter currently works with the ribbon mode only." range { 0 10 } parmtag { "spare_category" "Curves" } } parm { name "ar_radius" label "Default Radius" type float default { "0.05" } help "Sets the default rendered radius of points or thickness of curves. This property can be overridden per point with the \\"ar_radius\\", \\"pscale\\" or \\"width\\" (curves only) attributes." range { 0 10 } parmtag { "units" "m1" } } group { name "folder_points" label "Points" parm { name "ar_mode" label "Mode" type ordinal default { "sphere" } help "Rendering mode for points or particles. Can be spheres, or camera-facing disks or quads." menu { "disk" "Disk" "sphere" "Sphere" "quad" "Quad" } range { 0 1 } } parm { name "ar_point_scale" label "Point Scale" type float default { "1" } help "A global scale factor applied to points." range { 0! 10 } } parm { name "ar_aspect" label "Aspect" type log default { "1" } help "The aspect ratio for quads. This property can be overrriden per point by setting the \\"ar_aspect\\" or \\"spritescale\\" attributes on the geometry." disablewhen "{ ar_mode != quad }" range { 0.1 10 } } parm { name "ar_rotation" label "Rotation" type angle default { "0" } help "The rotation angle in degrees for quads. This property can be overrriden per point by setting the \\"ar_rotation\\" or the \\"spriterot\\" attributes on the geometry." disablewhen "{ ar_mode != quad }" range { -180 180 } } } group { name "folder_points_1" label "Curves" parm { name "ar_curves_basis" label "Basis" type string default { "auto" } help "The curves basis to interpret the knots of the input curves or open polygons. When set to \\"Automatic\\", the basis will attempt to match the closest equivalent in Arnold, ie. linear for open polygons, Bezier for Bezier curves and B-spline for NURBS." menu { "bezier" "Bezier" "b-spline" "B-Spline" "catmull-rom" "Catmull-Rom" "linear" "Linear" "auto" "Automatic" } range { 0 1 } parmtag { "spare_category" "Curves" } } parm { name "ar_curves_mode" label "Mode" type string default { "ribbon" } help "- Ribbon: This mode is recommended for fine geometry such as realistic hair, fur or fields of grass. These curves are rendered as camera-facing flat ribbons. For secondary and shadow rays, they face the incoming ray direction. This mode doesn\'t look so good for very wide hairs or dramatic zoom-ins because of the flat appearance. This mode works best with a proper hair shader (perhaps based on a Kay-Kajiya or Marschner specular model).\\\\n\\\\n- Thick: This mode resembles spaghetti. It has a circular cross section, and a normal vector that varies across the width of the hair. Thick hairs look great when zoomed in, and are specially useful for effects work, but their varying normals make them more difficult to antialias when they are small. You can use any shader with this rendering mode, including lambert, phong, etc.\\\\n\\\\n- Oriented: This mode is similar to the ribbons mode, but you can set the ribbon orientation for each knot with an \\"ar_orientations\\" vector attribute representing the direction of the normal of the ribbon. This mode can be useful to render grass strands for example." menu { "ribbon" "Ribbon" "thick" "Thick" "oriented" "Oriented " } range { 0 1 } parmtag { "spare_category" "Curves" } } } group { name "folder_points_2" label "Volumes" parm { name "ar_step_size" label "Volume Step Size" type float default { "0" } help "When ar_step_size is set to a value other than zero, then points rendered as spheres, particles and polymeshes will be rendered as volumes." range { 0 1 } } parm { name "ar_volume_padding" label "Volume Padding" type float default { "0" } help "When rendering particles or polymeshes as volumes (when ar_step_size is non-zero), ar_volume_padding will provide extra the volume padding specified for displacement requirements" disablewhen "{ ar_step_size == 0 }" range { 0 10 } } parm { name "label_volume" label "Label" type label nolabel default { "" } } parm { name "label_volume2" label "Label" type label nolabel default { "Points and polymeshes are rendered as volumes if Step Size > 0" } } } group { name "folder_points_3" label " VDB " parm { name "ar_vdb_file_enable" label "Export VDB File" type toggle nolabel joinnext default { "0" } help "Export the VDB primitives as a VDB file and reference the file in the Arnold volume." range { 0 1 } } parm { name "ar_vdb_file" label "Save to File" type file default { "$HIP/`pythonexprs(\\"hou.pwd().path()[1:].replace(\'/\', \'_\')\\")`.$F4.vdb" } help "The OpenVDB file name that the VDB primitves will be written to, and that will be referenced by the Arnold volume instead of attaching the volume data." disablewhen "{ ar_vdb_file_enable == 0 }" range { 0 1 } parmtag { "filechooser_pattern" "*.vdb" } } parm { name "ar_grids" label "Export Grids" type string default { "*" } help "The VDB grids to export and make available in the volume shading context." menutoggle { [ "import htoa.properties" ] [ "return htoa.properties.vdbGridMenu()" ] language python } range { 0 1 } parmtag { "script_callback" "__import__(\'htoa\').properties.vdbAutoStepSizeCallback()" } parmtag { "script_callback_language" "python" } } parm { name "ar_velocity_grids" label "Velocity Grids" type string default { "*" } help "Select 1 vector or 3 float grids representing velocity for motion blur." menutoggle { [ "import htoa.properties" ] [ "return htoa.properties.vdbGridMenu()" ] language python } range { 0 1 } } parm { name "ar_velocity_scale" label "Velocity Scale" type log default { "1" } help "Scale the velocities by this factor." disablewhen "{ ar_velocity_grids == \\"\\" }" range { 0.1 10 } } parm { name "ar_velocity_threshold" label "Velocity Threshold" type log default { "0.001" } help "Controls filtering of noisy velocities. The default value 0.001 should have little to no visual impact, setting it to zero disables filtering entirely." disablewhen "{ ar_velocity_grids == \\"\\" }" range { 0! 1! } } parm { name "ar_padding" label "Bounds Padding" type float default { "0" } help "Extra padding for the volume bounds" range { 0 10 } } parm { name "ar_step_size_type" label "Volume Step" type ordinal joinnext default { "0" } help "When set to auto, the step size is automatically determined by the volume plugin, yielding the minimum voxel size." menu { "auto" "Automatic " "custom" "Custom" } range { 0 1 } parmtag { "script_callback" "__import__(\'htoa\').properties.vdbAutoStepSizeCallback()" } parmtag { "script_callback_language" "python" } } parm { name "ar_vdb_step_size" label " Step Size" type float default { "0.02" } help "The ray marching step size. When the step type is auto, this indicates the computed step size, the minimum voxel size." disablewhen "{ ar_step_size_type == auto }" range { 0! 10 } } parm { name "ar_step_scale" label "Step Scale" type log default { "1" } help "Multiply the step size by this factor, including when it\'s automatically detected." range { 0.1! 10 } } parm { name "ar_compress" label "Compress" type toggle invisible default { "1" } help "Optimize voxel storage to reduce memory usage." range { 0 1 } } } group { name "folder_points_4" label "Tessellation" parm { name "ar_tessellation_enable" label "Tessellate Primitives" type toggle default { "1" } help "Tessellate Houdini primitives such as NURBS, Bezier meshes, circles, tubes or spheres prior to sending to Arnold." disablewhen "{ ar_tessellation_use_rop == 1 }" range { 0 1 } parmtag { "spare_category" "Tessellation" } } parm { name "ar_tessellation_style" label "Tessellation Style" type string invisible default { "lod" } help "Specifies the conversion style for the geometry. The default is\\"Level of Detail\\". Can be one of the following:\\\\n- Level of Detail: Tessellate geometry using the level of detail settings.\\\\n- Divisions: Tessellate geometry based on the number of divisions settings." disablewhen "{ ar_tessellation_enable == 0 }" menu { "lod" "Level of Detail" "div" "Divisions" } range { 0 1 } parmtag { "spare_category" "Tessellation" } } parm { name "ar_tessellation_ulod" label "U Level of Detail" type float default { "1" } help "Specifies the level of detail for U subdivisions of the surface being converted. Applicable only when conversion method is set to Level of Detail. Defaults to 1.0." disablewhen "{ ar_tessellation_enable == 0 }" hidewhen "{ ar_tessellation_style != lod }" range { 0! 10 } parmtag { "spare_category" "Tessellation" } } parm { name "ar_tessellation_vlod" label "V Level of Detail" type float default { "1" } help "Specifies the level of detail for V subdivisions of the surface being converted. Applicable only when conversion method is set to Level of Detail. Defaults to 1.0." disablewhen "{ ar_tessellation_enable == 0 }" hidewhen "{ ar_tessellation_style != lod }" range { 0! 10 } parmtag { "spare_category" "Tessellation" } } parm { name "ar_tessellation_trimlod" label "Trim Level of Detail" type float default { "1" } help "Specifies the level of detail for trim curves of the surface being converted. Applicable only when conversion method is set to Level of Detail. Defaults to 1.0." disablewhen "{ ar_tessellation_enable == 0 }" hidewhen "{ ar_tessellation_style != lod }" range { 0! 10 } parmtag { "spare_category" "Tessellation" } } } group { name "folder_points_5" label "Procedurals" parm { name "ar_operator_graph_enable" label "Enable Operator Graph" type toggle nolabel joinnext default { "1" } help "Enables the operator graph on procedurals in this OBJ node." range { 0 1 } } parm { name "ar_operator_graph" label "Operator Graph" type oppath default { "" } help "Specify an operator ROP graph to connect to procedurals created by this OBJ node." disablewhen "{ ar_operator_graph_enable == 0 }" parmtag { "opfilter" "!!ROP!!" } parmtag { "oprelative" "." } } } } group { name "folder_subdivision_3" label "Attributes" parm { name "ar_toon_id" label "Toon ID Group" type string default { "" } help "Objects in the same toon ID group will be rendered with the same silhouette, if the user_id attribute is set on the toon shader" } parm { name "ar_attributes_detail" label "Detail Attributes" type string default { "*" } help "The list of details attributes to be exported as user data for Arnold. As user data is costly in memory, nothing is exported by default. If this field contains a wildcard character (*), all available attributes will be exported." menutoggle { [ "__import__(\'htoa\').properties.detailAttributeMenu()" ] language python } range { 0 1 } parmtag { "spare_category" "Attributes" } } parm { name "ar_attributes_primitive" label "Primitive Attributes" type string default { "*" } help "The list of primitive attributes to be exported as user data for Arnold. As user data is costly in memory, nothing is exported by default. If this field contains a wildcard character (*), all available attributes will be exported." menutoggle { [ "__import__(\'htoa\').properties.primitiveAttributeMenu()" ] language python } range { 0 1 } parmtag { "spare_category" "Attributes" } } parm { name "ar_attributes_point" label "Point Attributes" type string default { "*" } help "The list of point attributes to be exported as user data for Arnold. As user data is costly in memory, nothing is exported by default. If this field contains a wildcard character (*), all available attributes will be exported." menutoggle { [ "__import__(\'htoa\').properties.pointAttributeMenu()" ] language python } range { 0 1 } parmtag { "spare_category" "Attributes" } } parm { name "ar_attributes_vertex" label "Vertex Attributes" type string default { "*" } help "The list of vertex attributes to be exported as user data for Arnold. As user data is costly in memory, nothing is exported by default. If this field contains a wildcard character (*), all available attributes will be exported." menutoggle { [ "__import__(\'htoa\').properties.vertexAttributeMenu()" ] language python } range { 0 1 } parmtag { "spare_category" "Attributes" } } } group { name "folder_subdivision_4" label "Motion Blur" parm { name "ar_transform_type" label "Transform Type" type ordinal default { "2" } help "The type of motion for the transformation of the object, as a hint for the matrix interpolation for transformation motion blur." menu { "linear" "Linear" "rotate_about_origin" "Rotate About Origin" "rotate_about_center" "Rotate About Center" } range { 0 2 } parmtag { "spare_category" "Motion Blur" } } parm { name "ar_mb_xform_keys_override" label "Transform Keys Override" type toggle nolabel joinnext default { "0" } help "Override the ROP settings for Transform Keys." range { 0 1 } parmtag { "spare_category" "Motion Blur" } } parm { name "ar_mb_xform_keys" label "Transform Keys" type integer default { "2" } help "Number of motion keys for matrix transformation. Transformation motion blur is calculated based on a linear interpolation of an object transform matrix, between successive motion keys. Increasing this value will add extra steps, which can improve the blurred result, especially for rotating objects. The default is 2, which results in straight lines of blur between shutter start and shutter end." disablewhen "{ ar_mb_xform_keys_override == 0 }" range { 1! 20 } parmtag { "spare_category" "Motion Blur" } } parm { name "ar_mb_dform_keys_override" label "Deform Keys Override" type toggle nolabel joinnext default { "0" } help "Override the ROP settings for Transform Keys." range { 0 1 } parmtag { "spare_category" "Motion Blur" } } parm { name "ar_mb_dform_keys" label "Deform Keys" type integer default { "2" } help "Number of motion keys for object points. Just like with transformation motion keys, increasing this value allows curved motion paths to be rendered more accurately, at the expense of using more memory." disablewhen "{ ar_mb_dform_keys_override == 0 } { ar_mb_velocity_enable == 1 ar_mb_acceleration_enable != 1 }" range { 1! 20 } parmtag { "spare_category" "Motion Blur" } } parm { name "ar_mb_velocity_enable" label "Velocity Blur Enable" type toggle nolabel joinnext default { "0" } help "Deformation blur will be computed from the \\"v\\" point attribute." range { 0 1 } parmtag { "spare_category" "Motion Blur" } } parm { name "ar_mb_velocity_attribute" label "Velocity Blur" type string default { "v" } help "The velocity point attribute to use for velocity blur. The Houdini convention is \'v\'." disablewhen "{ ar_mb_velocity_enable == 0 }" menureplace { [ "geometry = hou.pwd().renderNode().geometry()" ] [ "if not geometry:" ] [ " return []" ] [ "menu_items = []" ] [ "for attr in geometry.pointAttribs():" ] [ " if not attr.name() in (\'P\', \'Pw\'):" ] [ " menu_items += [attr.name(), \'%s\\\\t %s[%i]\' % (attr.name(), attr.dataType().name().lower(), attr.size())]" ] [ "return menu_items" ] language python } range { 0 1 } } parm { name "ar_mb_acceleration_enable" label "Acceleration Blur Enable" type toggle nolabel joinnext default { "0" } disablewhen "{ ar_mb_velocity_enable == 0 }" range { 0 1 } } parm { name "ar_mb_acceleration_attribute" label "Acceleration Blur" type string default { "force" } help "The acceleration point attribute to use for acceleration blur. The Houdini convention is \'force\' or \'accel\'. If you use use \'force\' ensure you divide by the mass." disablewhen "{ ar_mb_velocity_enable == 0 } { ar_mb_acceleration_enable == 0 }" menureplace { [ "geometry = hou.pwd().renderNode().geometry()" ] [ "if not geometry:" ] [ " return []" ] [ "menu_items = []" ] [ "for attr in geometry.pointAttribs():" ] [ " if not attr.name() in (\'P\', \'Pw\'):" ] [ " menu_items += [attr.name(), \'%s\\\\t %s[%i]\' % (attr.name(), attr.dataType().name().lower(), attr.size())]" ] [ "return menu_items" ] language python } range { 0 1 } } } group { name "folder_subdivision_5" label "Visibility" parm { name "ar_visibility_camera" label "Visible to Camera Rays" type toggle default { "1" } help "Toggle object visibility for camera rays (i.e. primary or view rays)." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_visibility_shadow" label "Visible to Shadow Rays" type toggle default { "1" } help "Toggle object visibility for shadow rays fired in the direct lighting calculations." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_visibility_diffuse_transmit" label "Visible to Diffuse Transmission Rays" type toggle default { "1" } help "Toggle object visibility for indirect diffuse transmission rays." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_visibility_specular_transmit" label "Visible to Specular Transmission Rays" type toggle default { "1" } help "Toggle object visibility for indirect specular transmission rays." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_visibility_diffuse_reflect" label "Visible to Diffuse Reflection Rays" type toggle default { "1" } help "Toggle object visibility for indirect diffuse reflection rays." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_visibility_specular_reflect" label "Visible to Specular Reflection Rays" type toggle default { "1" } help "Toggle object visibility for indirect specular reflection rays." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_visibility_volume" label "Visible to Volume Scattering Rays" type toggle default { "1" } help "Toggle object visibility for indirect volume scattering rays." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_receive_shadows" label "Receive Shadows" type toggle default { "1" } help "Enable/disable received shadows over the object." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_self_shadows" label "Self Shadows" type toggle default { "1" } help "Enable/disable self-shadowing over the object." disablewhen "{ ar_receive_shadows == 0 }" range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_opaque" label "Opaque" type toggle default { "1" } help "By default, Arnold will assume that objects are opaque, which lets the renderer take certain shortcuts and optimizations for maximum ray tracing speed. When this option is unchecked, the object is assumed as \\"possibly transparent\\", and Arnold will perform extra computations to support transparency and transparent shadows, according to the shader\'s opacity settings." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_matte" label "Matte" type toggle default { "0" } help "Output black and zero alpha for camera rays to create a holdout." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_skip" label "Skip" type toggle default { "0" } help "Do not output this object regardless of it being forced or not." range { 0 1 } parmtag { "spare_category" "Visibility" } } parm { name "ar_use_light_group" label "Use Light Group" type toggle invisible nolabel joinnext default { "0" } range { 0 1 } } parm { name "ar_light_group" label "Light Group" type oplist invisible default { "" } disablewhen "{ ar_use_light_group == 0 }" range { 0 1 } parmtag { "opfilter" "!!OBJ/LIGHT!!" } parmtag { "oprelative" "/" } } parm { name "ar_use_shadow_group" label "Use Shadow Group" type toggle invisible nolabel joinnext default { "0" } range { 0 1 } } parm { name "ar_shadow_group" label "Shadow Group" type oplist invisible default { "" } disablewhen "{ ar_use_shadow_group == 0 }" range { 0 1 } parmtag { "opfilter" "!!OBJ/LIGHT!!" } parmtag { "oprelative" "/" } } parm { name "ar_trace_sets" label "Trace Sets" type string default { "" } menutoggle { [ "__import__(\'htoa.properties\').properties.tracesetMenu()" ] language python } range { 0 1 } } parm { name "ar_sss_setname" label "SSS Set" type string default { "" } help "Use this parameter to tag multiple objects as belonging to the same SSS set so that illumination will blur across object boundaries. A common use case might be blurring between teeth and gum geometry. This feature is only available when using raytraced SSS." menureplace { [ "__import__(\'htoa.properties\').properties.sssMenu()" ] language python } range { 0 1 } } } group { name "folder_subdivision_6" label "Normals" parm { name "ar_smoothing" label "Smoothing" type toggle default { "1" } help "Smooth/Flat normals." range { 0 1 } parmtag { "spare_category" "Render" } } parm { name "ar_invert_normals" label "Invert Normals" type toggle default { "0" } help "Invert normals" range { 0 1 } parmtag { "spare_category" "Render" } } parm { name "ar_sidedness_camera" label "Double-sided for Camera Rays" type toggle default { "1" } help "Toggle object double-sidedness for camera rays (i.e. primary or view rays)." range { 0 1 } parmtag { "spare_category" "Sidedness" } } parm { name "ar_sidedness_shadow" label "Double-sided for Shadow Rays" type toggle default { "1" } help "Toggle object double-sidedness for shadow rays fired in the direct lighting calculations." range { 0 1 } parmtag { "spare_category" "Sidedness" } } parm { name "ar_sidedness_diffuse_transmit" label "Double-sided for Diffuse Transmission Rays" type toggle default { "1" } help "Toggle object double-sidedness for indirect diffuse transmission rays." range { 0 1 } parmtag { "spare_category" "Sidedness" } } parm { name "ar_sidedness_specular_transmit" label "Double-sided for Specular Transmission Rays" type toggle default { "1" } help "Toggle object double-sidedness for indirect specular transmission rays." range { 0 1 } parmtag { "spare_category" "Sidedness" } } parm { name "ar_sidedness_diffuse_reflect" label "Double-sided for Diffuse Reflection Rays" type toggle default { "1" } help "Toggle object double-sidedness for indirect diffuse reflection rays." range { 0 1 } parmtag { "spare_category" "Sidedness" } } parm { name "ar_sidedness_specular_reflect" label "Double-sided for Specular Reflection Rays" type toggle default { "1" } help "Toggle object double-sidedness for indirect specular reflection rays." range { 0 1 } parmtag { "spare_category" "Sidedness" } } parm { name "ar_sidedness_volume" label "Double-sided for Volume Scattering Rays" type toggle default { "1" } help "Toggle object double-sidedness for indirect volume scattering rays." range { 0 1 } parmtag { "spare_category" "Sidedness" } } } } group { name "stdswitcher4_3" label "Misc" parm { name "use_dcolor" baseparm label "Set Wireframe Color" export none } parm { name "dcolor" baseparm label "Wireframe Color" export none } parm { name "picking" baseparm label "Viewport Selecting Enabled" export none } parm { name "pickscript" baseparm label "Select Script" export none } parm { name "caching" baseparm label "Cache Object Transform" export none } parm { name "vport_shadeopen" baseparm label "Shade Open Curves In Viewport" export none } parm { name "vport_displayassubdiv" baseparm label "Display as Subdivision in Viewport" invisible export none } parm { name "vport_onionskin" baseparm label "Onion Skinning" export none } } ' $_obj_tube1
chblockbegin
chadd -t 0 0 $_obj_tube1 ar_point_scale
chkey -t 0 -v 0 -V 0 -m 0 -M 0 -a 0 -A 0 -F 'ch("vm_pointscale")' $_obj_tube1/ar_point_scale
chadd -t 0 0 $_obj_tube1 ar_mb_velocity_enable
chkey -t 0 -v 0 -V 0 -m 0 -M 0 -a 0 -A 0 -F 'ch("geo_velocityblur")' $_obj_tube1/ar_mb_velocity_enable
chadd -t 0 0 $_obj_tube1 ar_matte
chkey -t 0 -v 0 -V 0 -m 0 -M 0 -a 0 -A 0 -F 'ch("vm_matte")' $_obj_tube1/ar_matte
chblockend
opset -S on $_obj_tube1
chautoscope $_obj_tube1 +tx +ty +tz +rx +ry +rz +sx +sy +sz
opset -d on -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off -x off $_obj_tube1
opexprlanguage -s hscript $_obj_tube1
opcf $_obj_tube1
# Node $_obj_tube1_axiom_solver1 (Sop/axiom_solver::3.0)
set _obj_tube1_axiom_solver1 = `run("opadd -e -n -v axiom_solver::3.0 axiom_solver1")`
oplocate -x `$arg2 + 1.2023529411764704` -y `$arg3 + -6.0341176410983577` $_obj_tube1_axiom_solver1
opparm $_obj_tube1_axiom_solver1 dissipationRamp ( 2 ) coolingRateRamp ( 2 ) windRamp ( 2 ) dragRamp ( 2 ) disturbance1Ramp ( 2 ) disturbance2Ramp ( 2 ) disturbance3Ramp ( 2 ) turbulence1Ramp ( 2 ) turbulence2Ramp ( 2 ) turbulence3Ramp ( 2 ) confinementRamp ( 2 ) ignitionTemperatureRamp ( 2 ) colorRamp ( 3 )
chblockbegin
chadd -t 41.708375041708379 41.708375041708379 $_obj_tube1_axiom_solver1 disturbance1BlockSize
chkey -t 41.708375041708379 -v 0 -m 0 -a 0 -A 0 -T a -F 'ch("divisionSize")*2' $_obj_tube1_axiom_solver1/disturbance1BlockSize
chadd -t 41.708375041708379 41.708375041708379 $_obj_tube1_axiom_solver1 disturbance2BlockSize
chkey -t 41.708375041708379 -v 0 -m 0 -a 0 -A 0 -T a -F 'ch("divisionSize")*4' $_obj_tube1_axiom_solver1/disturbance2BlockSize
chadd -t 41.708375041708379 41.708375041708379 $_obj_tube1_axiom_solver1 disturbance3BlockSize
chkey -t 41.708375041708379 -v 0 -m 0 -a 0 -A 0 -T a -F 'ch("divisionSize")*8' $_obj_tube1_axiom_solver1/disturbance3BlockSize
chadd -t 41.708375041708379 41.708375041708379 $_obj_tube1_axiom_solver1 hardwareID
chkey -t 41.708375041708379 -v 0 -m 0 -a 0 -A 0 -T a -F 'node = hou.pwd().type().name()\n\nversion = node.split(\'::\')[1]\n\ncommand = "AXIOM_licenseHardwareID"\ncommand += "_"\ncommand += version.replace(\'.\', "_")\n\nval = hou.hscript(command)[0]\n\nreturn val' -l p $_obj_tube1_axiom_solver1/hardwareID
chblockend
opparm $_obj_tube1_axiom_solver1 folder0 ( 1 1 1 1 1 1 1 ) substeps ( 5 ) divisionSize ( 0.01 ) computeAPI ( 2 ) device ( 'NVIDIA RTX A4000 (0) Must be nice.' ) memory ( '2.37 GB (Device)' ) activeMemory ( '348.5 MB 14%' ) activeVoxels ( 4,702,208 ) description ( 'NVIDIA RTX A4000 (0)' ) sourceDensity ( 20 ) sourcePressure ( 100 ) timeScale ( 1.5 ) densityDissipation ( 0.01 ) enableCoolingRate ( off ) enableTemperatureDiffusion ( off ) enableDisturbance1 ( on ) disturbance1 ( 0.14999999999999999 ) turbulence1 ( 0.050000000000000003 ) dissipationSettings ( 7 7 7 7 7 7 7 7 7 7 7 7 7 7 ) disturbance1ControlField ( 4 ) disturbance1InputRange ( 0 0.20000000000000001 ) outputTemperature ( off ) outputVelocity ( off ) licenses ( 'key_value_dict:{"ASXXXXXXXXXXXXXX":"axiom_commercial_floating"}' ) dissipationRamp1value ( 1 ) dissipationRamp2pos ( 1 ) dissipationRamp2value ( 0.25 ) coolingRateRamp2pos ( 1 ) coolingRateRamp2value ( 1 ) windRamp2pos ( 1 ) windRamp2value ( 1 ) dragRamp2pos ( 1 ) dragRamp2value ( 1 ) disturbance1Ramp1pos ( 0.1202404797077179 ) disturbance1Ramp2pos ( 1 ) disturbance1Ramp2value ( 1 ) disturbance2Ramp2pos ( 1 ) disturbance2Ramp2value ( 1 ) disturbance3Ramp2pos ( 1 ) disturbance3Ramp2value ( 1 ) turbulence1Ramp2pos ( 1 ) turbulence1Ramp2value ( 1 ) turbulence2Ramp2pos ( 1 ) turbulence2Ramp2value ( 1 ) turbulence3Ramp2pos ( 1 ) turbulence3Ramp2value ( 1 ) confinementRamp2pos ( 1 ) confinementRamp2value ( 1 ) ignitionTemperatureRamp2pos ( 1 ) ignitionTemperatureRamp2value ( 1 ) colorRamp1c ( 0.29588711261749268 0.36125144362449646 0.5 ) colorRamp2pos ( 0.24265842139720917 ) colorRamp2c ( 0.047032315284013748 0.10041522234678268 0.44179984927177429 ) colorRamp3pos ( 1 ) colorRamp3c ( 0 0.5 0.2703932523727417 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_axiom_solver1
opexprlanguage -s hscript $_obj_tube1_axiom_solver1
opuserdata -n '___Version___' -v '' $_obj_tube1_axiom_solver1
opuserdata -n '___toolcount___' -v '2' $_obj_tube1_axiom_solver1
opuserdata -n '___toolid___' -v 'axiom_sourceVDBs_v02_b002' $_obj_tube1_axiom_solver1
# Node $_obj_tube1_axiom_volumeVisualize1 (Sop/axiom_volumeVisualize::3.0)
set _obj_tube1_axiom_volumeVisualize1 = `run("opadd -e -n -v axiom_volumeVisualize::3.0 axiom_volumeVisualize1")`
oplocate -x `$arg2 + 3.2585181061339443` -y `$arg3 + -8.2077518580918252` $_obj_tube1_axiom_volumeVisualize1
opparm $_obj_tube1_axiom_volumeVisualize1 color ( 2 )
opparm $_obj_tube1_axiom_volumeVisualize1 color2pos ( 1 ) color2c ( 1 1 1 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_axiom_volumeVisualize1
opexprlanguage -s hscript $_obj_tube1_axiom_volumeVisualize1
opuserdata -n '___Version___' -v '' $_obj_tube1_axiom_volumeVisualize1
opcf ..
opcf $_obj_tube1
# Node $_obj_tube1_tube1 (Sop/tube)
set _obj_tube1_tube1 = `run("opadd -e -n -v tube tube1")`
oplocate -x `$arg2 + 0` -y `$arg3 + 1.7884` $_obj_tube1_tube1
opparm -V 19.0.589 $_obj_tube1_tube1 type ( poly ) rad ( 0.080000000000000002 0.14999999999999999 ) height ( 0.25 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_tube1
opexprlanguage -s hscript $_obj_tube1_tube1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_tube1
# Node $_obj_tube1_polyfill1 (Sop/polyfill)
set _obj_tube1_polyfill1 = `run("opadd -e -n -v polyfill polyfill1")`
oplocate -x `$arg2 + 5.5511151231257827e-17` -y `$arg3 + 0.78839998807907108` $_obj_tube1_polyfill1
opparm -V 19.0.589 $_obj_tube1_polyfill1 fillmode ( none )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_polyfill1
opexprlanguage -s hscript $_obj_tube1_polyfill1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_polyfill1
# Node $_obj_tube1_transform1 (Sop/xform)
set _obj_tube1_transform1 = `run("opadd -e -n -v xform transform1")`
oplocate -x `$arg2 + 5.5511151231257827e-17` -y `$arg3 + -0.21160002384185772` $_obj_tube1_transform1
opparm -V 19.0.589 $_obj_tube1_transform1 t ( 0 1.1888542324304581 0 ) r ( 0 0 -90 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_transform1
opexprlanguage -s hscript $_obj_tube1_transform1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_transform1
# Node $_obj_tube1_blast1 (Sop/blast)
set _obj_tube1_blast1 = `run("opadd -e -n -v blast blast1")`
oplocate -x `$arg2 + 0` -y `$arg3 + -1.1058000238418577` $_obj_tube1_blast1
opparm -V 19.0.589 $_obj_tube1_blast1 group ( 13 ) grouptype ( prims ) removegrp ( on )
opset -d off -r off -h on -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_blast1
opexprlanguage -s hscript $_obj_tube1_blast1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_blast1
opuserdata -n '___toolcount___' -v '1' $_obj_tube1_blast1
opuserdata -n '___toolid___' -v 'generic_delete' $_obj_tube1_blast1
# Node $_obj_tube1_polyextrude1 (Sop/polyextrude::2.0)
set _obj_tube1_polyextrude1 = `run("opadd -e -n -v polyextrude::2.0 polyextrude1")`
oplocate -x `$arg2 + 5.377642775528102e-17` -y `$arg3 + -2.3822704117647056` $_obj_tube1_polyextrude1
opparm $_obj_tube1_polyextrude1 thicknessramp ( 2 ) twistramp ( 2 )
opparm -V 19.0.589 $_obj_tube1_polyextrude1 dist ( 0.085018754005432129 ) outputback ( on ) thicknessramp1value ( 1 ) thicknessramp1interp ( catmull-rom ) thicknessramp2pos ( 1 ) thicknessramp2value ( 1 ) thicknessramp2interp ( catmull-rom ) twistramp1value ( 0.5 ) twistramp1interp ( catmull-rom ) twistramp2pos ( 1 ) twistramp2value ( 0.5 ) twistramp2interp ( catmull-rom )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_polyextrude1
opexprlanguage -s hscript $_obj_tube1_polyextrude1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_polyextrude1
# Node $_obj_tube1_axiom_sourceShape1 (Sop/axiom_sourceShape::3.0)
set _obj_tube1_axiom_sourceShape1 = `run("opadd -e -n -v axiom_sourceShape::3.0 axiom_sourceShape1")`
oplocate -x `$arg2 + 3.8760975058823544` -y `$arg3 + -2.9771550999218883` $_obj_tube1_axiom_sourceShape1
opparm $_obj_tube1_axiom_sourceShape1 main ( 1 ) cameraFolder ( 1 ) sourcing ( 1 ) temperature ( -0.40000000000000002 ) pressure ( 1 ) folder0 ( 1 ) noise ( 3 3 3 3 ) useNoise ( on ) noiseStrength ( 0.5 ) noiseFeatureSize ( 0.10000000000000001 ) noiseSpeed ( 10 ) noiseGain ( 10 ) useVelocityNoise ( on ) velocityNoiseStrength ( 0.25 ) velocityNoiseFeatureSize ( 0.10000000000000001 ) velocityNoiseSpeed ( 3 ) forceType ( 1 ) forceMagnitude ( 100 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_axiom_sourceShape1
opexprlanguage -s hscript $_obj_tube1_axiom_sourceShape1
opuserdata -n '___Version___' -v '' $_obj_tube1_axiom_sourceShape1
# Node $_obj_tube1_vdbfrompolygons1 (Sop/vdbfrompolygons)
set _obj_tube1_vdbfrompolygons1 = `run("opadd -e -n -v vdbfrompolygons vdbfrompolygons1")`
oplocate -x `$arg2 + 0.021979999999999989` -y `$arg3 + -4.2764704236856348` $_obj_tube1_vdbfrompolygons1
opparm $_obj_tube1_vdbfrompolygons1 numattrib ( 0 )
opparm -V 19.0.589 $_obj_tube1_vdbfrompolygons1 voxelsize ( 0.01 ) distancename ( collision )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_vdbfrompolygons1
opexprlanguage -s hscript $_obj_tube1_vdbfrompolygons1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_vdbfrompolygons1
# Node $_obj_tube1_sphere1 (Sop/sphere)
set _obj_tube1_sphere1 = `run("opadd -e -n -v sphere sphere1")`
oplocate -x `$arg2 + 3.8760975058823544` -y `$arg3 + -1.4704256881571838` $_obj_tube1_sphere1
opparm -V 19.0.589 $_obj_tube1_sphere1 type ( polymesh ) rad ( 0.70154660567641258 0.5 0.5 ) t ( 0.0072662718594074249 1.1954050958156586 0 ) scale ( 0.20000000000000001 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_sphere1
opexprlanguage -s hscript $_obj_tube1_sphere1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_sphere1
# Node $_obj_tube1_axiom_sourceShape2 (Sop/axiom_sourceShape::3.0)
set _obj_tube1_axiom_sourceShape2 = `run("opadd -e -n -v axiom_sourceShape::3.0 axiom_sourceShape2")`
oplocate -x `$arg2 + 7.7326622117647084` -y `$arg3 + -2.9771550999218883` $_obj_tube1_axiom_sourceShape2
opparm $_obj_tube1_axiom_sourceShape2 main ( 1 ) type ( 2 ) shape ( 2 ) cameraFolder ( 1 ) sourcing ( 1 ) temperature ( -1 ) pressure ( 1 ) folder0 ( 1 ) t ( 0 -1 0 ) s ( 10 1 10 ) noise ( 3 3 3 3 ) forceType ( 1 ) forceMagnitude ( 50 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_axiom_sourceShape2
opexprlanguage -s hscript $_obj_tube1_axiom_sourceShape2
opuserdata -n '___Version___' -v '' $_obj_tube1_axiom_sourceShape2
# Node $_obj_tube1_merge1 (Sop/merge)
set _obj_tube1_merge1 = `run("opadd -e -n -v merge merge1")`
oplocate -x `$arg2 + 3.2573680941176479` -y `$arg3 + -3.9984550998742043` $_obj_tube1_merge1
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_merge1
opexprlanguage -s hscript $_obj_tube1_merge1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_merge1
# Node $_obj_tube1_volumevisualization1 (Sop/volumevisualization)
set _obj_tube1_volumevisualization1 = `run("opadd -e -n -v volumevisualization volumevisualization1")`
oplocate -x `$arg2 + 1.1580090000000001` -y `$arg3 + -7.1160699999999997` $_obj_tube1_volumevisualization1
opparm $_obj_tube1_volumevisualization1 densityramp ( 2 ) cdramp ( 2 ) emitramp ( 2 ) emitcdramp ( 2 )
opparm -V 19.0.589 $_obj_tube1_volumevisualization1 densityscale ( 5.6900000000000004 ) shadowscale ( 0.84999999999999998 ) densityramp2pos ( 1 ) densityramp2value ( 1 ) cdramp2pos ( 1 ) cdramp2c ( 1 1 1 ) emitramp2pos ( 1 ) emitramp2value ( 1 ) emitcdramp2pos ( 1 ) emitcdramp2c ( 1 0.32500000000000001 0.10000000000000001 )
opset -d on -r on -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_volumevisualization1
opexprlanguage -s hscript $_obj_tube1_volumevisualization1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_volumevisualization1
# Node $_obj_tube1_grid1 (Sop/grid)
set _obj_tube1_grid1 = `run("opadd -e -n -v grid grid1")`
oplocate -x `$arg2 + 7.6039884339869239` -y `$arg3 + -4.6029636227977075` $_obj_tube1_grid1
opparm -V 19.0.589 $_obj_tube1_grid1 size ( 30 30 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_grid1
opexprlanguage -s hscript $_obj_tube1_grid1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_grid1
# Node $_obj_tube1_color1 (Sop/color)
set _obj_tube1_color1 = `run("opadd -e -n -v color color1")`
oplocate -x `$arg2 + 7.434577` -y `$arg3 + -5.6029636347186367` $_obj_tube1_color1
opparm $_obj_tube1_color1 ramp ( 2 )
opparm $_obj_tube1_color1 color ( 0.13099999725818634 0.13099999725818634 0.13099999725818634 ) ramp2pos ( 1 ) ramp2c ( 1 1 1 )
opset -d off -r off -h off -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_color1
opexprlanguage -s hscript $_obj_tube1_color1
opuserdata -n '___Version___' -v '' $_obj_tube1_color1
opuserdata -n '___toolcount___' -v '2' $_obj_tube1_color1
opuserdata -n '___toolid___' -v 'sop_color' $_obj_tube1_color1
# Node $_obj_tube1_color2 (Sop/color)
set _obj_tube1_color2 = `run("opadd -e -n -v color color2")`
oplocate -x `$arg2 + -3.1197759999999999` -y `$arg3 + -2.1295519999999999` $_obj_tube1_color2
opparm $_obj_tube1_color2 ramp ( 2 )
opparm $_obj_tube1_color2 color ( 0.2370000034570694 0.2370000034570694 0.2370000034570694 ) ramp2pos ( 1 ) ramp2c ( 1 1 1 )
opset -d off -r off -h off -f on -y off -t on -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_color2
opexprlanguage -s hscript $_obj_tube1_color2
opuserdata -n '___Version___' -v '' $_obj_tube1_color2
opuserdata -n '___toolcount___' -v '2' $_obj_tube1_color2
opuserdata -n '___toolid___' -v 'sop_color' $_obj_tube1_color2
# Node $_obj_tube1_edit1 (Sop/edit)
set _obj_tube1_edit1 = `run("opadd -e -n -v edit edit1")`
oplocate -x `$arg2 + 0` -y `$arg3 + -3.2764704117647057` $_obj_tube1_edit1
opparm -V 19.0.589 $_obj_tube1_edit1 group ( '26-27 29 31 33 35 37 39 41 43 45 47' ) grouptype ( points ) s ( 0.76145815465433941 0.76145815465433941 0.76145815465433941 ) p ( -0.10132560133934021 1.1888542175292969 0 ) leadislandhint ( 43 )
opset -d off -r off -h on -f off -y off -t off -l off -s off -u off -F on -c on -e on -b off $_obj_tube1_edit1
opexprlanguage -s hscript $_obj_tube1_edit1
opuserdata -n '___Version___' -v '19.0.589' $_obj_tube1_edit1
oporder -e tube1 polyfill1 transform1 blast1 polyextrude1 axiom_solver1 axiom_sourceShape1 vdbfrompolygons1 sphere1 axiom_sourceShape2 merge1 volumevisualization1 grid1 color1 color2 axiom_volumeVisualize1 edit1
opcf ..
opset -p on $_obj_tube1
opcf $arg1
opcf $_obj_tube1
opwire -n $_obj_tube1_tube1 -0 $_obj_tube1_polyfill1
opwire -n $_obj_tube1_polyfill1 -0 $_obj_tube1_transform1
opwire -n $_obj_tube1_transform1 -0 $_obj_tube1_blast1
opwire -n $_obj_tube1_blast1 -0 $_obj_tube1_polyextrude1
opwire -n $_obj_tube1_vdbfrompolygons1 -0 $_obj_tube1_axiom_solver1
opwire -n $_obj_tube1_merge1 -1 $_obj_tube1_axiom_solver1
opwire -n $_obj_tube1_sphere1 -0 $_obj_tube1_axiom_sourceShape1
opwire -n $_obj_tube1_edit1 -0 $_obj_tube1_vdbfrompolygons1
opwire -n $_obj_tube1_axiom_sourceShape1 -0 $_obj_tube1_merge1
opwire -n $_obj_tube1_axiom_sourceShape2 -1 $_obj_tube1_merge1
opwire -n $_obj_tube1_axiom_solver1 -0 $_obj_tube1_volumevisualization1
opwire -n $_obj_tube1_grid1 -0 $_obj_tube1_color1
opwire -n $_obj_tube1_blast1 -0 $_obj_tube1_color2
opwire -n $_obj_tube1_axiom_solver1 -0 $_obj_tube1_axiom_volumeVisualize1
opwire -n $_obj_tube1_polyextrude1 -0 $_obj_tube1_edit1
opcf ..
set oidx = 0
if ($argc >= 9 && "$arg9" != "") then
set oidx = $arg9
endif
if ($argc >= 5 && "$arg4" != "") then
set output = $_obj_tube1
opwire -n $output -$arg5 $arg4
endif
if ($argc >= 6 && "$arg6" != "") then
set input = $_obj_tube1
if ($arg8) then
opwire -n -i $arg6 -0 $input
else
opwire -n -o $oidx $arg6 -0 $input
endif
endif
opcf $saved_path
'''
hou.hscript(h_preamble + h_extra_args + h_cmd)