Transfer Functions
You can change a visualization’s appearance by accessing and modifying its transfer function.
import example_utils
from vapor import session, renderer, dataset, camera, transferfunction
from vapor.utils import histogram
ses = session.Session()
data = example_utils.OpenExampleDataset(ses)
ren = data.NewRenderer(renderer.VolumeRenderer)
ses.GetCamera().LookAt((32, 120, 120), (32, 32, 32))
ses.Show()
Warning: sysroot "/Applications/Xcode_12.4.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk" not found (ignoring for now).
Vapor 3.9.3
Python 3.9.19 (/opt/anaconda3/envs/vapor)
OpenGL 4.1 Metal - 83.1
UNSUPPORTED (log once): POSSIBLE ISSUE: unit 3 GLD_TEXTURE_INDEX_3D is unloadable and bound to sampler type (Float) - using zero texture because texture unloadable
data:image/s3,"s3://crabby-images/86cac/86cacae4030f4a30c9d8fbbc436a040cb9dd96c0" alt="../_images/e0612cb8ca7a0ecba2e349f8b3d281f77ef161e55f9415c5776077c5a5b7e960.png"
Changing Opacities
We created a volume rendering however it is fully opaque. We can use a transfer function to adjust the visible portions. Before we adjust the opacity map of the TF, we get a histogram to help us determine what we want to hide.
histogram.ShowMatPlotLibHistogram(ses, ren)
data:image/s3,"s3://crabby-images/9481c/9481cf8055b95cdefcbe87d3570b84938cad3060" alt="../_images/9996235b994e2413a963f3c5dcaf7e815ee7665dcad94acc7fc770b3e82d3bf4.png"
Usually we want to hide the most common value so below we construct an opacity map that accomplishes this.
# List of x,y pairs where x is the data value and y is the opacity for that data value
opacities = [(-0.3, 1), (-0.1, 0), (0.1, 0), (0.3, 1)]
We can get the matplotlib histogram plot and add our opacity map to it to compare.
plt = histogram.GetMatPlotLibHistogram(ses, ren)
plt.plot(*zip(*opacities))
plt.show()
data:image/s3,"s3://crabby-images/0d41d/0d41ddc2bd5e1d63f38ae6032239c93c1bc96e70" alt="../_images/b7191fd7c490c8f5163acf3c5c1a2f5e8df20510f3cf6cbe80ce63eb3c64b612.png"
Now we apply the map to the transfer function
# Renderers can have multiple transfer functions.
# GetPrimaryTransferFunction returns the one that is usually the most useful.
# You can use `tf.GetTransferFunction(var_name)` to get other transfer functions.
tf = ren.GetPrimaryTransferFunction()
tf.SetOpacityControlPoints(opacities)
ses.Show()
data:image/s3,"s3://crabby-images/0ba17/0ba17e697edbc9a7757736c644dc35eb3a5aa14d" alt="../_images/a99e7785df071fdca34f57b23ada7010809ad4a6cb9f89e8da31b32e5452f654.png"
You can adjust the colormap in a similar fashion. Use help(tf)
for more information.
Vapor includes a list of built-in colormaps and these can be applied with tf.LoadBuiltinColormap(name)
Builtin Colormaps
tf.LoadBuiltinColormap("Sequential/BlackBodyExtended")
ses.Show()
data:image/s3,"s3://crabby-images/6b280/6b280219acddf73798332e5e33c2059497feea1a" alt="../_images/9e0aad32a7f67d201b97538801082c6021185e88a5f12b8e143ef3370b1bb416.png"
List of All Builtin Colormaps
ses.DeleteRenderer(ren)
ren = data.NewRenderer(renderer.TwoDDataRenderer)
tf = ren.GetPrimaryTransferFunction()
for cmap in transferfunction.TransferFunction.ListBuiltinColormaps():
tf.LoadBuiltinColormap(cmap)
print(cmap)
tf.ShowMatPlotLibColorbar()
Highlighting/topo
data:image/s3,"s3://crabby-images/d64f6/d64f601d30403976025c54581eb7ba02d54a2444" alt="../_images/6b974b7eefe2bb929945df70bcf142b70b163c08651a14b626539aca86be502b.png"
Highlighting/oxy
data:image/s3,"s3://crabby-images/c8425/c8425c8ee7216b3dcb53a4c9f67172e558d6c91e" alt="../_images/0185659624893a6c60432010b08fcad95991266fdbdfa3fc7ebf54abeb7ab35f.png"
Diverging/tarn
data:image/s3,"s3://crabby-images/f5053/f50532855aefbddee5421e891cab4d13456c01e7" alt="../_images/f063f27e0160fcaf6706ed7f0e05a5399db1556a0c04205303b16ccba6e3ac1d.png"
Diverging/curl
data:image/s3,"s3://crabby-images/c4767/c476734fda8a27a0fccc4881fa0a73ceb660adcf" alt="../_images/a253968331f1494c900605ce41c4559341d0ec9340db7f50d244d710ca09aa84.png"
Diverging/CoolWarmSmooth
data:image/s3,"s3://crabby-images/913b3/913b3249cba6f01f3cd29c8b0dce78a91a4ca57b" alt="../_images/404576a499c96426d82008be790950acd410bd71be5258241b48fc0a1073f3f5.png"
Diverging/PurpleWhiteOrange
data:image/s3,"s3://crabby-images/12ab8/12ab8830adb3fa002c3b12de2d752f155b22a5ff" alt="../_images/d593c54c9af6f18410f56c56d270e3afda7482479b5ebd49772bfd716f8a237f.png"
Diverging/diff
data:image/s3,"s3://crabby-images/3fe67/3fe67ab33ef4ec6babe05736a3ad23ae476c7cfe" alt="../_images/cf52bc63e268a3505a070729c05d7d12e5ca563464fc7599bf12b7d2a2e4fce3.png"
Diverging/GreenWhiteRed
data:image/s3,"s3://crabby-images/8a0ae/8a0ae8b19a433d3ab821184a4f62ff5f961678a3" alt="../_images/d1233391a458b9ef573fef05693ddfa93cd4363e0393213347827bd66ec78663.png"
Diverging/CoolWarmBent
data:image/s3,"s3://crabby-images/6f599/6f5994938998ed4c36e73d526dffbb0bcb5f6eae" alt="../_images/da7b075b2491daea08671d513df2e2ead11846c6b954f08d606e9dfe24f44459.png"
Diverging/BlueWhiteGold
data:image/s3,"s3://crabby-images/4489f/4489f4cc39f692b0982637432ad945bca03fb1e4" alt="../_images/8940709aa905b893b83fb8e7adbefe62271f0736913bb9550f88b20d7596a813.png"
Diverging/CoolWarm
data:image/s3,"s3://crabby-images/29fda/29fdaeeeeeee8b8b4fa133764ce21f468337a875" alt="../_images/f496790457f502ee84c3dea8b4c1231d2a8d5df553045df38972ceedb4287dfb.png"
Diverging/GreenWhitePurple
data:image/s3,"s3://crabby-images/aa8fd/aa8fdbce5003b16803c8b08f4f36e737f96da56f" alt="../_images/6161270fd700a5920690a64fc4bb81f2959356d62172fa6c662b3383d5d6163a.png"
Diverging/balance
data:image/s3,"s3://crabby-images/aea58/aea58ddcd9e13b2fc1a11602ad3f04b11a4bd40c" alt="../_images/d5866d369466ce27ce73b51966cb0e3731102d573faada7e6dccae1aba46a80d.png"
Diverging/delta
data:image/s3,"s3://crabby-images/a08df/a08df2c6d832d9b4bd03b0dea1b7cf1e5b2ca848" alt="../_images/7c61f042a38b06054c49f3e0ee4ac7dde823916fc9df270146682eb31fef5209.png"
Sequential/BlackBody
data:image/s3,"s3://crabby-images/a99f6/a99f6387505af1795a178e83ed468ce4c60eaf6f" alt="../_images/15b6d0f95d7a31f1cd966b17dd068ad960e72a4e1feb57a161aed19392cd6690.png"
Sequential/thermal
data:image/s3,"s3://crabby-images/c8718/c871801c9d4ee4842739ce2891c1b567e888803c" alt="../_images/3137abe91fb7140eb48d0bfc837557b9eb69285a669a614802dd803f932882d8.png"
Sequential/tempo
data:image/s3,"s3://crabby-images/a362c/a362cd03ad40b52e4aff2bc7a42cf52fb29bcd91" alt="../_images/484ee4f8cafd4dca49b955c2564360ab508815b9c72f97d3062b97617bd31b5d.png"
Sequential/speed
data:image/s3,"s3://crabby-images/ed265/ed265c9d56c9c360791408ce59c3f5262168b3eb" alt="../_images/1cdd77086e340fc2ee3ab0097e918a21f1b6750eb4d8649bf1641b923761e2e8.png"
Sequential/Kindlmann
data:image/s3,"s3://crabby-images/e6fb9/e6fb91e73470c1815663ea91a6add23de676fc98" alt="../_images/2328f1878b7006757ecce8a2f3f109d4f3c91897ae14f390dd6011e7e0d34ff6.png"
Sequential/KindlmannExtended
data:image/s3,"s3://crabby-images/710ce/710ce627368295b46f7b86a0671b717c8a0198f6" alt="../_images/f1f58f4ad28d90c3d0f50f51fb48bd47b6f92c01fd40733f4a1abd5ec8e3f928.png"
Sequential/algae
data:image/s3,"s3://crabby-images/640b3/640b3fa9a76698fba1714a0a920c200f9fac5ba4" alt="../_images/e568e35fa14bf565795710fbbd4495c0efec73cd5891d385604199c986c85876.png"
Sequential/deep
data:image/s3,"s3://crabby-images/529b6/529b651302b3a1d8e3f780d2dc36db32f2f8ed7c" alt="../_images/d12004b3f2e89283ae9f21a302711bd92c4d20b5c9ab549ad702f6b094f1761c.png"
Sequential/haline
data:image/s3,"s3://crabby-images/6f438/6f43874d71ca77124d397c03ba16a371e3c5bdd8" alt="../_images/7869fd55b46c668c0861d930238ac46f7ad55053830c3f52347b7387b6802a37.png"
Sequential/turbid
data:image/s3,"s3://crabby-images/12d6b/12d6b05ff539b0367f82376a099244a47b390b20" alt="../_images/c0c2860b0168d387fdb9650ff59f795a839a8d33ddf8a9afeef612f168edcf35.png"
Sequential/rain
data:image/s3,"s3://crabby-images/7a6b9/7a6b9687987b09f56871e77bc0b7d3bafa36fe2e" alt="../_images/10751c42c7ef1399ae2767e95482197a7a9f5f6c77116275b0e9c092f54e330b.png"
Sequential/Rainbow
data:image/s3,"s3://crabby-images/502fe/502fe3b8f60a2f2c2bb5d44420be0e51bf898619" alt="../_images/4fbdae4a11ed3a6309a99520d556ef76dcb7d411b09abfda79cb49d632f4684f.png"
Sequential/phase
data:image/s3,"s3://crabby-images/ceaf7/ceaf75027af91960162a6923fe007765850d1375" alt="../_images/ec47d34e74c2812bb1b0a29b4dfc1bb9341c960214f54ec9e8c7ccdc19b475d0.png"
Sequential/BlackBodyExtended
data:image/s3,"s3://crabby-images/60574/60574d39c05db7d2bfe53927d5d4d1d611ba0084" alt="../_images/2be121a98d68a32757e9815b235f24694518f079538074bff4f09161520320c4.png"
Sequential/dense
data:image/s3,"s3://crabby-images/72db7/72db7bed0e53e58bfd3af5cea893eb5549cbcfad" alt="../_images/60da62d72e02350ce586ace93807801917526caffdff7ccb9a7bfab9a8cd9dd1.png"
Sequential/amp
data:image/s3,"s3://crabby-images/8ef5c/8ef5c6cc4dfb70437838d9c4410e403bb55e7af6" alt="../_images/c0fe58598ba82e38a00a03159b7b445e180087e82ee7d49c1e9a6249327dc2ca.png"
Sequential/ice
data:image/s3,"s3://crabby-images/cbcbd/cbcbd1f7cc87bc55a18b815886c5402bcad8a09a" alt="../_images/7d9d584287392e88ecb18c9aeabdb4993c8051413b125159fe264e67a357e3d5.png"
Sequential/matter
data:image/s3,"s3://crabby-images/e7a57/e7a57f0c194249094cad017291e76494e868e0c6" alt="../_images/4bdfbe5aef5b19258e743865c9544ddd8c2535db0391495f73d88b62baf367d0.png"
Sequential/BlackWhite
data:image/s3,"s3://crabby-images/72cb9/72cb994f4c012d247b3a1079cd51fbce0ee8911b" alt="../_images/e760eb99826e781338474c1870cb287a8398d61acd2126ce2afd91165925309d.png"
Sequential/solar
data:image/s3,"s3://crabby-images/e3a85/e3a8504f76904ff1c29e79117fb94664b861796a" alt="../_images/866a60d9bede2f44818a917f4fce41e7c482ecd5ca638ae47940a6dc582eba0f.png"