VRAD: Difference between revisions
|  (Added reference to thread limit article) | Dr. Orange (talk | contribs)  m (Changed non-wiki link to wiki link.) | ||
| Line 76: | Line 76: | ||
| :Run as a low-priority process. | :Run as a low-priority process. | ||
| ;<code>-threads <[[int]]></code> | ;<code>-threads <[[int]]></code> | ||
| :Override the number of CPU threads used. Maximum is 16 threads. With a [ | :Override the number of CPU threads used. Maximum is 16 threads. With a [[Increased_Thread_Limit_for_Compile_Tools|patched vrad_dll]] you can use 32 threads.   | ||
| ;<code>-mpi</code> | ;<code>-mpi</code> | ||
| :Use [[Vmpi|VMPI]] to distribute computations. | :Use [[Vmpi|VMPI]] to distribute computations. | ||
Revision as of 12:05, 2 April 2017
VRAD is the command-line tool that takes a compiled BSP map and embeds lighting data into it. VRAD's static and pre-compiled light is bounced around the world with a radiosity algorithm.
VRAD will:
- Generate lightmaps
- Generate ambient samples
- Generate per-object or per-vertex prop_static and detail prop lighting
VRAD is generally the slowest of the three compilers due to the many, many calculations it must perform. Lighting optimization can help, as can ensuring your map is free of leaks.
 Tip:If you are watching the compile dialog and it looks like it has hung at
Tip:If you are watching the compile dialog and it looks like it has hung at 9... this is usually because VRAD takes longer with each light bounce calculation. Bug:Ep1 and L4D users seeing crashes when VRAD compiles HDR lighting should read VRAD HDR Crash Fix.  [todo tested in ?]
Bug:Ep1 and L4D users seeing crashes when VRAD compiles HDR lighting should read VRAD HDR Crash Fix.  [todo tested in ?] Warning:VRAD will take up a lot of CPU during conversion of trying to make light
Warning:VRAD will take up a lot of CPU during conversion of trying to make lightSyntax
vrad [options...] <bsp file>
For example:
"%sourcesdk%\bin\orangebox\bin\vrad" -both -StaticPropLighting sdk_trainstation_01
This will generate and embed both standard and High Dynamic Range lighting data, at per-vertex detail for prop_static entities.
 Bug:To find resources in GCF files, VRAD must be started in
Bug:To find resources in GCF files, VRAD must be started in %sourcesdk%\bin\orangebox\ (or ep1 as the case may be). You can do this with the cd command, or by setting the "Start In" value of a Windows shortcut. In Batch Compiler, set the BinRoot variable.  [todo tested in ?]Options
Use these in combination with expert compile mode or a batch file.
Effects
- -ldr
- -hdr
- -both
- Whether to compile standard or High Dynamic Range lighting, or both.
- -fast
- Quick and dirty lighting. Don't ship with this.
- -final
- Increases the quality of light_environment and indirect lighting by spending more time firing rays.
- -extrasky <int>
- Trace N times as many rays for indirect light and sky ambient. (-final is equivalent to -extrasky 16; normal is equivalent to -extrasky 1)
- -lights <filename>.rad
- Load a custom lights file in addition to lights.radand map-specific lights file.
- -bounce <int>
- Set the maximum number of light ray bounces (default: 100).
- -smooth <int>
- Set the threshold for smoothing groups, in degrees (default: 45).
- -luxeldensity <normal>
- Scale down all luxels. Default (and maximum) value is 1.
- -softsun <float>
- Treat the sun as an area light source of this many degrees. Produces soft shadows. Recommended values are 0-5, default is 0.
- -StaticPropLighting
- Generate per-vertex prop_static lighting; always enabled for light_spot entities. Disables info_lighting entities on props WITHOUT normal maps. Does not work on props with Phong Enabled.
 Note:In
Note:In  , in order to get proper lighting on your static props, you will need to run VRAD with this command.
, in order to get proper lighting on your static props, you will need to run VRAD with this command.- Template:EP2 add
- Perform shadow tests of prop_statics at polygon precision. Default is to use collision meshes.
 Note:When using this command in Source 2013, static props that don't have
Note:When using this command in Source 2013, static props that don't have .dx80.vtx files won't be compiled with lightmapped shadows.- Template:EP2 add
- Generates lightmap shadows from $translucent surfaces of models (NOT brushes) that are specified in a lights file and being used with prop_static. Usually requires -StaticPropPolysto have any effect.
 Note:A surface will need a low lightmap scale for most texture shadows to be recognisable. Note:A surface will need a low lightmap scale for most texture shadows to be recognisable.
Performance
- -low
- Run as a low-priority process.
- -threads <int>
- Override the number of CPU threads used. Maximum is 16 threads. With a patched vrad_dll you can use 32 threads.
- -mpi
- Use VMPI to distribute computations.
- -mpi_pw <string>
- Use a password to choose a specific set of VMPI workers.
- -noextra
- Disable supersampling.
- -chop <int>
- Smallest number of luxel widths for a bounce patch, used on edges.
- -maxchop <int>
- Coarsest allowed number of luxel widths for a patch, used in face interiors.
- -LargeDispSampleRadius
- This can be used if there are splotches of bounced light on terrain. The compile will take longer, but it will gather light across a wider area.
- -compressconstant <int>
- Compress lightmaps whose color variation is less than this many units.
- Template:CSGO add
- Regulates the generated per-vertex prop_static lighting.
- slow: 16 (high quality); default: 4 (normal); fast: 0.25 (low quality)
 Note:-final is the equivalent of having -StaticPropLightingScale 16. Note:-final is the equivalent of having -StaticPropLightingScale 16.
Debugging
- -rederrors
- Emit red light when "a luxel has no samples".
- -vproject <directory>
- -game <directory>
- Override the VPROJECT environment variable.
- -v
- -verbose
- Turn on verbose output.
- -novconfig
- Don't bring up graphical UI on vproject errors.
- -dump
- Dump patches to debug files.
- -dumpnormals
- Write normals to debug .txt files.
- -debugextra
- Places debugging data in lightmaps to visualize supersampling.
- -dlightmap
- Force direct lighting into different lightmap than radiosity.
- -stoponexit
- Wait for a keypress on exit.
- -nodetaillight
- Don't light detail props.
- -centersamples
- Move sample centers.
- -loghash
- Log the sample hash table to samplehash.txt.
- -onlydetail
- Only light detail props and per-leaf lighting.
- -maxdispsamplesize #
- Set max displacement sample size (default: 512).
- -FullMinidump
- Write large minidumps on crash.
- -OnlyStaticProps
- Only perform direct static prop lighting.
- -StaticPropNormals
- When lighting static props, just show their normal vector.
- -noskyboxrecurse
- Turn off recursion into 3d skybox (skybox shadows on world).
- -nossprops
- Globally disable self-shadowing on static props.
Lights files
A light file is a plain text file that can be used to manipulate the way VRAD handles given materials when compiling static lighting. All lights files must have the .rad file extension and must be in the same folder as your gameinfo.txt.
There are:
- lights.rad, the global file.
- An auto-loaded map light file, using the format <map name>.rad. The file must be placed in the same folder as<map name>.vmf.
- Any number of additional lights files that can be added with the -lightsparameter.
Rules
Lights files perform these functions, one rule per line:
- <material> <red> <green> <blue> <intensity> <hdr_red> <hdr_green> <hdr_blue> <hdr_intensity>
- Makes the material emit the given light value when applied to a brush face (hdr_values are optional). Texture scale has an effect on final intensity. Note:materials that aren't in a folder must have a slash before their name. Note:materials that aren't in a folder must have a slash before their name.
- noshadow <material name>
- Prevents the named material from casting shadows.
- forcetextureshadow <model path>.mdl
- Enables translucency shadow testing for a model when VRAD is run with -TextureShadows. Path is relative to the models folder.
- ldr:
- hdr:
- Prefixes to make any rule only apply to LDR or HDR lighting.
- hdr:ldr:
- Lines beginning with both tags (in that order) will always be ignored by VRAD. Can be used to add comments or quickly disable some entries.
See also
| 
 | |||||||||||||||||||||||||||||












